Details

Time bar (total: 4.3s)

analyze1.3s (29.4%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.8%0.2%0
0%99.8%0.2%1
0%99.8%0.2%2
0%99.8%0.2%3
0%99.8%0.2%4
0%99.8%0.2%5
0%99.8%0.2%6
0%99.8%0.2%7
0%99.8%0.2%8
0%99.8%0.2%9
0%99.8%0.2%10
10.1%89.6%0.2%11
15.2%84.6%0.2%12
20.5%79.3%0.2%13
21.6%77.1%1.3%14
Compiler

Compiled 15 to 10 computations (33.3% saved)

sample1.4s (32.2%)

Results
981.0ms8256×body128valid
302.0ms2598×body128invalid
Compiler

Compiled 44 to 29 computations (34.1% saved)

simplify66.0ms (1.5%)

Algorithm
egg-herbie
Rules
783×fma-neg_binary64
721×fma-def_binary64
244×cancel-sign-sub-inv_binary64
187×distribute-rgt-in_binary64
138×distribute-lft-in_binary64
Counts
1 → 2
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01013
11713
23913
39813
425811
554211
6101911
7130211
8141411
9147011
10147611
11148111
12148111
13140811

prune3.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.0b
Counts
3 → 2
Alt Table
StatusErrorProgram
5.6b
(fma.f64 y (/.f64 (-.f64 t z) a) x)
8.1b
(-.f64 x (/.f64 (*.f64 y (-.f64 z t)) a))
Compiler

Compiled 76 to 46 computations (39.5% saved)

localize6.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(/.f64 (-.f64 t z) a)
5.4b
(fma.f64 y (/.f64 (-.f64 t z) a) x)

series38.0ms (0.9%)

Counts
2 → 88
Calls

2 calls:

29.0ms
(fma.f64 y (/.f64 (-.f64 t z) a) x)
9.0ms
(/.f64 (-.f64 t z) a)

rewrite8.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
20×*-un-lft-identity_binary64
20×add-sqr-sqrt_binary64
15×times-frac_binary64
12×add-cube-cbrt_binary64
associate-/l*_binary64
Counts
2 → 50
Calls

2 calls:

5.0ms
(/.f64 (-.f64 t z) a)
0.0ms
(fma.f64 y (/.f64 (-.f64 t z) a) x)

simplify81.0ms (1.9%)

Algorithm
egg-herbie
Rules
696×distribute-rgt-in_binary64
684×distribute-lft-in_binary64
583×times-frac_binary64
453×fma-def_binary64
215×div-sub_binary64
Counts
138 → 78
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01111607
12381462
25251460
313331460
448861460
549831460

prune43.0ms (1%)

Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New76278
Fresh011
Picked011
Done000
Total76480
Error
0.0b
Counts
80 → 4
Alt Table
StatusErrorProgram
6.1b
(fma.f64 y (*.f64 (*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z))) (/.f64 (cbrt.f64 (-.f64 t z)) a)) x)
8.1b
(-.f64 x (/.f64 (*.f64 y (-.f64 z t)) a))
5.6b
(fma.f64 y (/.f64 (-.f64 t z) a) x)
1.3b
(fma.f64 (/.f64 y a) (-.f64 t z) x)
Compiler

Compiled 1159 to 321 computations (72.3% saved)

localize7.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
1.2b
(fma.f64 (/.f64 y a) (-.f64 t z) x)

series22.0ms (0.5%)

Counts
1 → 60
Calls

1 calls:

22.0ms
(fma.f64 (/.f64 y a) (-.f64 t z) x)

rewrite1.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:

0.0ms
(fma.f64 (/.f64 y a) (-.f64 t z) x)

simplify64.0ms (1.5%)

Algorithm
egg-herbie
Rules
426×distribute-lft-neg-out_binary64
425×distribute-rgt-neg-out_binary64
378×distribute-rgt-in_binary64
375×distribute-lft-in_binary64
225×distribute-rgt-out_binary64
Counts
70 → 27
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
040863
176750
2164733
3450733
42142733
54579733
65069733

prune13.0ms (0.3%)

Pruning

4 alts after pruning (2 fresh and 2 done)

PrunedKeptTotal
New27027
Fresh022
Picked011
Done011
Total27431
Error
0.0b
Counts
31 → 4
Alt Table
StatusErrorProgram
6.1b
(fma.f64 y (*.f64 (*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z))) (/.f64 (cbrt.f64 (-.f64 t z)) a)) x)
8.1b
(-.f64 x (/.f64 (*.f64 y (-.f64 z t)) a))
5.6b
(fma.f64 y (/.f64 (-.f64 t z) a) x)
1.3b
(fma.f64 (/.f64 y a) (-.f64 t z) x)
Compiler

Compiled 391 to 116 computations (70.3% saved)

localize12.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.3b
(*.f64 (*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z))) (/.f64 (cbrt.f64 (-.f64 t z)) a))
0.5b
(*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z)))
0.5b
(cbrt.f64 (-.f64 t z))
5.4b
(fma.f64 y (*.f64 (*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z))) (/.f64 (cbrt.f64 (-.f64 t z)) a)) x)

series114.0ms (2.6%)

Counts
4 → 144
Calls

4 calls:

34.0ms
(fma.f64 y (*.f64 (*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z))) (/.f64 (cbrt.f64 (-.f64 t z)) a)) x)
34.0ms
(*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z)))
23.0ms
(cbrt.f64 (-.f64 t z))
21.0ms
(*.f64 (*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z))) (/.f64 (cbrt.f64 (-.f64 t z)) a))

rewrite40.0ms (0.9%)

Algorithm
rewrite-expression-head
Rules
57×add-sqr-sqrt_binary64
50×*-un-lft-identity_binary64
49×cbrt-prod_binary64
38×cbrt-div_binary64
36×associate-*r*_binary64
Counts
4 → 154
Calls

4 calls:

16.0ms
(*.f64 (*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z))) (/.f64 (cbrt.f64 (-.f64 t z)) a))
8.0ms
(*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z)))
2.0ms
(cbrt.f64 (-.f64 t z))
0.0ms
(fma.f64 y (*.f64 (*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z))) (/.f64 (cbrt.f64 (-.f64 t z)) a)) x)

simplify143.0ms (3.3%)

Algorithm
egg-herbie
Rules
792×fma-def_binary64
594×times-frac_binary64
410×associate-*l*_binary64
383×associate-*r*_binary64
224×*-commutative_binary64
Counts
298 → 291
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
03795928
19815615
233855374
351085374

prune254.0ms (5.9%)

Pruning

4 alts after pruning (1 fresh and 3 done)

PrunedKeptTotal
New3930393
Fresh011
Picked011
Done022
Total3934397
Error
0.0b
Counts
397 → 4
Alt Table
StatusErrorProgram
6.1b
(fma.f64 y (*.f64 (*.f64 (cbrt.f64 (-.f64 t z)) (cbrt.f64 (-.f64 t z))) (/.f64 (cbrt.f64 (-.f64 t z)) a)) x)
8.1b
(-.f64 x (/.f64 (*.f64 y (-.f64 z t)) a))
5.6b
(fma.f64 y (/.f64 (-.f64 t z) a) x)
1.3b
(fma.f64 (/.f64 y a) (-.f64 t z) x)
Compiler

Compiled 12080 to 4172 computations (65.5% saved)

localize6.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(*.f64 y (-.f64 z t))
0.0b
(-.f64 x (/.f64 (*.f64 y (-.f64 z t)) a))
8.1b
(/.f64 (*.f64 y (-.f64 z t)) a)

series55.0ms (1.3%)

Counts
3 → 144
Calls

3 calls:

29.0ms
(-.f64 x (/.f64 (*.f64 y (-.f64 z t)) a))
19.0ms
(/.f64 (*.f64 y (-.f64 z t)) a)
6.0ms
(*.f64 y (-.f64 z t))

rewrite24.0ms (0.6%)

Algorithm
rewrite-expression-head
Rules
43×add-sqr-sqrt_binary64
41×*-un-lft-identity_binary64
39×prod-diff_binary64
37×add-cube-cbrt_binary64
15×times-frac_binary64
Counts
3 → 121
Calls

3 calls:

6.0ms
(/.f64 (*.f64 y (-.f64 z t)) a)
5.0ms
(-.f64 x (/.f64 (*.f64 y (-.f64 z t)) a))
5.0ms
(*.f64 y (-.f64 z t))

simplify114.0ms (2.7%)

Algorithm
egg-herbie
Rules
753×fma-def_binary64
746×times-frac_binary64
299×exp-prod_binary64
213×cancel-sign-sub-inv_binary64
208×fma-neg_binary64
Counts
265 → 195
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
02683653
15553282
220752974
345622896
448772896

prune103.0ms (2.4%)

Pruning

5 alts after pruning (2 fresh and 3 done)

PrunedKeptTotal
New1932195
Fresh000
Picked011
Done123
Total1945199
Error
0b
Counts
199 → 5
Alt Table
StatusErrorProgram
5.6b
(fma.f64 y (/.f64 (-.f64 t z) a) x)
8.1b
(-.f64 x (/.f64 (*.f64 y (-.f64 z t)) a))
8.2b
(-.f64 x (/.f64 (+.f64 (*.f64 (fma.f64 (*.f64 (cbrt.f64 z) (cbrt.f64 z)) (cbrt.f64 z) (neg.f64 (*.f64 t 1))) y) (*.f64 (fma.f64 (neg.f64 t) 1 (*.f64 t 1)) y)) a))
34.8b
(/.f64 y (/.f64 a (-.f64 t z)))
1.3b
(fma.f64 (/.f64 y a) (-.f64 t z) x)
Compiler

Compiled 3904 to 957 computations (75.5% saved)

regimes356.0ms (8.3%)

Accuracy

Total 1.7b remaining (99.1%)

Threshold costs 0b (0%)

Counts
36 → 3
Compiler

Compiled 6089 to 3527 computations (42.1% saved)

bsearch1.0ms (0%)

Compiler

Compiled 8 to 6 computations (25% saved)

simplify3.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
01951
12351
23151
33551
43751
53751

end74.0ms (1.7%)

Compiler

Compiled 167 to 88 computations (47.3% saved)

Profiling

Loading profile data...