logs (example 3.8)

Time bar (total: 5.5s)

start0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated

analyze0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%23.7%76.3%0%0%0%0
100%23.7%0%76.3%0%0%0%1
Compiler

Compiled 19 to 12 computations (36.8% saved)

sample3.4s (62.2%)

Memory
-51.4MiB live, 3 101.3MiB allocated
Samples
3.0s8 256×1valid
Precisions
Click to see histograms. Total time spent on operations: 2.7s
ival-log1p: 998.0ms (36.5% of total)
ival-log: 723.0ms (26.4% of total)
ival-sub: 302.0ms (11% of total)
ival-mult: 300.0ms (11% of total)
adjust: 273.0ms (10% of total)
ival-add: 100.0ms (3.7% of total)
ival->: 25.0ms (0.9% of total)
exact: 11.0ms (0.4% of total)
ival-assert: 4.0ms (0.1% of total)
Bogosity

explain291.0ms (5.3%)

Memory
-27.0MiB live, 289.1MiB allocated
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
2560-0-(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))
00-0-n
00-0-(*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64))))
00-0-#s(literal 1 binary64)
00-0-(+.f64 n #s(literal 1 binary64))
00-0-(log.f64 n)
00-0-(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
00-0-(*.f64 n (log.f64 n))
00-0-(log.f64 (+.f64 n #s(literal 1 binary64)))
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
-.f64(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))cancellation2500
-.f64(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))nan-rescue60
(*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64))))overflow6
(*.f64 n (log.f64 n))overflow6
Confusion
Predicted +Predicted -
+2560
-00
Precision
1.0
Recall
1.0
Confusion?
Predicted +Predicted MaybePredicted -
+25600
-000
Precision?
1.0
Recall?
1.0
Freqs
test
numberfreq
1256
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
195.0ms512×1valid
Compiler

Compiled 121 to 31 computations (74.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 172.0ms
ival-mult: 44.0ms (25.6% of total)
ival-log1p: 37.0ms (21.5% of total)
ival-log: 36.0ms (20.9% of total)
ival-sub: 34.0ms (19.8% of total)
adjust: 14.0ms (8.1% of total)
ival-add: 5.0ms (2.9% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)

preprocess96.0ms (1.8%)

Memory
14.3MiB live, 88.0MiB allocated
Algorithm
egg-herbie
Rules
1 408×lower-fma.f64
1 408×lower-fma.f32
360×lower-+.f32
360×lower--.f32
358×lower-+.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01137
13333
28832
328632
474632
5138832
6184432
7186232
0915
01615
13115
25915
312315
425815
549315
684915
7120115
8140015
9141715
0141711
Stop Event
iter limit
saturated
iter limit
saturated
Calls
Call 1
Inputs
(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
Outputs
(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
(fma.f64 (-.f64 (log1p.f64 n) (log.f64 n)) n (-.f64 (log1p.f64 n) #s(literal 1 binary64)))
Compiler

Compiled 15 to 9 computations (40% saved)

eval0.0ms (0%)

Memory
0.5MiB live, 0.5MiB allocated
Compiler

Compiled 0 to 1 computations (-∞% saved)

prune1.0ms (0%)

Memory
1.3MiB live, 1.3MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
1.5%
(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
Compiler

Compiled 15 to 9 computations (40% saved)

simplify192.0ms (3.5%)

Memory
2.1MiB live, 39.5MiB allocated
Algorithm
egg-herbie
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(+.f64 n #s(literal 1 binary64))
cost-diff0
(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
cost-diff192
(log.f64 (+.f64 n #s(literal 1 binary64)))
cost-diff320
(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))
Rules
1 408×lower-fma.f64
1 408×lower-fma.f32
360×lower-+.f32
360×lower--.f32
358×lower-+.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0951
01651
13151
25951
312351
425851
549351
684951
7120151
8140051
9141751
0141739
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))
(*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64))))
(+.f64 n #s(literal 1 binary64))
n
#s(literal 1 binary64)
(log.f64 (+.f64 n #s(literal 1 binary64)))
(*.f64 n (log.f64 n))
(log.f64 n)
Outputs
(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
(fma.f64 (-.f64 (log1p.f64 n) (log.f64 n)) n (-.f64 (log1p.f64 n) #s(literal 1 binary64)))
(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))
(fma.f64 (-.f64 (log1p.f64 n) (log.f64 n)) n (log1p.f64 n))
(*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64))))
(fma.f64 (log1p.f64 n) n (log1p.f64 n))
(+.f64 n #s(literal 1 binary64))
(-.f64 n #s(literal -1 binary64))
n
#s(literal 1 binary64)
(log.f64 (+.f64 n #s(literal 1 binary64)))
(log1p.f64 n)
(*.f64 n (log.f64 n))
(*.f64 (log.f64 n) n)
(log.f64 n)

localize137.0ms (2.5%)

Memory
-11.5MiB live, 109.0MiB allocated
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0
(log.f64 n)
accuracy0.2109375
(*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64))))
accuracy0.21484375
(*.f64 n (log.f64 n))
accuracy61.90452455050973
(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))
Samples
124.0ms256×1valid
Compiler

Compiled 53 to 11 computations (79.2% saved)

Precisions
Click to see histograms. Total time spent on operations: 64.0ms
ival-log1p: 19.0ms (29.5% of total)
ival-log: 17.0ms (26.4% of total)
ival-add: 10.0ms (15.5% of total)
adjust: 7.0ms (10.9% of total)
ival-mult: 6.0ms (9.3% of total)
ival-sub: 4.0ms (6.2% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)

series72.0ms (1.3%)

Memory
3.8MiB live, 92.9MiB allocated
Counts
7 → 84
Calls
Call 1
Inputs
#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())
#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())
#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())
#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())
#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())
#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())
#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())
Outputs
#s(alt (* n (- 1 (log n))) (taylor 0 n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (* n (- (+ 1 (* 1/2 n)) (log n))) (taylor 0 n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n))) (taylor 0 n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (* n (- (+ 1 (* n (+ 1/2 (* n (- (* 1/12 n) 1/6))))) (log n))) (taylor 0 n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt n (taylor 0 n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (* -1/2 n))) (taylor 0 n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (* n (- (* 1/3 n) 1/2)))) (taylor 0 n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (* n (- (* n (+ 1/3 (* -1/4 n))) 1/2)))) (taylor 0 n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt -1 (taylor 0 n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (- (* n (- 1 (log n))) 1) (taylor 0 n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (- (* n (- (+ 1 (* 1/2 n)) (log n))) 1) (taylor 0 n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (- (* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n))) 1) (taylor 0 n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt 1 (taylor 0 n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ 1 n) (taylor 0 n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ 1 n) (taylor 0 n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ 1 n) (taylor 0 n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (* n (log n)) (taylor 0 n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* n (log n)) (taylor 0 n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* n (log n)) (taylor 0 n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* n (log n)) (taylor 0 n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt n (taylor 0 n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (* 1/2 n))) (taylor 0 n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (* n (+ 1/2 (* -1/6 n))))) (taylor 0 n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (* n (+ 1/2 (* n (- (* 1/12 n) 1/6)))))) (taylor 0 n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (log n) (taylor 0 n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (log n) (taylor 0 n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (log n) (taylor 0 n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (log n) (taylor 0 n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (+ 1 (* -1 (log (/ 1 n)))) (taylor inf n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (+ 1 (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n)))) (taylor inf n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (- (+ 1 (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n)))) (/ 1/6 (pow n 2))) (taylor inf n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (- (+ 1 (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3)))))) (/ 1/6 (pow n 2))) (taylor inf n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (+ (* -1 (log (/ 1 n))) (/ 1 n)) (taylor inf n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (- (+ (* -1 (log (/ 1 n))) (/ 1 n)) (/ 1/2 (pow n 2))) (taylor inf n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (- (+ (* -1 (log (/ 1 n))) (+ (/ 1 n) (* 1/3 (/ 1 (pow n 3))))) (/ 1/2 (pow n 2))) (taylor inf n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (taylor inf n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (- (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (/ 1/6 (pow n 2))) (taylor inf n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (- (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3))))) (/ 1/6 (pow n 2))) (taylor inf n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt n (taylor inf n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (/ 1 n))) (taylor inf n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (/ 1 n))) (taylor inf n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (/ 1 n))) (taylor inf n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* n (log (/ 1 n)))) (taylor inf n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* n (log (/ 1 n)))) (taylor inf n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* n (log (/ 1 n)))) (taylor inf n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* n (log (/ 1 n)))) (taylor inf n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* n (log (/ 1 n)))) (taylor inf n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (* n (+ (* -1 (log (/ 1 n))) (+ (* -1 (/ (log (/ 1 n)) n)) (/ 1 n)))) (taylor inf n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (* n (+ (* -1 (log (/ 1 n))) (+ (* -1 (/ (log (/ 1 n)) n)) (+ (/ 1/2 (pow n 2)) (/ 1 n))))) (taylor inf n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (* n (- (+ (* -1 (log (/ 1 n))) (+ (* -1 (/ (log (/ 1 n)) n)) (+ (/ 1/2 (pow n 2)) (/ 1 n)))) (* 1/6 (/ 1 (pow n 3))))) (taylor inf n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (+ 1 (+ (log -1) (* -1 (log (/ -1 n))))) (taylor -inf n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n))))) (taylor -inf n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n))))) (taylor -inf n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n))))) (taylor -inf n) (#s(alt (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) (patch (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (/ 1 n))) (taylor -inf n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/2 (/ 1 n)) 1) n)))) (taylor -inf n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/3 (/ 1 n)) 1/2) n)) 1) n)))) (taylor -inf n) (#s(alt (log.f64 (+.f64 n #s(literal 1 binary64))) (patch (log.f64 (+.f64 n #s(literal 1 binary64))) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n)))) (taylor -inf n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n)))) (taylor -inf n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n)))) (taylor -inf n) (#s(alt (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) (patch (-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt n (taylor -inf n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (/ 1 n))) (taylor -inf n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (/ 1 n))) (taylor -inf n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (* n (+ 1 (/ 1 n))) (taylor -inf n) (#s(alt (+.f64 n #s(literal 1 binary64)) (patch (+.f64 n #s(literal 1 binary64)) #<representation binary64>) () ())) ())
#s(alt (* n (+ (log -1) (* -1 (log (/ -1 n))))) (taylor -inf n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* n (+ (log -1) (* -1 (log (/ -1 n))))) (taylor -inf n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* n (+ (log -1) (* -1 (log (/ -1 n))))) (taylor -inf n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* n (+ (log -1) (* -1 (log (/ -1 n))))) (taylor -inf n) (#s(alt (*.f64 n (log.f64 n)) (patch (*.f64 n (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* n (+ (log -1) (* -1 (log (/ -1 n))))) (taylor -inf n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* n (+ (* -1 (+ (log -1) (* -1 (log (/ -1 n))))) (* -1 (/ (+ 1 (+ (log -1) (* -1 (log (/ -1 n))))) n))))) (taylor -inf n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* n (+ (* -1 (+ (log -1) (* -1 (log (/ -1 n))))) (* -1 (/ (+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n))))) n))))) (taylor -inf n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* n (+ (* -1 (+ (log -1) (* -1 (log (/ -1 n))))) (* -1 (/ (+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n))))) n))))) (taylor -inf n) (#s(alt (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (patch (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
Calls

3 calls:

TimeVariablePointExpression
40.0ms
n
@0
((- (* (+ n 1) (log (+ n 1))) (* n (log n))) (log (+ n 1)) (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (+ n 1) (* n (log n)) (* (+ n 1) (log (+ n 1))) (log n))
16.0ms
n
@inf
((- (* (+ n 1) (log (+ n 1))) (* n (log n))) (log (+ n 1)) (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (+ n 1) (* n (log n)) (* (+ n 1) (log (+ n 1))) (log n))
13.0ms
n
@-inf
((- (* (+ n 1) (log (+ n 1))) (* n (log n))) (log (+ n 1)) (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (+ n 1) (* n (log n)) (* (+ n 1) (log (+ n 1))) (log n))

simplify142.0ms (2.6%)

Memory
-0.6MiB live, 110.3MiB allocated
Algorithm
egg-herbie
Rules
12 630×lower-fma.f64
12 630×lower-fma.f32
3 314×lower-+.f64
3 314×lower-+.f32
2 944×lower--.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0157804
1496733
21409710
34863694
08508665
Stop Event
iter limit
node limit
Counts
84 → 80
Calls
Call 1
Inputs
(* n (- 1 (log n)))
(* n (- (+ 1 (* 1/2 n)) (log n)))
(* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n)))
(* n (- (+ 1 (* n (+ 1/2 (* n (- (* 1/12 n) 1/6))))) (log n)))
n
(* n (+ 1 (* -1/2 n)))
(* n (+ 1 (* n (- (* 1/3 n) 1/2))))
(* n (+ 1 (* n (- (* n (+ 1/3 (* -1/4 n))) 1/2))))
-1
(- (* n (- 1 (log n))) 1)
(- (* n (- (+ 1 (* 1/2 n)) (log n))) 1)
(- (* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n))) 1)
1
(+ 1 n)
(+ 1 n)
(+ 1 n)
(* n (log n))
(* n (log n))
(* n (log n))
(* n (log n))
n
(* n (+ 1 (* 1/2 n)))
(* n (+ 1 (* n (+ 1/2 (* -1/6 n)))))
(* n (+ 1 (* n (+ 1/2 (* n (- (* 1/12 n) 1/6))))))
(log n)
(log n)
(log n)
(log n)
(+ 1 (* -1 (log (/ 1 n))))
(+ 1 (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))))
(- (+ 1 (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n)))) (/ 1/6 (pow n 2)))
(- (+ 1 (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3)))))) (/ 1/6 (pow n 2)))
(* -1 (log (/ 1 n)))
(+ (* -1 (log (/ 1 n))) (/ 1 n))
(- (+ (* -1 (log (/ 1 n))) (/ 1 n)) (/ 1/2 (pow n 2)))
(- (+ (* -1 (log (/ 1 n))) (+ (/ 1 n) (* 1/3 (/ 1 (pow n 3))))) (/ 1/2 (pow n 2)))
(* -1 (log (/ 1 n)))
(+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n)))
(- (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (/ 1/6 (pow n 2)))
(- (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3))))) (/ 1/6 (pow n 2)))
n
(* n (+ 1 (/ 1 n)))
(* n (+ 1 (/ 1 n)))
(* n (+ 1 (/ 1 n)))
(* -1 (* n (log (/ 1 n))))
(* -1 (* n (log (/ 1 n))))
(* -1 (* n (log (/ 1 n))))
(* -1 (* n (log (/ 1 n))))
(* -1 (* n (log (/ 1 n))))
(* n (+ (* -1 (log (/ 1 n))) (+ (* -1 (/ (log (/ 1 n)) n)) (/ 1 n))))
(* n (+ (* -1 (log (/ 1 n))) (+ (* -1 (/ (log (/ 1 n)) n)) (+ (/ 1/2 (pow n 2)) (/ 1 n)))))
(* n (- (+ (* -1 (log (/ 1 n))) (+ (* -1 (/ (log (/ 1 n)) n)) (+ (/ 1/2 (pow n 2)) (/ 1 n)))) (* 1/6 (/ 1 (pow n 3)))))
(* -1 (log (/ 1 n)))
(* -1 (log (/ 1 n)))
(* -1 (log (/ 1 n)))
(* -1 (log (/ 1 n)))
(+ 1 (+ (log -1) (* -1 (log (/ -1 n)))))
(+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n)))))
(+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n)))))
(+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n)))))
(+ (log -1) (* -1 (log (/ -1 n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (/ 1 n)))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/2 (/ 1 n)) 1) n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/3 (/ 1 n)) 1/2) n)) 1) n))))
(+ (log -1) (* -1 (log (/ -1 n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n))))
n
(* n (+ 1 (/ 1 n)))
(* n (+ 1 (/ 1 n)))
(* n (+ 1 (/ 1 n)))
(* n (+ (log -1) (* -1 (log (/ -1 n)))))
(* n (+ (log -1) (* -1 (log (/ -1 n)))))
(* n (+ (log -1) (* -1 (log (/ -1 n)))))
(* n (+ (log -1) (* -1 (log (/ -1 n)))))
(* n (+ (log -1) (* -1 (log (/ -1 n)))))
(* -1 (* n (+ (* -1 (+ (log -1) (* -1 (log (/ -1 n))))) (* -1 (/ (+ 1 (+ (log -1) (* -1 (log (/ -1 n))))) n)))))
(* -1 (* n (+ (* -1 (+ (log -1) (* -1 (log (/ -1 n))))) (* -1 (/ (+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n))))) n)))))
(* -1 (* n (+ (* -1 (+ (log -1) (* -1 (log (/ -1 n))))) (* -1 (/ (+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n))))) n)))))
(+ (log -1) (* -1 (log (/ -1 n))))
(+ (log -1) (* -1 (log (/ -1 n))))
(+ (log -1) (* -1 (log (/ -1 n))))
(+ (log -1) (* -1 (log (/ -1 n))))
Outputs
(* n (- 1 (log n)))
(fma.f64 (neg.f64 n) (log.f64 n) n)
(* n (- (+ 1 (* 1/2 n)) (log n)))
(*.f64 (-.f64 (fma.f64 #s(literal 1/2 binary64) n #s(literal 1 binary64)) (log.f64 n)) n)
(* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n)))
(*.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) n #s(literal 1/2 binary64)) n (-.f64 #s(literal 1 binary64) (log.f64 n))) n)
(* n (- (+ 1 (* n (+ 1/2 (* n (- (* 1/12 n) 1/6))))) (log n)))
(*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/12 binary64) n #s(literal -1/6 binary64)) n #s(literal 1/2 binary64)) n (-.f64 #s(literal 1 binary64) (log.f64 n))) n)
n
(* n (+ 1 (* -1/2 n)))
(*.f64 (fma.f64 #s(literal -1/2 binary64) n #s(literal 1 binary64)) n)
(* n (+ 1 (* n (- (* 1/3 n) 1/2))))
(*.f64 (fma.f64 (fma.f64 #s(literal 1/3 binary64) n #s(literal -1/2 binary64)) n #s(literal 1 binary64)) n)
(* n (+ 1 (* n (- (* n (+ 1/3 (* -1/4 n))) 1/2))))
(*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/4 binary64) n #s(literal 1/3 binary64)) n #s(literal -1/2 binary64)) n #s(literal 1 binary64)) n)
-1
#s(literal -1 binary64)
(- (* n (- 1 (log n))) 1)
(fma.f64 (-.f64 #s(literal 1 binary64) (log.f64 n)) n #s(literal -1 binary64))
(- (* n (- (+ 1 (* 1/2 n)) (log n))) 1)
(fma.f64 (-.f64 (fma.f64 #s(literal 1/2 binary64) n #s(literal 1 binary64)) (log.f64 n)) n #s(literal -1 binary64))
(- (* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n))) 1)
(fma.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) n #s(literal 1/2 binary64)) n (-.f64 #s(literal 1 binary64) (log.f64 n))) n #s(literal -1 binary64))
1
#s(literal 1 binary64)
(+ 1 n)
(+.f64 #s(literal 1 binary64) n)
(+ 1 n)
(+.f64 #s(literal 1 binary64) n)
(+ 1 n)
(+.f64 #s(literal 1 binary64) n)
(* n (log n))
(*.f64 (log.f64 n) n)
(* n (log n))
(*.f64 (log.f64 n) n)
(* n (log n))
(*.f64 (log.f64 n) n)
(* n (log n))
(*.f64 (log.f64 n) n)
n
(* n (+ 1 (* 1/2 n)))
(*.f64 (fma.f64 #s(literal 1/2 binary64) n #s(literal 1 binary64)) n)
(* n (+ 1 (* n (+ 1/2 (* -1/6 n)))))
(*.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) n #s(literal 1/2 binary64)) n #s(literal 1 binary64)) n)
(* n (+ 1 (* n (+ 1/2 (* n (- (* 1/12 n) 1/6))))))
(*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/12 binary64) n #s(literal -1/6 binary64)) n #s(literal 1/2 binary64)) n #s(literal 1 binary64)) n)
(log n)
(log.f64 n)
(log n)
(log.f64 n)
(log n)
(log.f64 n)
(log n)
(log.f64 n)
(+ 1 (* -1 (log (/ 1 n))))
(+.f64 (log.f64 n) #s(literal 1 binary64))
(+ 1 (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))))
(+.f64 (+.f64 (/.f64 #s(literal 1/2 binary64) n) #s(literal 1 binary64)) (log.f64 n))
(- (+ 1 (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n)))) (/ 1/6 (pow n 2)))
(-.f64 (+.f64 (log.f64 n) #s(literal 1 binary64)) (/.f64 (-.f64 (/.f64 #s(literal 1/6 binary64) n) #s(literal 1/2 binary64)) n))
(- (+ 1 (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3)))))) (/ 1/6 (pow n 2)))
(+.f64 (-.f64 #s(literal 1 binary64) (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1/12 binary64) n) #s(literal 1/6 binary64)) n)) n)) (log.f64 n))
(* -1 (log (/ 1 n)))
(log.f64 n)
(+ (* -1 (log (/ 1 n))) (/ 1 n))
(+.f64 (log.f64 n) (/.f64 #s(literal 1 binary64) n))
(- (+ (* -1 (log (/ 1 n))) (/ 1 n)) (/ 1/2 (pow n 2)))
(-.f64 (log.f64 n) (/.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) n) #s(literal 1 binary64)) n))
(- (+ (* -1 (log (/ 1 n))) (+ (/ 1 n) (* 1/3 (/ 1 (pow n 3))))) (/ 1/2 (pow n 2)))
(+.f64 (/.f64 (-.f64 (/.f64 (-.f64 (/.f64 #s(literal 1/3 binary64) n) #s(literal 1/2 binary64)) n) #s(literal -1 binary64)) n) (log.f64 n))
(* -1 (log (/ 1 n)))
(log.f64 n)
(+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n)))
(+.f64 (/.f64 #s(literal 1/2 binary64) n) (log.f64 n))
(- (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (/ 1/6 (pow n 2)))
(-.f64 (log.f64 n) (/.f64 (-.f64 (/.f64 #s(literal 1/6 binary64) n) #s(literal 1/2 binary64)) n))
(- (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3))))) (/ 1/6 (pow n 2)))
(+.f64 (/.f64 (-.f64 (/.f64 (-.f64 (/.f64 #s(literal 1/12 binary64) n) #s(literal 1/6 binary64)) n) #s(literal -1/2 binary64)) n) (log.f64 n))
n
(* n (+ 1 (/ 1 n)))
(+.f64 #s(literal 1 binary64) n)
(* n (+ 1 (/ 1 n)))
(+.f64 #s(literal 1 binary64) n)
(* n (+ 1 (/ 1 n)))
(+.f64 #s(literal 1 binary64) n)
(* -1 (* n (log (/ 1 n))))
(*.f64 (log.f64 n) n)
(* -1 (* n (log (/ 1 n))))
(*.f64 (log.f64 n) n)
(* -1 (* n (log (/ 1 n))))
(*.f64 (log.f64 n) n)
(* -1 (* n (log (/ 1 n))))
(*.f64 (log.f64 n) n)
(* -1 (* n (log (/ 1 n))))
(*.f64 (log.f64 n) n)
(* n (+ (* -1 (log (/ 1 n))) (+ (* -1 (/ (log (/ 1 n)) n)) (/ 1 n))))
(fma.f64 (log.f64 n) n (+.f64 (log.f64 n) #s(literal 1 binary64)))
(* n (+ (* -1 (log (/ 1 n))) (+ (* -1 (/ (log (/ 1 n)) n)) (+ (/ 1/2 (pow n 2)) (/ 1 n)))))
(fma.f64 (/.f64 (/.f64 #s(literal 1/2 binary64) n) n) n (fma.f64 (log.f64 n) n (+.f64 (log.f64 n) #s(literal 1 binary64))))
(* n (- (+ (* -1 (log (/ 1 n))) (+ (* -1 (/ (log (/ 1 n)) n)) (+ (/ 1/2 (pow n 2)) (/ 1 n)))) (* 1/6 (/ 1 (pow n 3)))))
(fma.f64 (/.f64 #s(literal -1/6 binary64) (pow.f64 n #s(literal 3 binary64))) n (fma.f64 (/.f64 (/.f64 #s(literal 1/2 binary64) n) n) n (fma.f64 (log.f64 n) n (+.f64 (log.f64 n) #s(literal 1 binary64)))))
(* -1 (log (/ 1 n)))
(log.f64 n)
(* -1 (log (/ 1 n)))
(log.f64 n)
(* -1 (log (/ 1 n)))
(log.f64 n)
(* -1 (log (/ 1 n)))
(log.f64 n)
(+ 1 (+ (log -1) (* -1 (log (/ -1 n)))))
(-.f64 (+.f64 (log.f64 #s(literal -1 binary64)) #s(literal 1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n)))
(+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n)))))
(+.f64 (+.f64 (/.f64 #s(literal 1/2 binary64) n) #s(literal 1 binary64)) (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))))
(+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n)))))
(-.f64 (-.f64 (+.f64 (log.f64 #s(literal -1 binary64)) #s(literal 1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) (/.f64 (-.f64 (/.f64 #s(literal 1/6 binary64) n) #s(literal 1/2 binary64)) n))
(+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n)))))
(-.f64 (-.f64 (+.f64 (log.f64 #s(literal -1 binary64)) #s(literal 1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1/12 binary64) n) #s(literal 1/6 binary64)) n)) n))
(+ (log -1) (* -1 (log (/ -1 n))))
(-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n)))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (/ 1 n)))
(-.f64 (+.f64 (log.f64 #s(literal -1 binary64)) (/.f64 #s(literal 1 binary64) n)) (log.f64 (/.f64 #s(literal -1 binary64) n)))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/2 (/ 1 n)) 1) n))))
(-.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (/.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) n) #s(literal 1 binary64)) n)) (log.f64 (/.f64 #s(literal -1 binary64) n)))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/3 (/ 1 n)) 1/2) n)) 1) n))))
(-.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (/.f64 (-.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1/3 binary64) n) #s(literal 1/2 binary64)) n)) n)) (log.f64 (/.f64 #s(literal -1 binary64) n)))
(+ (log -1) (* -1 (log (/ -1 n))))
(-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n)))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n))))
(+.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) n) (log.f64 (/.f64 #s(literal -1 binary64) n))) (log.f64 #s(literal -1 binary64)))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n))))
(-.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) (/.f64 (-.f64 (/.f64 #s(literal 1/6 binary64) n) #s(literal 1/2 binary64)) n))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n))))
(-.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1/12 binary64) n) #s(literal 1/6 binary64)) n)) n))
n
(* n (+ 1 (/ 1 n)))
(+.f64 #s(literal 1 binary64) n)
(* n (+ 1 (/ 1 n)))
(+.f64 #s(literal 1 binary64) n)
(* n (+ 1 (/ 1 n)))
(+.f64 #s(literal 1 binary64) n)
(* n (+ (log -1) (* -1 (log (/ -1 n)))))
(*.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) n)
(* n (+ (log -1) (* -1 (log (/ -1 n)))))
(*.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) n)
(* n (+ (log -1) (* -1 (log (/ -1 n)))))
(*.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) n)
(* n (+ (log -1) (* -1 (log (/ -1 n)))))
(*.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) n)
(* n (+ (log -1) (* -1 (log (/ -1 n)))))
(*.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) n)
(* -1 (* n (+ (* -1 (+ (log -1) (* -1 (log (/ -1 n))))) (* -1 (/ (+ 1 (+ (log -1) (* -1 (log (/ -1 n))))) n)))))
(fma.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) n (-.f64 (+.f64 (log.f64 #s(literal -1 binary64)) #s(literal 1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))))
(* -1 (* n (+ (* -1 (+ (log -1) (* -1 (log (/ -1 n))))) (* -1 (/ (+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n))))) n)))))
(-.f64 (*.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) n) (-.f64 (+.f64 (/.f64 #s(literal -1/2 binary64) n) #s(literal -1 binary64)) (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n)))))
(* -1 (* n (+ (* -1 (+ (log -1) (* -1 (log (/ -1 n))))) (* -1 (/ (+ 1 (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n))))) n)))))
(-.f64 (*.f64 (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n))) n) (-.f64 (-.f64 (/.f64 (-.f64 (/.f64 #s(literal 1/6 binary64) n) #s(literal 1/2 binary64)) n) #s(literal 1 binary64)) (-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n)))))
(+ (log -1) (* -1 (log (/ -1 n))))
(-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n)))
(+ (log -1) (* -1 (log (/ -1 n))))
(-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n)))
(+ (log -1) (* -1 (log (/ -1 n))))
(-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n)))
(+ (log -1) (* -1 (log (/ -1 n))))
(-.f64 (log.f64 #s(literal -1 binary64)) (log.f64 (/.f64 #s(literal -1 binary64) n)))

rewrite172.0ms (3.2%)

Memory
19.4MiB live, 138.9MiB allocated
Rules
8 652×lower-fma.f64
8 652×lower-fma.f32
5 492×lower-*.f32
5 488×lower-*.f64
3 876×lower-/.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0949
01649
16649
251649
0839740
Stop Event
iter limit
node limit
iter limit
Counts
7 → 500
Calls
Call 1
Inputs
(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))
(log.f64 (+.f64 n #s(literal 1 binary64)))
(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
(+.f64 n #s(literal 1 binary64))
(*.f64 n (log.f64 n))
(*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64))))
(log.f64 n)
Outputs
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>

eval106.0ms (2%)

Memory
16.4MiB live, 132.1MiB allocated
Compiler

Compiled 19 871 to 2 121 computations (89.3% saved)

prune18.0ms (0.3%)

Memory
-9.1MiB live, 27.6MiB allocated
Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New6542656
Fresh000
Picked101
Done000
Total6552657
Accuracy
100.0%
Counts
657 → 2
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
1.6%
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
Compiler

Compiled 5 to 6 computations (-20% saved)

simplify44.0ms (0.8%)

Memory
-4.8MiB live, 33.4MiB allocated
Algorithm
egg-herbie
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
cost-diff0
(log.f64 n)
cost-diff0
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
cost-diff0
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
Rules
1 408×lower-fma.f64
1 408×lower-fma.f32
360×lower-+.f64
360×lower--.f64
360×lower-+.f32
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01339
01439
12839
25639
312039
425539
548139
683039
7116439
8135739
9137439
0137431
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
#s(literal -1 binary64)
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
(log.f64 n)
n
Outputs
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
#s(literal -1 binary64)
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
(log.f64 n)
n

localize94.0ms (1.7%)

Memory
-4.8MiB live, 83.9MiB allocated
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
accuracy0
(log.f64 n)
accuracy0
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
accuracy63.004315827234464
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
Samples
85.0ms256×1valid
Compiler

Compiled 36 to 12 computations (66.7% saved)

Precisions
Click to see histograms. Total time spent on operations: 65.0ms
ival-log: 24.0ms (37.2% of total)
ival-log1p: 19.0ms (29.4% of total)
adjust: 8.0ms (12.4% of total)
ival-mult: 6.0ms (9.3% of total)
ival-sub: 4.0ms (6.2% of total)
ival-add: 3.0ms (4.6% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)

series23.0ms (0.4%)

Memory
8.0MiB live, 44.0MiB allocated
Counts
3 → 36
Calls
Call 1
Inputs
#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())
#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())
#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())
Outputs
#s(alt -1 (taylor 0 n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (- (* n (- 1 (log n))) 1) (taylor 0 n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (- (* n (- (+ 1 (* 1/2 n)) (log n))) 1) (taylor 0 n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (- (* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n))) 1) (taylor 0 n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt -1 (taylor 0 n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (- (* n (- 1 (log n))) 1) (taylor 0 n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (- (* n (- (+ 1 (* 1/2 n)) (log n))) 1) (taylor 0 n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (- (* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n))) 1) (taylor 0 n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (log n) (taylor 0 n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (log n) (taylor 0 n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (log n) (taylor 0 n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (log n) (taylor 0 n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (taylor inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (- (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (/ 1/6 (pow n 2))) (taylor inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (- (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3))))) (/ 1/6 (pow n 2))) (taylor inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (taylor inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (- (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (/ 1/6 (pow n 2))) (taylor inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (- (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3))))) (/ 1/6 (pow n 2))) (taylor inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (* -1 (log (/ 1 n))) (taylor inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n)))) (taylor -inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n)))) (taylor -inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n)))) (taylor -inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n)))) (taylor -inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n)))) (taylor -inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n)))) (taylor -inf n) (#s(alt #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) (patch #s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n)) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
#s(alt (+ (log -1) (* -1 (log (/ -1 n)))) (taylor -inf n) (#s(alt (log.f64 n) (patch (log.f64 n) #<representation binary64>) () ())) ())
Calls

3 calls:

TimeVariablePointExpression
10.0ms
n
@inf
((- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log n))
6.0ms
n
@-inf
((- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log n))
6.0ms
n
@0
((- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log n))

simplify202.0ms (3.7%)

Memory
6.1MiB live, 131.3MiB allocated
Algorithm
egg-herbie
Rules
13 742×lower-fma.f64
13 742×lower-fma.f32
2 484×lower-+.f64
2 484×lower-+.f32
2 332×lower-*.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
061328
1159300
2382290
3957286
42620274
54930274
66112274
77139274
87558274
97776274
107916274
117916274
08031262
Stop Event
iter limit
node limit
Counts
36 → 36
Calls
Call 1
Inputs
-1
(- (* n (- 1 (log n))) 1)
(- (* n (- (+ 1 (* 1/2 n)) (log n))) 1)
(- (* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n))) 1)
-1
(- (* n (- 1 (log n))) 1)
(- (* n (- (+ 1 (* 1/2 n)) (log n))) 1)
(- (* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n))) 1)
(log n)
(log n)
(log n)
(log n)
(* -1 (log (/ 1 n)))
(+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n)))
(- (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (/ 1/6 (pow n 2)))
(- (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3))))) (/ 1/6 (pow n 2)))
(* -1 (log (/ 1 n)))
(+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n)))
(- (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (/ 1/6 (pow n 2)))
(- (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3))))) (/ 1/6 (pow n 2)))
(* -1 (log (/ 1 n)))
(* -1 (log (/ 1 n)))
(* -1 (log (/ 1 n)))
(* -1 (log (/ 1 n)))
(+ (log -1) (* -1 (log (/ -1 n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n))))
(+ (log -1) (* -1 (log (/ -1 n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n))))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n))))
(+ (log -1) (* -1 (log (/ -1 n))))
(+ (log -1) (* -1 (log (/ -1 n))))
(+ (log -1) (* -1 (log (/ -1 n))))
(+ (log -1) (* -1 (log (/ -1 n))))
Outputs
-1
#s(literal -1 binary64)
(- (* n (- 1 (log n))) 1)
(fma.f64 (-.f64 #s(literal 1 binary64) (log.f64 n)) n #s(literal -1 binary64))
(- (* n (- (+ 1 (* 1/2 n)) (log n))) 1)
(fma.f64 (fma.f64 #s(literal 1/2 binary64) n (-.f64 #s(literal 1 binary64) (log.f64 n))) n #s(literal -1 binary64))
(- (* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n))) 1)
(fma.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) n #s(literal 1/2 binary64)) n (-.f64 #s(literal 1 binary64) (log.f64 n))) n #s(literal -1 binary64))
-1
#s(literal -1 binary64)
(- (* n (- 1 (log n))) 1)
(fma.f64 (-.f64 #s(literal 1 binary64) (log.f64 n)) n #s(literal -1 binary64))
(- (* n (- (+ 1 (* 1/2 n)) (log n))) 1)
(fma.f64 (fma.f64 #s(literal 1/2 binary64) n (-.f64 #s(literal 1 binary64) (log.f64 n))) n #s(literal -1 binary64))
(- (* n (- (+ 1 (* n (+ 1/2 (* -1/6 n)))) (log n))) 1)
(fma.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) n #s(literal 1/2 binary64)) n (-.f64 #s(literal 1 binary64) (log.f64 n))) n #s(literal -1 binary64))
(log n)
(log.f64 n)
(log n)
(log.f64 n)
(log n)
(log.f64 n)
(log n)
(log.f64 n)
(* -1 (log (/ 1 n)))
(log.f64 n)
(+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n)))
(-.f64 (log.f64 n) (/.f64 #s(literal -1/2 binary64) n))
(- (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (/ 1/6 (pow n 2)))
(-.f64 (log.f64 n) (/.f64 (-.f64 (/.f64 #s(literal 1/6 binary64) n) #s(literal 1/2 binary64)) n))
(- (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3))))) (/ 1/6 (pow n 2)))
(-.f64 (log.f64 n) (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1/12 binary64) n) #s(literal 1/6 binary64)) n)) n))
(* -1 (log (/ 1 n)))
(log.f64 n)
(+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n)))
(-.f64 (log.f64 n) (/.f64 #s(literal -1/2 binary64) n))
(- (+ (* -1 (log (/ 1 n))) (* 1/2 (/ 1 n))) (/ 1/6 (pow n 2)))
(-.f64 (log.f64 n) (/.f64 (-.f64 (/.f64 #s(literal 1/6 binary64) n) #s(literal 1/2 binary64)) n))
(- (+ (* -1 (log (/ 1 n))) (+ (* 1/2 (/ 1 n)) (* 1/12 (/ 1 (pow n 3))))) (/ 1/6 (pow n 2)))
(-.f64 (log.f64 n) (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1/12 binary64) n) #s(literal 1/6 binary64)) n)) n))
(* -1 (log (/ 1 n)))
(log.f64 n)
(* -1 (log (/ 1 n)))
(log.f64 n)
(* -1 (log (/ 1 n)))
(log.f64 n)
(* -1 (log (/ 1 n)))
(log.f64 n)
(+ (log -1) (* -1 (log (/ -1 n))))
(+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64)))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n))))
(-.f64 (+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64))) (/.f64 #s(literal -1/2 binary64) n))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n))))
(-.f64 (+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64))) (/.f64 (-.f64 (/.f64 #s(literal 1/6 binary64) n) #s(literal 1/2 binary64)) n))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n))))
(-.f64 (+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64))) (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1/12 binary64) n) #s(literal 1/6 binary64)) n)) n))
(+ (log -1) (* -1 (log (/ -1 n))))
(+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64)))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* 1/2 (/ 1 n))))
(-.f64 (+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64))) (/.f64 #s(literal -1/2 binary64) n))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* 1/6 (/ 1 n)) 1/2) n))))
(-.f64 (+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64))) (/.f64 (-.f64 (/.f64 #s(literal 1/6 binary64) n) #s(literal 1/2 binary64)) n))
(+ (log -1) (+ (* -1 (log (/ -1 n))) (* -1 (/ (- (* -1 (/ (- (* 1/12 (/ 1 n)) 1/6) n)) 1/2) n))))
(-.f64 (+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64))) (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1/12 binary64) n) #s(literal 1/6 binary64)) n)) n))
(+ (log -1) (* -1 (log (/ -1 n))))
(+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64)))
(+ (log -1) (* -1 (log (/ -1 n))))
(+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64)))
(+ (log -1) (* -1 (log (/ -1 n))))
(+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64)))
(+ (log -1) (* -1 (log (/ -1 n))))
(+.f64 (log.f64 (neg.f64 n)) (log.f64 #s(literal -1 binary64)))

rewrite209.0ms (3.8%)

Memory
-6.9MiB live, 180.8MiB allocated
Rules
8 652×lower-fma.f64
8 652×lower-fma.f32
5 492×lower-*.f64
5 492×lower-*.f32
3 876×lower-/.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01337
01437
16337
251337
0838531
Stop Event
iter limit
node limit
iter limit
Counts
3 → 5
Calls
Call 1
Inputs
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
(log.f64 n)
Outputs
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>

eval3.0ms (0.1%)

Memory
7.3MiB live, 7.3MiB allocated
Compiler

Compiled 328 to 56 computations (82.9% saved)

prune3.0ms (0.1%)

Memory
7.0MiB live, 7.0MiB allocated
Pruning

2 alts after pruning (0 fresh and 2 done)

PrunedKeptTotal
New41041
Fresh000
Picked022
Done000
Total41243
Accuracy
100.0%
Counts
43 → 2
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
1.6%
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
Compiler

Compiled 25 to 18 computations (28% saved)

regimes5.0ms (0.1%)

Memory
10.1MiB live, 10.1MiB allocated
Counts
3 → 1
Calls
Call 1
Inputs
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
Outputs
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
Calls

3 calls:

2.0ms
n
1.0ms
(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))
1.0ms
(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
Results
AccuracySegmentsBranch
100.0%1n
100.0%1(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
100.0%1(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))
Compiler

Compiled 29 to 18 computations (37.9% saved)

regimes7.0ms (0.1%)

Memory
-30.4MiB live, 7.7MiB allocated
Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
Calls
Call 1
Inputs
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
Outputs
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
Calls

3 calls:

4.0ms
(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))
1.0ms
n
1.0ms
(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
Results
AccuracySegmentsBranch
1.6%1n
1.6%1(-.f64 (-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n))) #s(literal 1 binary64))
1.6%1(-.f64 (*.f64 (+.f64 n #s(literal 1 binary64)) (log.f64 (+.f64 n #s(literal 1 binary64)))) (*.f64 n (log.f64 n)))
Compiler

Compiled 29 to 18 computations (37.9% saved)

simplify25.0ms (0.5%)

Memory
-7.0MiB live, 40.5MiB allocated
Algorithm
egg-herbie
Rules
1-exp-binary32-exp.f32
1-exp-binary64-exp.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01335
11635
Stop Event
saturated
Calls
Call 1
Inputs
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))
Outputs
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) (log.f64 n))
#s(approx (- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1) #s(literal -1 binary64))

soundness185.0ms (3.4%)

Memory
-0.8MiB live, 157.9MiB allocated
Rules
12 630×lower-fma.f64
12 630×lower-fma.f32
3 314×lower-+.f64
3 314×lower-+.f32
2 944×lower--.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0157804
1496733
21409710
34863694
08508665
Stop Event
done
iter limit
node limit
Compiler

Compiled 8 to 9 computations (-12.5% saved)

preprocess33.0ms (0.6%)

Memory
34.2MiB live, 73.1MiB allocated
Compiler

Compiled 88 to 62 computations (29.5% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...