Details

Time bar (total: 2.2s)

analyze83.0ms (3.7%)

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
25%74.9%0.1%5
50%50%0.1%6
62.4%31.2%6.3%7
71.8%21.9%6.3%8
76.5%14%9.5%9
80.4%10.1%9.5%10
82.3%6.6%11%11
84.1%4.9%11%12
85%3.2%11.8%13
85.8%2.4%11.8%14
Compiler

Compiled 12 to 10 computations (16.7% saved)

sample926.0ms (41.6%)

Results
890.0ms8256×body128valid
6.0ms68×body128invalid
Compiler

Compiled 35 to 29 computations (17.1% saved)

simplify7.0ms (0.3%)

Algorithm
egg-herbie
Rules
18×fma-def_binary64
13×distribute-lft-in_binary64
13×distribute-rgt-in_binary64
10×*-commutative_binary64
associate-*l*_binary64
Counts
1 → 2
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01110
11810
2328
3568
4688
5748
6668

prune4.0ms (0.2%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.1b
Counts
3 → 2
Alt Table
StatusErrorProgram
0.2b
(*.f64 (fma.f64 x 3 -12/29) y)
0.2b
(*.f64 (*.f64 (-.f64 x (/.f64 16 116)) 3) y)
Compiler

Compiled 55 to 43 computations (21.8% saved)

localize5.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 x 3 -12/29)
0.2b
(*.f64 (fma.f64 x 3 -12/29) y)

series9.0ms (0.4%)

Counts
2 → 36
Calls

2 calls:

8.0ms
(*.f64 (fma.f64 x 3 -12/29) y)
1.0ms
(fma.f64 x 3 -12/29)

rewrite119.0ms (5.4%)

Algorithm
batch-egg-rewrite
Rules
583×log1p-expm1-u_binary64
583×expm1-log1p-u_binary64
287×log-prod_binary64
246×fma-def_binary64
190×pow2_binary64
Counts
2 → 52
Calls

2 calls:

118.0ms
(fma.f64 x 3 -12/29)
118.0ms
(*.f64 (fma.f64 x 3 -12/29) y)
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
114113
2151313
3494413
4507913
000
100

simplify33.0ms (1.5%)

Algorithm
egg-herbie
Rules
315×fma-def_binary64
170×fma-neg_binary64
59×cancel-sign-sub-inv_binary64
48×distribute-rgt-neg-in_binary64
29×distribute-rgt-in_binary64
Counts
88 → 61
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
014345
129240
244240
361240
499240
5148240
6266240
7409240
8492240
9545240
10547240
11476240

prune53.0ms (2.4%)

Pruning

7 alts after pruning (7 fresh and 0 done)

PrunedKeptTotal
New54761
Fresh101
Picked101
Done000
Total56763
Error
0.0b
Counts
63 → 7
Alt Table
StatusErrorProgram
13.8b
(*.f64 (expm1.f64 (log1p.f64 (fma.f64 x 3 -12/29))) y)
31.0b
(pow.f64 (sqrt.f64 (*.f64 (fma.f64 x 3 -12/29) y)) 2)
0.2b
(-.f64 (*.f64 3 (*.f64 y x)) (*.f64 12/29 y))
0.2b
(fma.f64 y (*.f64 x 3) (*.f64 y -12/29))
1.4b
(pow.f64 (cbrt.f64 (*.f64 (fma.f64 x 3 -12/29) y)) 3)
14.4b
(*.f64 (cbrt.f64 (pow.f64 (fma.f64 x 3 -12/29) 3)) y)
50.9b
(*.f64 (pow.f64 (sqrt.f64 (fma.f64 x 3 -12/29)) 2) y)
Compiler

Compiled 738 to 568 computations (23% saved)

localize5.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(*.f64 y -12/29)
0.1b
(fma.f64 y (*.f64 x 3) (*.f64 y -12/29))

series8.0ms (0.3%)

Counts
2 → 36
Calls

2 calls:

6.0ms
(fma.f64 y (*.f64 x 3) (*.f64 y -12/29))
1.0ms
(*.f64 y -12/29)

rewrite124.0ms (5.6%)

Algorithm
batch-egg-rewrite
Rules
669×log1p-expm1-u_binary64
669×expm1-log1p-u_binary64
158×prod-diff_binary64
141×expm1-udef_binary64
141×log1p-udef_binary64
Counts
2 → 36
Calls

2 calls:

123.0ms
(*.f64 y -12/29)
123.0ms
(fma.f64 y (*.f64 x 3) (*.f64 y -12/29))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0815
116114
2175012
3491212
4497512
5499512
6488412
000
100

simplify29.0ms (1.3%)

Algorithm
egg-herbie
Rules
203×fma-def_binary64
135×fma-neg_binary64
52×cancel-sign-sub-inv_binary64
46×associate-*r*_binary64
45×associate-*l*_binary64
Counts
72 → 43
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
018234
144234
282234
3171234
4271234
5392234
6470234
7541234
8470234

prune41.0ms (1.9%)

Pruning

8 alts after pruning (7 fresh and 1 done)

PrunedKeptTotal
New42143
Fresh066
Picked011
Done000
Total42850
Error
0.0b
Counts
50 → 8
Alt Table
StatusErrorProgram
13.8b
(*.f64 (expm1.f64 (log1p.f64 (fma.f64 x 3 -12/29))) y)
31.0b
(pow.f64 (sqrt.f64 (*.f64 (fma.f64 x 3 -12/29) y)) 2)
0.2b
(-.f64 (*.f64 3 (*.f64 y x)) (*.f64 12/29 y))
1.4b
(*.f64 (cbrt.f64 (*.f64 y (fma.f64 x 3 -12/29))) (pow.f64 (cbrt.f64 (*.f64 y (fma.f64 x 3 -12/29))) 2))
0.2b
(fma.f64 y (*.f64 x 3) (*.f64 y -12/29))
1.4b
(pow.f64 (cbrt.f64 (*.f64 (fma.f64 x 3 -12/29) y)) 3)
14.4b
(*.f64 (cbrt.f64 (pow.f64 (fma.f64 x 3 -12/29) 3)) y)
50.9b
(*.f64 (pow.f64 (sqrt.f64 (fma.f64 x 3 -12/29)) 2) y)
Compiler

Compiled 630 to 466 computations (26% saved)

localize7.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (*.f64 3 (*.f64 y x)) (*.f64 12/29 y))
0.1b
(*.f64 12/29 y)
0.3b
(*.f64 3 (*.f64 y x))

series11.0ms (0.5%)

Counts
3 → 15
Calls

3 calls:

6.0ms
(-.f64 (*.f64 3 (*.f64 y x)) (*.f64 12/29 y))
4.0ms
(*.f64 3 (*.f64 y x))
1.0ms
(*.f64 12/29 y)

rewrite77.0ms (3.5%)

Algorithm
batch-egg-rewrite
Rules
495×log-prod_binary64
410×fma-def_binary64
221×egg-rr
202×fma-neg_binary64
178×pow1/3_binary64
Counts
3 → 221
Calls

3 calls:

73.0ms
(-.f64 (*.f64 3 (*.f64 y x)) (*.f64 12/29 y))
73.0ms
(*.f64 12/29 y)
73.0ms
(*.f64 3 (*.f64 y x))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0924
120122
2244922
3494222
000
100

simplify26.0ms (1.2%)

Algorithm
egg-herbie
Rules
176×fma-def_binary64
142×fma-neg_binary64
49×associate-*r*_binary64
48×associate-*l*_binary64
36×cancel-sign-sub-inv_binary64
Counts
236 → 227
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
016114
137114
274114
3155114
4248114
5374114
6468114
7541114
8470114

prune179.0ms (8%)

Pruning

7 alts after pruning (6 fresh and 1 done)

PrunedKeptTotal
New2243227
Fresh336
Picked101
Done011
Total2287235
Error
0b
Counts
235 → 7
Alt Table
StatusErrorProgram
0.2b
(fma.f64 x (*.f64 3 y) (*.f64 y -12/29))
14.4b
(*.f64 (cbrt.f64 (pow.f64 (fma.f64 x 3 -12/29) 3)) y)
0.2b
(fma.f64 y -12/29 (*.f64 3 (*.f64 y x)))
0.2b
(fma.f64 y (*.f64 x 3) (*.f64 y -12/29))
13.8b
(*.f64 (expm1.f64 (log1p.f64 (fma.f64 x 3 -12/29))) y)
0.6b
(fma.f64 (cbrt.f64 (*.f64 3 (*.f64 y x))) (pow.f64 (cbrt.f64 (*.f64 3 (*.f64 y x))) 2) (*.f64 y -12/29))
50.9b
(*.f64 (pow.f64 (sqrt.f64 (fma.f64 x 3 -12/29)) 2) y)
Compiler

Compiled 4342 to 2750 computations (36.7% saved)

localize5.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 y -12/29 (*.f64 3 (*.f64 y x)))
0.3b
(*.f64 3 (*.f64 y x))

series10.0ms (0.4%)

Counts
1 → 24
Calls

1 calls:

10.0ms
(fma.f64 y -12/29 (*.f64 3 (*.f64 y x)))

rewrite43.0ms (1.9%)

Algorithm
batch-egg-rewrite
Rules
686×log1p-expm1-u_binary64
686×expm1-log1p-u_binary64
158×prod-diff_binary64
143×expm1-udef_binary64
143×log1p-udef_binary64
Counts
1 → 24
Calls

1 calls:

41.0ms
(fma.f64 y -12/29 (*.f64 3 (*.f64 y x)))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0811
116311
2179211
3492311
000
100

simplify28.0ms (1.2%)

Algorithm
egg-herbie
Rules
203×fma-def_binary64
135×fma-neg_binary64
52×cancel-sign-sub-inv_binary64
46×associate-*r*_binary64
45×associate-*l*_binary64
Counts
48 → 32
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
018186
144186
282186
3171186
4271186
5392186
6470186
7541186
8470186

prune38.0ms (1.7%)

Pruning

7 alts after pruning (5 fresh and 2 done)

PrunedKeptTotal
New47148
Fresh145
Picked011
Done011
Total48755
Error
0b
Counts
55 → 7
Alt Table
StatusErrorProgram
0.6b
(fma.f64 y -12/29 (pow.f64 (cbrt.f64 (*.f64 3 (*.f64 y x))) 3))
0.2b
(fma.f64 y (*.f64 x 3) (*.f64 y -12/29))
0.2b
(fma.f64 x (*.f64 3 y) (*.f64 y -12/29))
14.4b
(*.f64 (cbrt.f64 (pow.f64 (fma.f64 x 3 -12/29) 3)) y)
0.2b
(fma.f64 y -12/29 (*.f64 3 (*.f64 y x)))
13.8b
(*.f64 (expm1.f64 (log1p.f64 (fma.f64 x 3 -12/29))) y)
50.9b
(*.f64 (pow.f64 (sqrt.f64 (fma.f64 x 3 -12/29)) 2) y)
Compiler

Compiled 637 to 408 computations (35.9% saved)

regimes251.0ms (11.3%)

Accuracy

Total 0.2b remaining (90.7%)

Threshold costs 0.2b (90.7%)

Counts
50 → 1
Compiler

Compiled 3005 to 2306 computations (23.3% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0811
11011
21011

end106.0ms (4.7%)

Compiler

Compiled 95 to 71 computations (25.3% saved)

Profiling

Loading profile data...