Details

Time bar (total: 3.6s)

analyze224.0ms (6.3%)

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
12.5%87.4%0.1%5
31.2%68.7%0.1%6
46.8%53.1%0.1%7
60.9%39%0.1%8
67.9%31.2%0.9%9
74.5%22.2%3.2%10
77.9%17.2%5%11
81.1%11.8%7.1%12
82.7%9%8.3%13
84.3%6.1%9.7%14
Compiler

Compiled 14 to 10 computations (28.6% saved)

sample962.0ms (27%)

Results
823.0ms8256×body128valid
29.0ms294×body128invalid
Compiler

Compiled 41 to 29 computations (29.3% saved)

simplify83.0ms (2.3%)

Algorithm
egg-herbie
Rules
1151×distribute-rgt-in_binary64
1143×distribute-lft-in_binary64
971×fma-def_binary64
653×associate-/l*_binary64
535×associate-/l/_binary64
Counts
1 → 2
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0916
12214
23014
37514
411214
522214
640614
741914
878314
993714
10125914
11161114
12177814
13201514
14293914
15324514
16507514

prune3.0ms (0.1%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
8.3b
Counts
3 → 1
Alt Table
StatusErrorProgram
8.3b
(/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))
Compiler

Compiled 47 to 27 computations (42.6% saved)

localize6.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 x (/.f64 x y) x)
7.8b
(/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))

series19.0ms (0.5%)

Counts
2 → 48
Calls

2 calls:

12.0ms
(/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))
7.0ms
(fma.f64 x (/.f64 x y) x)

rewrite6.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
19×*-un-lft-identity_binary64
12×times-frac_binary64
11×add-sqr-sqrt_binary64
11×add-cube-cbrt_binary64
associate-/r*_binary64
Counts
2 → 45
Calls

2 calls:

3.0ms
(/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))
0.0ms
(fma.f64 x (/.f64 x y) x)

simplify81.0ms (2.3%)

Algorithm
egg-herbie
Rules
1032×fma-neg_binary64
526×cancel-sign-sub-inv_binary64
338×sub-neg_binary64
265×distribute-rgt-in_binary64
240×associate-/l/_binary64
Counts
93 → 74
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01081641
12451554
27141484
324091453
444391453
550611453

prune80.0ms (2.2%)

Pruning

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New69574
Fresh000
Picked101
Done000
Total70575
Error
0.0b
Counts
75 → 5
Alt Table
StatusErrorProgram
0.1b
(*.f64 1 (*.f64 (+.f64 (/.f64 x y) 1) (/.f64 x (+.f64 x 1))))
15.2b
(+.f64 (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y)) (/.f64 x (+.f64 1 x)))
31.0b
(*.f64 (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))) (sqrt.f64 (/.f64 (fma.f64 x (/.f64 x y) x) (+.f64 x 1))))
8.5b
(/.f64 1 (/.f64 (+.f64 x 1) (fma.f64 x (/.f64 x y) x)))
8.8b
(*.f64 (/.f64 1 (*.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (+.f64 x 1)))) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))
Compiler

Compiled 1449 to 668 computations (53.9% saved)

localize7.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (/.f64 x y) 1)
0.0b
(/.f64 x (+.f64 x 1))
0.1b
(*.f64 (+.f64 (/.f64 x y) 1) (/.f64 x (+.f64 x 1)))

series18.0ms (0.5%)

Counts
3 → 51
Calls

3 calls:

12.0ms
(*.f64 (+.f64 (/.f64 x y) 1) (/.f64 x (+.f64 x 1)))
4.0ms
(+.f64 (/.f64 x y) 1)
2.0ms
(/.f64 x (+.f64 x 1))

rewrite32.0ms (0.9%)

Algorithm
rewrite-expression-head
Rules
46×*-un-lft-identity_binary64
34×times-frac_binary64
33×add-sqr-sqrt_binary64
28×add-cube-cbrt_binary64
18×associate-*r*_binary64
Counts
3 → 106
Calls

3 calls:

12.0ms
(*.f64 (+.f64 (/.f64 x y) 1) (/.f64 x (+.f64 x 1)))
5.0ms
(+.f64 (/.f64 x y) 1)
3.0ms
(/.f64 x (+.f64 x 1))

simplify120.0ms (3.4%)

Algorithm
egg-herbie
Rules
440×fma-def_binary64
386×associate-/l*_binary64
386×times-frac_binary64
344×distribute-rgt-in_binary64
313×fma-neg_binary64
Counts
157 → 161
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01712330
14442167
214662015
344492015
448962015
549952015
649662015

prune195.0ms (5.5%)

Pruning

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New1583161
Fresh224
Picked101
Done000
Total1615166
Error
0.0b
Counts
166 → 5
Alt Table
StatusErrorProgram
18.2b
(*.f64 1 (*.f64 (*.f64 (+.f64 (/.f64 x y) 1) (sqrt.f64 (/.f64 x (+.f64 x 1)))) (sqrt.f64 (/.f64 x (+.f64 x 1)))))
19.4b
(*.f64 1 (/.f64 (fma.f64 x (pow.f64 (/.f64 x y) 3) x) (*.f64 (+.f64 x 1) (+.f64 1 (*.f64 (/.f64 x y) (-.f64 (/.f64 x y) 1))))))
8.4b
(*.f64 1 (*.f64 (fma.f64 x (/.f64 x y) x) (/.f64 1 (+.f64 x 1))))
15.2b
(+.f64 (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y)) (/.f64 x (+.f64 1 x)))
8.8b
(*.f64 (/.f64 1 (*.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (+.f64 x 1)))) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))
Compiler

Compiled 3462 to 2119 computations (38.8% saved)

localize9.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(/.f64 1 (+.f64 x 1))
0.1b
(fma.f64 x (/.f64 x y) x)
7.8b
(*.f64 (fma.f64 x (/.f64 x y) x) (/.f64 1 (+.f64 x 1)))

series13.0ms (0.4%)

Counts
2 → 36
Calls

2 calls:

11.0ms
(*.f64 (fma.f64 x (/.f64 x y) x) (/.f64 1 (+.f64 x 1)))
2.0ms
(/.f64 1 (+.f64 x 1))

rewrite17.0ms (0.5%)

Algorithm
rewrite-expression-head
Rules
35×*-un-lft-identity_binary64
27×add-sqr-sqrt_binary64
26×times-frac_binary64
20×add-cube-cbrt_binary64
18×associate-*r*_binary64
Counts
2 → 82
Calls

2 calls:

9.0ms
(*.f64 (fma.f64 x (/.f64 x y) x) (/.f64 1 (+.f64 x 1)))
3.0ms
(/.f64 1 (+.f64 x 1))

simplify108.0ms (3%)

Algorithm
egg-herbie
Rules
892×fma-neg_binary64
598×cancel-sign-sub-inv_binary64
402×sub-neg_binary64
234×associate--l+_binary64
202×associate-+l+_binary64
Counts
118 → 133
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01301920
13151752
29531660
331411647
441911647
549991647
649861647

prune130.0ms (3.7%)

Pruning

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New1490149
Fresh044
Picked011
Done000
Total1495154
Error
0.0b
Counts
154 → 5
Alt Table
StatusErrorProgram
18.2b
(*.f64 1 (*.f64 (*.f64 (+.f64 (/.f64 x y) 1) (sqrt.f64 (/.f64 x (+.f64 x 1)))) (sqrt.f64 (/.f64 x (+.f64 x 1)))))
19.4b
(*.f64 1 (/.f64 (fma.f64 x (pow.f64 (/.f64 x y) 3) x) (*.f64 (+.f64 x 1) (+.f64 1 (*.f64 (/.f64 x y) (-.f64 (/.f64 x y) 1))))))
8.4b
(*.f64 1 (*.f64 (fma.f64 x (/.f64 x y) x) (/.f64 1 (+.f64 x 1))))
15.2b
(+.f64 (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y)) (/.f64 x (+.f64 1 x)))
8.8b
(*.f64 (/.f64 1 (*.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (+.f64 x 1)))) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))
Compiler

Compiled 3223 to 1846 computations (42.7% saved)

localize10.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (+.f64 x 1)))
0.3b
(cbrt.f64 (+.f64 x 1))
1.7b
(/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1)))
6.2b
(*.f64 (/.f64 1 (*.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (+.f64 x 1)))) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))

series102.0ms (2.9%)

Counts
4 → 72
Calls

4 calls:

76.0ms
(/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1)))
15.0ms
(*.f64 (/.f64 1 (*.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (+.f64 x 1)))) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))
6.0ms
(*.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (+.f64 x 1)))
4.0ms
(cbrt.f64 (+.f64 x 1))

rewrite55.0ms (1.5%)

Algorithm
rewrite-expression-head
Rules
78×*-un-lft-identity_binary64
74×add-sqr-sqrt_binary64
59×cbrt-prod_binary64
57×times-frac_binary64
53×add-exp-log_binary64
Counts
4 → 203
Calls

4 calls:

19.0ms
(*.f64 (/.f64 1 (*.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (+.f64 x 1)))) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))
7.0ms
(*.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (+.f64 x 1)))
6.0ms
(/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1)))
2.0ms
(cbrt.f64 (+.f64 x 1))

simplify214.0ms (6%)

Algorithm
egg-herbie
Rules
436×cancel-sign-sub-inv_binary64
355×fma-neg_binary64
250×sub-neg_binary64
216×associate-*r*_binary64
178×associate-*l*_binary64
Counts
275 → 356
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
03848065
110326727
236326343
347746294
449756294
549116294

prune405.0ms (11.4%)

Pruning

5 alts after pruning (3 fresh and 2 done)

PrunedKeptTotal
New4400440
Fresh033
Picked011
Done011
Total4405445
Error
0.0b
Counts
445 → 5
Alt Table
StatusErrorProgram
18.2b
(*.f64 1 (*.f64 (*.f64 (+.f64 (/.f64 x y) 1) (sqrt.f64 (/.f64 x (+.f64 x 1)))) (sqrt.f64 (/.f64 x (+.f64 x 1)))))
19.4b
(*.f64 1 (/.f64 (fma.f64 x (pow.f64 (/.f64 x y) 3) x) (*.f64 (+.f64 x 1) (+.f64 1 (*.f64 (/.f64 x y) (-.f64 (/.f64 x y) 1))))))
8.4b
(*.f64 1 (*.f64 (fma.f64 x (/.f64 x y) x) (/.f64 1 (+.f64 x 1))))
15.2b
(+.f64 (/.f64 (pow.f64 x 2) (*.f64 (+.f64 1 x) y)) (/.f64 x (+.f64 1 x)))
8.8b
(*.f64 (/.f64 1 (*.f64 (cbrt.f64 (+.f64 x 1)) (cbrt.f64 (+.f64 x 1)))) (/.f64 (fma.f64 x (/.f64 x y) x) (cbrt.f64 (+.f64 x 1))))
Compiler

Compiled 14836 to 9391 computations (36.7% saved)

regimes580.0ms (16.3%)

Accuracy

Total 0.0b remaining (65.1%)

Threshold costs 0.0b (65.1%)

Counts
187 → 1
Compiler

Compiled 10229 to 7058 computations (31% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Rules
+-commutative_binary64
*-commutative_binary64
*-lft-identity_binary64
/-rgt-identity_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01116
11716
21616

end85.0ms (2.4%)

Compiler

Compiled 135 to 93 computations (31.1% saved)

Profiling

Loading profile data...