Details

Time bar (total: 6.9s)

analyze1.7s (24.8%)

Algorithm
search
Search
TrueOtherFalseIter
0%100%0%0
0%100%0%1
0%100%0%2
25%75%0%3
25%62.5%12.5%4
25%56.2%18.8%5
28.1%50%21.9%6
29.7%46.9%23.5%7
30.5%45.3%24.3%8
30.8%44.9%24.3%9
31.2%44.5%24.3%10
31.3%44.3%24.4%11
31.4%44.3%24.4%12
31.4%44%24.5%13
31.5%43.8%24.8%14
Compiler

Compiled 14 to 12 computations (14.3% saved)

sample121.0ms (1.8%)

Algorithm
intervals
Results
73.0ms100×body1024valid
14.0ms36×body512valid
10.0ms92×body128valid
7.0msbody2048valid
5.0ms19×body256valid
Compiler

Compiled 28 to 24 computations (14.3% saved)

simplify57.0ms (0.8%)

Algorithm
egg-herbie
Rules
667×div-sub_binary64
601×associate-/l*_binary64
488×associate-/r*_binary64
380×fma-def_binary64
279×distribute-rgt-in_binary64
Counts
1 → 2
Iterations

Useful iterations: 5 (0.0ms)

IterNodesCost
01113
12513
23413
35913
412311
53188
610568
743508
849878

prune8.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.3b
Counts
3 → 2
Alt Table
StatusErrorProgram
0.3b
(sqrt.f64 (+.f64 1 (exp.f64 x)))
42.5b
(sqrt.f64 (/.f64 (-.f64 (exp.f64 (*.f64 2 x)) 1) (-.f64 (exp.f64 x) 1)))
Compiler

Compiled 56 to 46 computations (17.9% saved)

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 1 (exp.f64 x))
0.3b
(sqrt.f64 (+.f64 1 (exp.f64 x)))

rewrite14.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
*-un-lft-identity_binary64
add-sqr-sqrt_binary64
sqrt-prod_binary64
add-cube-cbrt_binary64
add-log-exp_binary64
Counts
2 → 38
Calls

2 calls:

6.0ms
(sqrt.f64 (+.f64 1 (exp.f64 x)))
6.0ms
(+.f64 1 (exp.f64 x))

series15.0ms (0.2%)

Counts
2 → 8
Calls

2 calls:

13.0ms
(sqrt.f64 (+.f64 1 (exp.f64 x)))
2.0ms
(+.f64 1 (exp.f64 x))

simplify214.0ms (3.1%)

Algorithm
egg-herbie
Rules
733×times-frac_binary64
283×fma-neg_binary64
235×fma-def_binary64
177×associate-/r/_binary64
165×associate-+l+_binary64
Counts
46 → 63
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
086538
1218494
2595470
32140454
44978454
54938454
65008454

prune92.0ms (1.3%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New60363
Fresh101
Picked101
Done000
Total62365
Error
0.2b
Counts
65 → 3
Alt Table
StatusErrorProgram
0.3b
(sqrt.f64 (/.f64 (neg.f64 (expm1.f64 (+.f64 x x))) (neg.f64 (expm1.f64 x))))
0.3b
(hypot.f64 1 (sqrt.f64 (exp.f64 x)))
20.2b
(-.f64 (+.f64 (*.f64 1/12 (/.f64 (pow.f64 x 3) (sqrt.f64 2))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 x 2) (sqrt.f64 2))) (+.f64 (*.f64 1/16 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 2) 5))) (+.f64 (sqrt.f64 2) (*.f64 1/2 (/.f64 x (sqrt.f64 2))))))) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 x 3) (pow.f64 (sqrt.f64 2) 3))) (*.f64 1/8 (/.f64 (pow.f64 x 2) (pow.f64 (sqrt.f64 2) 3)))))
Compiler

Compiled 811 to 610 computations (24.8% saved)

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(hypot.f64 1 (sqrt.f64 (exp.f64 x)))
0.2b
(sqrt.f64 (exp.f64 x))

rewrite5.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
add-sqr-sqrt_binary64
*-un-lft-identity_binary64
sqrt-pow1_binary64
add-cube-cbrt_binary64
sqrt-prod_binary64
Counts
2 → 28
Calls

2 calls:

3.0ms
(sqrt.f64 (exp.f64 x))
1.0ms
(hypot.f64 1 (sqrt.f64 (exp.f64 x)))

series61.0ms (0.9%)

Counts
2 → 16
Calls

2 calls:

41.0ms
(hypot.f64 1 (sqrt.f64 (exp.f64 x)))
19.0ms
(sqrt.f64 (exp.f64 x))

simplify75.0ms (1.1%)

Algorithm
egg-herbie
Rules
795×times-frac_binary64
699×associate-/l*_binary64
289×fma-neg_binary64
186×associate-/r/_binary64
169×fma-def_binary64
Counts
44 → 62
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
082503
1173470
2482443
31872430
45251430

prune72.0ms (1%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New61162
Fresh112
Picked011
Done000
Total62365
Error
0.0b
Counts
65 → 3
Alt Table
StatusErrorProgram
0.3b
(sqrt.f64 (/.f64 (neg.f64 (expm1.f64 (+.f64 x x))) (neg.f64 (expm1.f64 x))))
0.3b
(hypot.f64 1 (sqrt.f64 (exp.f64 x)))
0.1b
(hypot.f64 1 (pow.f64 (exp.f64 1) (/.f64 x 2)))
Compiler

Compiled 637 to 445 computations (30.1% saved)

localize108.0ms (1.6%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(hypot.f64 1 (pow.f64 (exp.f64 1) (/.f64 x 2)))
0.1b
(pow.f64 (exp.f64 1) (/.f64 x 2))

rewrite10.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
13×pow-unpow_binary64
11×*-un-lft-identity_binary64
11×add-sqr-sqrt_binary64
11×add-cube-cbrt_binary64
times-frac_binary64
Counts
2 → 42
Calls

2 calls:

6.0ms
(pow.f64 (exp.f64 1) (/.f64 x 2))
1.0ms
(hypot.f64 1 (pow.f64 (exp.f64 1) (/.f64 x 2)))

series35.0ms (0.5%)

Counts
2 → 24
Calls

2 calls:

32.0ms
(hypot.f64 1 (pow.f64 (exp.f64 1) (/.f64 x 2)))
3.0ms
(pow.f64 (exp.f64 1) (/.f64 x 2))

simplify158.0ms (2.3%)

Algorithm
egg-herbie
Rules
782×fma-neg_binary64
176×fma-def_binary64
172×distribute-neg-frac_binary64
168×distribute-rgt-neg-in_binary64
163×associate-/l*_binary64
Counts
66 → 126
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0117858
1281777
2759721
32693653
44787653
55204653

prune127.0ms (1.8%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New1251126
Fresh011
Picked101
Done011
Total1263129
Error
0b
Counts
129 → 3
Alt Table
StatusErrorProgram
0.3b
(sqrt.f64 (/.f64 (neg.f64 (expm1.f64 (+.f64 x x))) (neg.f64 (expm1.f64 x))))
0.3b
(hypot.f64 1 (sqrt.f64 (exp.f64 x)))
0.0b
(hypot.f64 1 (exp.f64 (*.f64 1/2 x)))
Compiler

Compiled 1276 to 1026 computations (19.6% saved)

localize8.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(hypot.f64 1 (exp.f64 (*.f64 1/2 x)))

rewrite2.0ms (0%)

Algorithm
rewrite-expression-head
Rules
*-un-lft-identity_binary64
add-sqr-sqrt_binary64
add-cube-cbrt_binary64
add-cbrt-cube_binary64
add-exp-log_binary64
Counts
1 → 10
Calls

1 calls:

1.0ms
(hypot.f64 1 (exp.f64 (*.f64 1/2 x)))

series30.0ms (0.4%)

Counts
1 → 12
Calls

1 calls:

30.0ms
(hypot.f64 1 (exp.f64 (*.f64 1/2 x)))

simplify67.0ms (1%)

Algorithm
egg-herbie
Rules
796×associate-/l*_binary64
405×associate-/r*_binary64
268×fma-neg_binary64
182×associate-/r/_binary64
153×distribute-neg-frac_binary64
Counts
22 → 41
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
054400
1135326
2411281
31699269
44944269

prune75.0ms (1.1%)

Pruning

3 alts after pruning (1 fresh and 2 done)

PrunedKeptTotal
New41041
Fresh011
Picked011
Done011
Total41344
Error
0b
Counts
44 → 3
Alt Table
StatusErrorProgram
0.3b
(sqrt.f64 (/.f64 (neg.f64 (expm1.f64 (+.f64 x x))) (neg.f64 (expm1.f64 x))))
0.3b
(hypot.f64 1 (sqrt.f64 (exp.f64 x)))
0.0b
(hypot.f64 1 (exp.f64 (*.f64 1/2 x)))
Compiler

Compiled 390 to 328 computations (15.9% saved)

regimes128.0ms (1.9%)

Accuracy

Total 0.0b remaining (54%)

Threshold costs 0.0b (54%)

Compiler

Compiled 942 to 800 computations (15.1% saved)

simplify6.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
079
1109
299

end1.0ms (0%)

Compiler

Compiled 7 to 6 computations (14.3% saved)

sample3.7s (53.4%)

Algorithm
intervals
Results
1.8s2628×body1024valid
537.0ms1368×body512valid
426.0ms3101×body128valid
213.0ms270×body2048valid
158.0ms633×body256valid
1.0msbody128invalid
Compiler

Compiled 46 to 38 computations (17.4% saved)

Profiling

Loading profile data...