Details

Time bar (total: 12.1s)

analyze992.0ms (8.2%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
0%99.9%0.1%3
0%99.9%0.1%4
0%99.9%0.1%5
3.1%96.8%0.1%6
15.6%81.2%3.2%7
23.4%72.6%4%8
32.4%55.8%11.8%9
36.3%50.9%12.8%10
40.7%41.5%17.9%11
42.6%38.6%18.8%12
44.5%33.5%22%13
45.5%32%22.5%14
Compiler

Compiled 18 to 12 computations (33.3% saved)

sample6.9s (56.5%)

Results
2.8s1727×body2048valid
2.5s2759×body1024valid
578.0ms1240×body512valid
282.0ms1892×body128valid
167.0ms607×body256valid
160.0ms158×body1024invalid
118.0ms211×body512invalid
78.0ms31×body4096valid
72.0ms489×body128invalid
54.0ms156×body256invalid
33.0ms23×body2048invalid
Compiler

Compiled 53 to 35 computations (34% saved)

simplify42.0ms (0.3%)

Algorithm
egg-herbie
Rules
701×fma-def_binary64
563×associate-/r/_binary64
484×associate-/r*_binary64
474×associate-*l/_binary64
421×associate-/l/_binary64
Counts
1 → 2
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01122
12922
26720
316420
446320
5176120
6484720
7501320

prune4.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
46.5b
Counts
3 → 2
Alt Table
StatusErrorProgram
46.7b
(*.f64 100 (/.f64 (-.f64 (pow.f64 (+.f64 1 (/.f64 i n)) n) 1) (/.f64 i n)))
46.6b
(*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i))
Compiler

Compiled 97 to 63 computations (35.1% saved)

localize10.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)
0.0b
(*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i))
0.9b
(fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100)
8.2b
(pow.f64 (+.f64 1 (/.f64 i n)) n)

series302.0ms (2.5%)

Counts
4 → 96
Calls

4 calls:

123.0ms
(*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i))
86.0ms
(/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)
63.0ms
(fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100)
29.0ms
(pow.f64 (+.f64 1 (/.f64 i n)) n)

rewrite19.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
27×add-sqr-sqrt_binary64
24×*-un-lft-identity_binary64
22×add-cube-cbrt_binary64
19×times-frac_binary64
13×associate-*r*_binary64
Counts
4 → 93
Calls

4 calls:

6.0ms
(pow.f64 (+.f64 1 (/.f64 i n)) n)
5.0ms
(*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i))
2.0ms
(/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)
0.0ms
(fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100)

simplify207.0ms (1.7%)

Algorithm
egg-herbie
Rules
462×times-frac_binary64
322×*-commutative_binary64
293×+-commutative_binary64
262×fma-def_binary64
225×sub-neg_binary64
Counts
189 → 261
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
098210503
1314010129
248709717
349729717

prune414.0ms (3.4%)

Pruning

16 alts after pruning (16 fresh and 0 done)

PrunedKeptTotal
New24516261
Fresh101
Picked101
Done000
Total24716263
Error
1.9b
Counts
263 → 16
Alt Table
StatusErrorProgram
44.6b
(*.f64 n (/.f64 (fma.f64 100 (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n) -100) i))
54.5b
(/.f64 (*.f64 (pow.f64 n 2) (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i)
30.2b
(*.f64 100 n)
55.0b
(*.f64 n (-.f64 (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 i)) (*.f64 i i)) (fma.f64 50 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (log.f64 n)) (pow.f64 i 3)) (fma.f64 50 (/.f64 (pow.f64 n 4) (pow.f64 i 3)) (fma.f64 100/3 (/.f64 (pow.f64 n 4) (pow.f64 i 4)) (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 25/6 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 i) 4)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i) (fma.f64 25 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 2))) i) (fma.f64 25/6 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 4)) i) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 3)) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 i) 2)) (*.f64 i i)) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 2)) (*.f64 i i)) (*.f64 100 (*.f64 (/.f64 n i) (/.f64 n i))))))))))))))))) (fma.f64 50/3 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 3))) i) (fma.f64 100 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 4) (log.f64 n))) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 (log.f64 i) 3) (*.f64 (pow.f64 n 4) (log.f64 n))) i) (fma.f64 50 (pow.f64 (/.f64 n i) 3) (fma.f64 50 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 3) (log.f64 n))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (log.f64 i)) (pow.f64 i 3)) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 n)) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 3)) i) (*.f64 100 (+.f64 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 n (log.f64 n)) i)))))))))))))
54.5b
(*.f64 n (fma.f64 100 (+.f64 (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i) (*.f64 (/.f64 (*.f64 n n) i) (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i))) (/.f64 -100 i)))
49.7b
(-.f64 (*.f64 100 (/.f64 (*.f64 n (exp.f64 i)) i)) (+.f64 (*.f64 100 (/.f64 n i)) (*.f64 50 (*.f64 (exp.f64 i) i))))
53.9b
(*.f64 n (/.f64 (*.f64 n (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i))
46.6b
(/.f64 (*.f64 n (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100)) i)
49.2b
(cbrt.f64 (pow.f64 (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)) 3))
44.6b
(neg.f64 (/.f64 (*.f64 100 (-.f64 n (*.f64 n (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n)))) i))
54.3b
(*.f64 n (-.f64 (fma.f64 50 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2))) i) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 i)) (*.f64 i i)) (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 3)) i) (fma.f64 100 (*.f64 (/.f64 n i) (/.f64 n i)) (*.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i)))))))) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 n)) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 3)) i) (fma.f64 50 (pow.f64 (/.f64 n i) 3) (fma.f64 100 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 3) (log.f64 n))) i) (*.f64 100 (/.f64 (*.f64 n (log.f64 n)) i)))))))))
31.2b
(*.f64 n (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))))
54.8b
(*.f64 -1 (/.f64 (-.f64 (*.f64 100 n) (*.f64 100 (*.f64 n (exp.f64 (*.f64 (-.f64 (log.f64 (neg.f64 (/.f64 1 n))) (log.f64 (/.f64 -1 i))) n))))) i))
54.7b
(fma.f64 100 (+.f64 (/.f64 (*.f64 n (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i)))) i) (/.f64 (*.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) (pow.f64 n 3)) (*.f64 i i))) (*.f64 (/.f64 n i) -100))
54.3b
(/.f64 (*.f64 100 (*.f64 n (expm1.f64 (*.f64 n (fma.f64 -1 (log.f64 n) (log.f64 i)))))) i)
33.9b
(-.f64 (fma.f64 100 n (fma.f64 275/6 (/.f64 (pow.f64 i 3) n) (fma.f64 50 (*.f64 i n) (fma.f64 25/6 (*.f64 n (pow.f64 i 3)) (fma.f64 50/3 (*.f64 (*.f64 i i) n) (*.f64 (/.f64 (*.f64 i i) n) 100/3)))))) (fma.f64 25 (pow.f64 i 3) (fma.f64 50 i (fma.f64 50 (*.f64 i i) (*.f64 (/.f64 (pow.f64 i 3) (*.f64 n n)) 25)))))
Compiler

Compiled 14755 to 9247 computations (37.3% saved)

localize2.0ms (0%)

prune34.0ms (0.3%)

Pruning

16 alts after pruning (15 fresh and 1 done)

PrunedKeptTotal
New000
Fresh01515
Picked011
Done000
Total01616
Error
1.9b
Counts
16 → 16
Alt Table
StatusErrorProgram
44.6b
(*.f64 n (/.f64 (fma.f64 100 (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n) -100) i))
54.5b
(/.f64 (*.f64 (pow.f64 n 2) (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i)
30.2b
(*.f64 100 n)
55.0b
(*.f64 n (-.f64 (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 i)) (*.f64 i i)) (fma.f64 50 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (log.f64 n)) (pow.f64 i 3)) (fma.f64 50 (/.f64 (pow.f64 n 4) (pow.f64 i 3)) (fma.f64 100/3 (/.f64 (pow.f64 n 4) (pow.f64 i 4)) (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 25/6 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 i) 4)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i) (fma.f64 25 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 2))) i) (fma.f64 25/6 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 4)) i) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 3)) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 i) 2)) (*.f64 i i)) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 2)) (*.f64 i i)) (*.f64 100 (*.f64 (/.f64 n i) (/.f64 n i))))))))))))))))) (fma.f64 50/3 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 3))) i) (fma.f64 100 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 4) (log.f64 n))) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 (log.f64 i) 3) (*.f64 (pow.f64 n 4) (log.f64 n))) i) (fma.f64 50 (pow.f64 (/.f64 n i) 3) (fma.f64 50 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 3) (log.f64 n))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (log.f64 i)) (pow.f64 i 3)) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 n)) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 3)) i) (*.f64 100 (+.f64 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 n (log.f64 n)) i)))))))))))))
54.5b
(*.f64 n (fma.f64 100 (+.f64 (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i) (*.f64 (/.f64 (*.f64 n n) i) (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i))) (/.f64 -100 i)))
49.7b
(-.f64 (*.f64 100 (/.f64 (*.f64 n (exp.f64 i)) i)) (+.f64 (*.f64 100 (/.f64 n i)) (*.f64 50 (*.f64 (exp.f64 i) i))))
53.9b
(*.f64 n (/.f64 (*.f64 n (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i))
46.6b
(/.f64 (*.f64 n (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100)) i)
49.2b
(cbrt.f64 (pow.f64 (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)) 3))
44.6b
(neg.f64 (/.f64 (*.f64 100 (-.f64 n (*.f64 n (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n)))) i))
54.3b
(*.f64 n (-.f64 (fma.f64 50 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2))) i) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 i)) (*.f64 i i)) (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 3)) i) (fma.f64 100 (*.f64 (/.f64 n i) (/.f64 n i)) (*.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i)))))))) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 n)) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 3)) i) (fma.f64 50 (pow.f64 (/.f64 n i) 3) (fma.f64 100 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 3) (log.f64 n))) i) (*.f64 100 (/.f64 (*.f64 n (log.f64 n)) i)))))))))
31.2b
(*.f64 n (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))))
54.8b
(*.f64 -1 (/.f64 (-.f64 (*.f64 100 n) (*.f64 100 (*.f64 n (exp.f64 (*.f64 (-.f64 (log.f64 (neg.f64 (/.f64 1 n))) (log.f64 (/.f64 -1 i))) n))))) i))
54.7b
(fma.f64 100 (+.f64 (/.f64 (*.f64 n (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i)))) i) (/.f64 (*.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) (pow.f64 n 3)) (*.f64 i i))) (*.f64 (/.f64 n i) -100))
54.3b
(/.f64 (*.f64 100 (*.f64 n (expm1.f64 (*.f64 n (fma.f64 -1 (log.f64 n) (log.f64 i)))))) i)
33.9b
(-.f64 (fma.f64 100 n (fma.f64 275/6 (/.f64 (pow.f64 i 3) n) (fma.f64 50 (*.f64 i n) (fma.f64 25/6 (*.f64 n (pow.f64 i 3)) (fma.f64 50/3 (*.f64 (*.f64 i i) n) (*.f64 (/.f64 (*.f64 i i) n) 100/3)))))) (fma.f64 25 (pow.f64 i 3) (fma.f64 50 i (fma.f64 50 (*.f64 i i) (*.f64 (/.f64 (pow.f64 i 3) (*.f64 n n)) 25)))))
Compiler

Compiled 1619 to 1004 computations (38% saved)

localize17.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
2.2b
(*.f64 n (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))))
3.3b
(+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))
5.2b
(-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))))
7.6b
(/.f64 (*.f64 i i) n)

series93.0ms (0.8%)

Counts
4 → 96
Calls

4 calls:

39.0ms
(*.f64 n (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))))
30.0ms
(-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))))
14.0ms
(+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))
10.0ms
(/.f64 (*.f64 i i) n)

rewrite41.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
37×*-un-lft-identity_binary64
23×add-sqr-sqrt_binary64
21×add-cube-cbrt_binary64
20×associate-*r/_binary64
20×times-frac_binary64
Counts
4 → 131
Calls

4 calls:

8.0ms
(-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))))
8.0ms
(+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))
7.0ms
(*.f64 n (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))))
3.0ms
(/.f64 (*.f64 i i) n)

simplify192.0ms (1.6%)

Algorithm
egg-herbie
Rules
568×times-frac_binary64
407×fma-neg_binary64
312×cancel-sign-sub-inv_binary64
200×distribute-rgt-in_binary64
185×distribute-lft-in_binary64
Counts
227 → 236
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02728392
17847689
228797475
347657475
449387475

prune282.0ms (2.3%)

Pruning

16 alts after pruning (15 fresh and 1 done)

PrunedKeptTotal
New2351236
Fresh01414
Picked101
Done011
Total23616252
Error
1.9b
Counts
252 → 16
Alt Table
StatusErrorProgram
54.5b
(/.f64 (*.f64 (pow.f64 n 2) (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i)
31.9b
(*.f64 n (expm1.f64 (log1p.f64 (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))))))
44.6b
(*.f64 n (/.f64 (fma.f64 100 (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n) -100) i))
30.2b
(*.f64 100 n)
55.0b
(*.f64 n (-.f64 (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 i)) (*.f64 i i)) (fma.f64 50 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (log.f64 n)) (pow.f64 i 3)) (fma.f64 50 (/.f64 (pow.f64 n 4) (pow.f64 i 3)) (fma.f64 100/3 (/.f64 (pow.f64 n 4) (pow.f64 i 4)) (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 25/6 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 i) 4)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i) (fma.f64 25 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 2))) i) (fma.f64 25/6 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 4)) i) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 3)) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 i) 2)) (*.f64 i i)) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 2)) (*.f64 i i)) (*.f64 100 (*.f64 (/.f64 n i) (/.f64 n i))))))))))))))))) (fma.f64 50/3 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 3))) i) (fma.f64 100 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 4) (log.f64 n))) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 (log.f64 i) 3) (*.f64 (pow.f64 n 4) (log.f64 n))) i) (fma.f64 50 (pow.f64 (/.f64 n i) 3) (fma.f64 50 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 3) (log.f64 n))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (log.f64 i)) (pow.f64 i 3)) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 n)) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 3)) i) (*.f64 100 (+.f64 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 n (log.f64 n)) i)))))))))))))
54.5b
(*.f64 n (fma.f64 100 (+.f64 (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i) (*.f64 (/.f64 (*.f64 n n) i) (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i))) (/.f64 -100 i)))
49.7b
(-.f64 (*.f64 100 (/.f64 (*.f64 n (exp.f64 i)) i)) (+.f64 (*.f64 100 (/.f64 n i)) (*.f64 50 (*.f64 (exp.f64 i) i))))
53.9b
(*.f64 n (/.f64 (*.f64 n (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i))
46.6b
(/.f64 (*.f64 n (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100)) i)
49.2b
(cbrt.f64 (pow.f64 (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)) 3))
44.6b
(neg.f64 (/.f64 (*.f64 100 (-.f64 n (*.f64 n (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n)))) i))
54.3b
(*.f64 n (-.f64 (fma.f64 50 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2))) i) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 i)) (*.f64 i i)) (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 3)) i) (fma.f64 100 (*.f64 (/.f64 n i) (/.f64 n i)) (*.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i)))))))) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 n)) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 3)) i) (fma.f64 50 (pow.f64 (/.f64 n i) 3) (fma.f64 100 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 3) (log.f64 n))) i) (*.f64 100 (/.f64 (*.f64 n (log.f64 n)) i)))))))))
54.8b
(*.f64 -1 (/.f64 (-.f64 (*.f64 100 n) (*.f64 100 (*.f64 n (exp.f64 (*.f64 (-.f64 (log.f64 (neg.f64 (/.f64 1 n))) (log.f64 (/.f64 -1 i))) n))))) i))
54.7b
(fma.f64 100 (+.f64 (/.f64 (*.f64 n (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i)))) i) (/.f64 (*.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) (pow.f64 n 3)) (*.f64 i i))) (*.f64 (/.f64 n i) -100))
54.3b
(/.f64 (*.f64 100 (*.f64 n (expm1.f64 (*.f64 n (fma.f64 -1 (log.f64 n) (log.f64 i)))))) i)
33.9b
(-.f64 (fma.f64 100 n (fma.f64 275/6 (/.f64 (pow.f64 i 3) n) (fma.f64 50 (*.f64 i n) (fma.f64 25/6 (*.f64 n (pow.f64 i 3)) (fma.f64 50/3 (*.f64 (*.f64 i i) n) (*.f64 (/.f64 (*.f64 i i) n) 100/3)))))) (fma.f64 25 (pow.f64 i 3) (fma.f64 50 i (fma.f64 50 (*.f64 i i) (*.f64 (/.f64 (pow.f64 i 3) (*.f64 n n)) 25)))))
Compiler

Compiled 14298 to 6030 computations (57.8% saved)

localize20.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
3.3b
(+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))
5.2b
(-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n))))
7.6b
(/.f64 (*.f64 i i) n)
18.4b
(log1p.f64 (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))))

series92.0ms (0.8%)

Counts
1 → 24
Calls

1 calls:

92.0ms
(log1p.f64 (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))))

rewrite3.0ms (0%)

Algorithm
rewrite-expression-head
Rules
expm1-log1p-u_binary64
*-un-lft-identity_binary64
add-sqr-sqrt_binary64
add-cube-cbrt_binary64
add-cbrt-cube_binary64
Counts
1 → 11
Calls

1 calls:

2.0ms
(log1p.f64 (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))))

simplify83.0ms (0.7%)

Algorithm
egg-herbie
Rules
290×sub-neg_binary64
282×distribute-neg-in_binary64
276×fma-def_binary64
255×cancel-sign-sub-inv_binary64
240×associate-+r+_binary64
Counts
35 → 58
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02733739
18793633
234723615
349793615

prune209.0ms (1.7%)

Pruning

16 alts after pruning (14 fresh and 2 done)

PrunedKeptTotal
New2110211
Fresh01414
Picked011
Done011
Total21116227
Error
1.9b
Counts
227 → 16
Alt Table
StatusErrorProgram
54.5b
(/.f64 (*.f64 (pow.f64 n 2) (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i)
31.9b
(*.f64 n (expm1.f64 (log1p.f64 (-.f64 (+.f64 100 (fma.f64 50 i (fma.f64 50/3 (*.f64 i i) (*.f64 100/3 (*.f64 (/.f64 i n) (/.f64 i n)))))) (*.f64 50 (+.f64 (/.f64 i n) (/.f64 (*.f64 i i) n)))))))
44.6b
(*.f64 n (/.f64 (fma.f64 100 (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n) -100) i))
30.2b
(*.f64 100 n)
55.0b
(*.f64 n (-.f64 (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 i)) (*.f64 i i)) (fma.f64 50 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (log.f64 n)) (pow.f64 i 3)) (fma.f64 50 (/.f64 (pow.f64 n 4) (pow.f64 i 3)) (fma.f64 100/3 (/.f64 (pow.f64 n 4) (pow.f64 i 4)) (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 25/6 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 i) 4)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i) (fma.f64 25 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 2))) i) (fma.f64 25/6 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 4)) i) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 3)) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 i) 2)) (*.f64 i i)) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 2)) (*.f64 i i)) (*.f64 100 (*.f64 (/.f64 n i) (/.f64 n i))))))))))))))))) (fma.f64 50/3 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 4) (pow.f64 (log.f64 n) 3))) i) (fma.f64 100 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 4) (log.f64 n))) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 (log.f64 i) 3) (*.f64 (pow.f64 n 4) (log.f64 n))) i) (fma.f64 50 (pow.f64 (/.f64 n i) 3) (fma.f64 50 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 3) (log.f64 n))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 n 4) (log.f64 i)) (pow.f64 i 3)) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 n)) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 3)) i) (*.f64 100 (+.f64 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (/.f64 (*.f64 n (log.f64 n)) i)))))))))))))
54.5b
(*.f64 n (fma.f64 100 (+.f64 (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i) (*.f64 (/.f64 (*.f64 n n) i) (/.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) i))) (/.f64 -100 i)))
49.7b
(-.f64 (*.f64 100 (/.f64 (*.f64 n (exp.f64 i)) i)) (+.f64 (*.f64 100 (/.f64 n i)) (*.f64 50 (*.f64 (exp.f64 i) i))))
53.9b
(*.f64 n (/.f64 (*.f64 n (-.f64 (*.f64 100 (log.f64 i)) (*.f64 100 (log.f64 n)))) i))
46.6b
(/.f64 (*.f64 n (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100)) i)
49.2b
(cbrt.f64 (pow.f64 (*.f64 n (/.f64 (fma.f64 100 (pow.f64 (+.f64 1 (/.f64 i n)) n) -100) i)) 3))
44.6b
(neg.f64 (/.f64 (*.f64 100 (-.f64 n (*.f64 n (pow.f64 (/.f64 (/.f64 -1 n) (/.f64 -1 i)) n)))) i))
54.3b
(*.f64 n (-.f64 (fma.f64 50 (/.f64 (*.f64 (log.f64 i) (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 2))) i) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 i)) (*.f64 i i)) (fma.f64 100 (/.f64 (*.f64 n (log.f64 i)) i) (fma.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 i) 2)) i) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 i) 3)) i) (fma.f64 100 (*.f64 (/.f64 n i) (/.f64 n i)) (*.f64 50 (/.f64 (*.f64 (*.f64 n n) (pow.f64 (log.f64 n) 2)) i)))))))) (fma.f64 100 (/.f64 (*.f64 (pow.f64 n 3) (log.f64 n)) (*.f64 i i)) (fma.f64 50/3 (/.f64 (*.f64 (pow.f64 n 3) (pow.f64 (log.f64 n) 3)) i) (fma.f64 50 (pow.f64 (/.f64 n i) 3) (fma.f64 100 (/.f64 (*.f64 (*.f64 n n) (*.f64 (log.f64 i) (log.f64 n))) i) (fma.f64 50 (/.f64 (*.f64 (pow.f64 (log.f64 i) 2) (*.f64 (pow.f64 n 3) (log.f64 n))) i) (*.f64 100 (/.f64 (*.f64 n (log.f64 n)) i)))))))))
54.8b
(*.f64 -1 (/.f64 (-.f64 (*.f64 100 n) (*.f64 100 (*.f64 n (exp.f64 (*.f64 (-.f64 (log.f64 (neg.f64 (/.f64 1 n))) (log.f64 (/.f64 -1 i))) n))))) i))
54.7b
(fma.f64 100 (+.f64 (/.f64 (*.f64 n (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i)))) i) (/.f64 (*.f64 (pow.f64 (exp.f64 n) (fma.f64 -1 (log.f64 n) (log.f64 i))) (pow.f64 n 3)) (*.f64 i i))) (*.f64 (/.f64 n i) -100))
54.3b
(/.f64 (*.f64 100 (*.f64 n (expm1.f64 (*.f64 n (fma.f64 -1 (log.f64 n) (log.f64 i)))))) i)
33.9b
(-.f64 (fma.f64 100 n (fma.f64 275/6 (/.f64 (pow.f64 i 3) n) (fma.f64 50 (*.f64 i n) (fma.f64 25/6 (*.f64 n (pow.f64 i 3)) (fma.f64 50/3 (*.f64 (*.f64 i i) n) (*.f64 (/.f64 (*.f64 i i) n) 100/3)))))) (fma.f64 25 (pow.f64 i 3) (fma.f64 50 i (fma.f64 50 (*.f64 i i) (*.f64 (/.f64 (pow.f64 i 3) (*.f64 n n)) 25)))))
Compiler

Compiled 13337 to 7009 computations (47.4% saved)

regimes1.4s (11.6%)

Accuracy

Total 7.1b remaining (71.3%)

Threshold costs 0b (0%)

Counts
132 → 3
Compiler

Compiled 22160 to 14084 computations (36.4% saved)

bsearch202.0ms (1.7%)

Steps
ItersRangePoint
9
0.0003228209862443448
12206.887681095914
0.009094777292108976
9
-2.725496350696478e-23
-3.5856823595343495e-29
-2.6748076836181006e-23
Compiler

Compiled 3 to 2 computations (33.3% saved)

simplify18.0ms (0.1%)

Algorithm
egg-herbie
Rules
40×*-commutative_binary64
12×+-commutative_binary64
sub-neg_binary64
neg-sub0_binary64
neg-mul-1_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0129544
1173544
2184544
3194544
4208544
5219544
6225544
7227544
8226544

end600.0ms (4.9%)

Compiler

Compiled 1542 to 936 computations (39.3% saved)

Profiling

Loading profile data...