Details

Time bar (total: 3.1s)

analyze6.0ms (0.2%)

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)

sample2.0s (66.7%)

Results
1.4s8256×body128valid
0.0msbody128invalid
Compiler

Compiled 44 to 32 computations (27.3% saved)

simplify201.0ms (6.5%)

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.3%)

Local error

Found 3 expressions with local error:

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

series22.0ms (0.7%)

Counts
3 → 36
Calls

3 calls:

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

rewrite75.0ms (2.4%)

Algorithm
batch-egg-rewrite
Rules
519×log-prod_binary64
399×fma-def_binary64
203×fma-neg_binary64
189×expm1-udef_binary64
188×log1p-udef_binary64
Counts
3 → 125
Calls

3 calls:

72.0ms
(log.f64 (+.f64 (/.f64 1 x) (/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x)))
72.0ms
(/.f64 (sqrt.f64 (-.f64 1 (*.f64 x x))) x)
72.0ms
(sqrt.f64 (-.f64 1 (*.f64 x x)))
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01041
122341
2293139
3558239

simplify55.0ms (1.8%)

Algorithm
egg-herbie
Rules
775×fma-neg_binary64
671×times-frac_binary64
338×associate-/r*_binary64
316×fma-def_binary64
193×associate-*r*_binary64
Counts
161 → 191
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0107833
1334800
21017777
33530774
45035774

prune114.0ms (3.7%)

Pruning

2 alts after pruning (1 fresh and 1 done)

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

Compiled 3913 to 2698 computations (31.1% saved)

localize10.0ms (0.3%)

Local error

Found 4 expressions with local error:

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

series30.0ms (1%)

Counts
3 → 28
Calls

3 calls:

16.0ms
(log.f64 (/.f64 (sqrt.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)) x))
11.0ms
(/.f64 (sqrt.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)) x)
4.0ms
(fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)

rewrite108.0ms (3.5%)

Algorithm
batch-egg-rewrite
Rules
464×log-prod_binary64
410×prod-diff_binary64
179×egg-rr
170×expm1-udef_binary64
169×log1p-udef_binary64
Counts
3 → 179
Calls

3 calls:

99.0ms
(log.f64 (/.f64 (sqrt.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)) x))
99.0ms
(fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)
99.0ms
(/.f64 (sqrt.f64 (fma.f64 x (sqrt.f64 (-.f64 1 (*.f64 x x))) x)) x)
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01051
120651
2241951
3486051
4518851

simplify80.0ms (2.6%)

Algorithm
egg-herbie
Rules
826×associate-/r*_binary64
503×associate-*l*_binary64
336×fma-def_binary64
323×div-sub_binary64
311×fma-neg_binary64
Counts
207 → 233
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0142921
1430854
21368769
34510736
44789736
55148736

prune206.0ms (6.7%)

Pruning

2 alts after pruning (0 fresh and 2 done)

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

Compiled 7552 to 4988 computations (34% saved)

regimes55.0ms (1.8%)

Accuracy

Total 0.0b remaining (83.2%)

Threshold costs 0.0b (83.2%)

Counts
18 → 1
Compiler

Compiled 778 to 571 computations (26.6% saved)

simplify2.0ms (0.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01223
12023
22623
33023
43223
53123

end49.0ms (1.6%)

Compiler

Compiled 62 to 43 computations (30.6% saved)

Profiling

Loading profile data...