Details

Time bar (total: 1.9s)

analyze6.0ms (0.3%)

Algorithm
search
Search
TrueOtherFalseIter
0%100%0%0
0%100%0%1
0%100%0%2
0%50%50%3
12.5%25%62.5%4
18.7%12.5%68.8%5
21.9%6.2%71.9%6
23.4%3.1%73.5%7
24.2%1.6%74.2%8
24.6%0.8%74.6%9
24.8%0.4%74.8%10
24.9%0.2%74.9%11
24.9%0.1%75%12
25%0%75%13
25%0%75%14
Compiler

Compiled 15 to 11 computations (26.7% saved)

sample1.2s (63%)

Results
1.0s8256×body128valid
1.0msbody128invalid
Compiler

Compiled 44 to 32 computations (27.3% saved)

simplify199.0ms (10.2%)

Algorithm
egg-herbie
Rules
1115×distribute-rgt-neg-in_binary64
788×distribute-rgt-out--_binary64
692×unsub-neg_binary64
492×fma-neg_binary64
461×distribute-neg-in_binary64
Counts
1 → 1
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
11820
22420
33420
45020
57320
611320
724720
845220
974220
10156020
11233820
12239220
13262820
14277620
15277420
16285120
17311020
18367320
19466520
20491020
21495220
22496320
23496020
24620820

prune2.0ms (0.1%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New011
Fresh011
Picked000
Done000
Total022
Error
0.0b
Counts
2 → 1
Alt Table
StatusErrorProgram
0.0b
(log.f64 (+.f64 (/.f64 1 x) (/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x)))
Compiler

Compiled 42 to 30 computations (28.6% saved)

localize8.0ms (0.4%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (/.f64 1 x) (/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x))
0.0b
(log.f64 (+.f64 (/.f64 1 x) (/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x)))

series14.0ms (0.7%)

Counts
2 → 24
Calls

2 calls:

10.0ms
(log.f64 (+.f64 (/.f64 1 x) (/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x)))
5.0ms
(+.f64 (/.f64 1 x) (/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x))

rewrite41.0ms (2.1%)

Algorithm
rewrite-expression-head
Rules
48×*-un-lft-identity_binary64
35×times-frac_binary64
24×add-sqr-sqrt_binary64
18×add-cube-cbrt_binary64
16×distribute-lft-out_binary64
Counts
2 → 68
Calls

2 calls:

18.0ms
(+.f64 (/.f64 1 x) (/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x))
16.0ms
(log.f64 (+.f64 (/.f64 1 x) (/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x)))

simplify96.0ms (4.9%)

Algorithm
egg-herbie
Rules
690×fma-neg_binary64
302×fma-def_binary64
298×associate-/r*_binary64
284×sub-neg_binary64
231×associate-*r*_binary64
Counts
92 → 127
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01571958
13991830
210811783
336371748
448031748
549091748

prune78.0ms (4%)

Pruning

2 alts after pruning (1 fresh and 1 done)

PrunedKeptTotal
New1261127
Fresh000
Picked011
Done000
Total1262128
Error
0b
Counts
128 → 2
Alt Table
StatusErrorProgram
0.0b
(log.f64 (+.f64 (/.f64 1 x) (/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x)))
0.4b
(-.f64 (log.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)) (*.f64 2 (log.f64 x)))
Compiler

Compiled 2589 to 1763 computations (31.9% saved)

localize12.0ms (0.6%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(log.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x))
0.4b
(-.f64 (log.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)) (*.f64 2 (log.f64 x)))

series19.0ms (1%)

Counts
2 → 24
Calls

2 calls:

10.0ms
(-.f64 (log.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)) (*.f64 2 (log.f64 x)))
9.0ms
(log.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x))

rewrite8.0ms (0.4%)

Algorithm
rewrite-expression-head
Rules
12×log-prod_binary64
*-un-lft-identity_binary64
add-sqr-sqrt_binary64
add-cube-cbrt_binary64
associate--r+_binary64
Counts
2 → 45
Calls

2 calls:

4.0ms
(-.f64 (log.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)) (*.f64 2 (log.f64 x)))
1.0ms
(log.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x))

simplify72.0ms (3.7%)

Algorithm
egg-herbie
Rules
853×fma-neg_binary64
390×fma-def_binary64
280×associate-*r*_binary64
276×associate-*l*_binary64
224×times-frac_binary64
Counts
69 → 114
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01601881
14181723
211451620
338601614
449681614

prune69.0ms (3.6%)

Pruning

2 alts after pruning (0 fresh and 2 done)

PrunedKeptTotal
New1140114
Fresh000
Picked011
Done011
Total1142116
Error
0b
Counts
116 → 2
Alt Table
StatusErrorProgram
0.0b
(log.f64 (+.f64 (/.f64 1 x) (/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x)))
0.4b
(-.f64 (log.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)) (*.f64 2 (log.f64 x)))
Compiler

Compiled 2790 to 1837 computations (34.2% saved)

regimes46.0ms (2.4%)

Accuracy

Total 0.1b remaining (96.8%)

Threshold costs 0.1b (96.8%)

Counts
14 → 1
Compiler

Compiled 547 to 391 computations (28.5% saved)

simplify2.0ms (0.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
11820
22420
32820
43020
52920

end47.0ms (2.4%)

Compiler

Compiled 58 to 41 computations (29.3% saved)

Profiling

Loading profile data...