Details

Time bar (total: 7.4s)

analyze1.2s (15.7%)

Algorithm
search
Search
TrueOtherFalseIter
0%100%0%0
0%100%0%1
0%100%0%2
0%100%0%3
0%100%0%4
0%100%0%5
0%100%0%6
0%100%0%7
0%100%0%8
0%100%0%9
0%100%0%10
0%100%0%11
0%100%0%12
3%46.9%50%13
3.1%46.8%50%14
Compiler

Compiled 16 to 11 computations (31.3% saved)

sample3.7s (49.3%)

Results
2.3s4147×body2048valid
830.0ms2005×body1024valid
310.0ms1017×body512valid
118.0ms552×body256valid
68.0ms535×body128valid
0.0msbody128invalid
Compiler

Compiled 47 to 32 computations (31.9% saved)

simplify29.0ms (0.4%)

Algorithm
egg-herbie
Rules
685×div-sub_binary64
303×associate-/r*_binary64
302×fma-def_binary64
296×fma-neg_binary64
220×associate-/l/_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01019
13119
27617
321517
464017
5182817
6439417
Stop Event
node limit
Counts
1 → 2

prune3.0ms (0%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
0.7b
Counts
3 → 1
Alt Table
StatusErrorProgram
0.7b
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
Compiler

Compiled 53 to 36 computations (32.1% saved)

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))
0.7b
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))

series4.0ms (0.1%)

Counts
2 → 24
Calls

2 calls:

3.0ms
(/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))
2.0ms
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))

rewrite63.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
891×log1p-expm1-u_binary64
891×expm1-log1p-u_binary64
98×add-sqr-sqrt_binary64
91×add-cbrt-cube_binary64
90×add-log-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01032
119932
2234532
Stop Event
node limit
Counts
2 → 67
Calls

2 calls:

62.0ms
(/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))
61.0ms
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))

simplify29.0ms (0.4%)

Algorithm
egg-herbie
Rules
649×cancel-sign-sub-inv_binary64
494×fma-def_binary64
285×unswap-sqr_binary64
207×distribute-neg-frac_binary64
189×associate-*l*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
040380
1114362
2326359
3976359
43116359
Stop Event
node limit
Counts
91 → 83

prune91.0ms (1.2%)

Pruning

6 alts after pruning (6 fresh and 0 done)

PrunedKeptTotal
New77683
Fresh000
Picked101
Done000
Total78684
Error
0.7b
Counts
84 → 6
Alt Table
StatusErrorProgram
2.2b
(*.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))
1.0b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
2.2b
(+.f64 (fma.f64 (sqrt.f64 (*.f64 (PI.f64) 1/2)) (sqrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))
2.6b
(+.f64 (fma.f64 (*.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) (cbrt.f64 (*.f64 (PI.f64) 1/2))) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))
2.2b
(+.f64 (fma.f64 (*.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) (cbrt.f64 (*.f64 (PI.f64) 1/2))) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1))) (fma.f64 (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 1 (*.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 1)))
0.7b
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
Compiler

Compiled 3065 to 2244 computations (26.8% saved)

localize10.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
0.0b
(/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))
0.0b
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
0.7b
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))

series330.0ms (4.4%)

Counts
2 → 24
Calls

2 calls:

328.0ms
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
2.0ms
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))

rewrite51.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
471×log-prod_binary64
272×pow2_binary64
190×pow1/3_binary64
188×expm1-udef_binary64
188×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01236
122036
2255336
Stop Event
node limit
Counts
2 → 66
Calls

2 calls:

50.0ms
(log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))
50.0ms
(expm1.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))

simplify46.0ms (0.6%)

Algorithm
egg-herbie
Rules
862×fma-neg_binary64
335×fma-def_binary64
328×div-sub_binary64
246×sub-neg_binary64
207×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
012432
121432
228432
337432
455432
596432
6178432
7388432
8786432
92475432
104590432
Stop Event
node limit
Counts
90 → 69

prune194.0ms (2.6%)

Pruning

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New1484152
Fresh415
Picked101
Done000
Total1535158
Error
0.7b
Counts
158 → 5
Alt Table
StatusErrorProgram
0.7b
(expm1.f64 (log1p.f64 (pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)))
3.3b
(expm1.f64 (pow.f64 (cbrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 3))
2.2b
(expm1.f64 (-.f64 (log1p.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3)) (log.f64 (+.f64 1 (-.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2) (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))
2.2b
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
1.0b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
Compiler

Compiled 4650 to 3471 computations (25.4% saved)

localize16.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(expm1.f64 (log1p.f64 (pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)))
0.0b
(pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)
0.7b
(acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))
1.0b
(pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3)

series812.0ms (10.9%)

Counts
3 → 36
Calls

3 calls:

421.0ms
(pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)
380.0ms
(expm1.f64 (log1p.f64 (pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)))
11.0ms
(pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3)

rewrite70.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
566×log-prod_binary64
232×expm1-udef_binary64
232×log1p-udef_binary64
197×log-pow_binary64
133×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01654
129754
2325254
Stop Event
node limit
Counts
3 → 120
Calls

3 calls:

66.0ms
(expm1.f64 (log1p.f64 (pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)))
66.0ms
(pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)
66.0ms
(pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3)

simplify51.0ms (0.7%)

Algorithm
egg-herbie
Rules
853×fma-neg_binary64
362×unswap-sqr_binary64
323×fma-def_binary64
245×sub-neg_binary64
217×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
012648
127648
239648
357648
496648
5211648
6653648
71515648
81967648
93787648
Stop Event
node limit
Counts
156 → 78

prune125.0ms (1.7%)

Pruning

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New1140114
Fresh044
Picked011
Done000
Total1145119
Error
0.7b
Counts
119 → 5
Alt Table
StatusErrorProgram
0.7b
(expm1.f64 (log1p.f64 (pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)))
3.3b
(expm1.f64 (pow.f64 (cbrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 3))
2.2b
(expm1.f64 (-.f64 (log1p.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3)) (log.f64 (+.f64 1 (-.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2) (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))
2.2b
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
1.0b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
Compiler

Compiled 4595 to 3459 computations (24.7% saved)

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.7b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))

series2.0ms (0%)

Counts
1 → 0
Calls

1 calls:

2.0ms
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))

rewrite40.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
667×log1p-expm1-u_binary64
667×expm1-log1p-u_binary64
152×prod-diff_binary64
138×expm1-udef_binary64
138×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0814
116414
2180514
Stop Event
node limit
Counts
1 → 35
Calls

1 calls:

39.0ms
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))

simplify6.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
000
Stop Event
saturated
Counts
35 → 35

prune51.0ms (0.7%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New33235
Fresh033
Picked101
Done011
Total34640
Error
0.7b
Counts
40 → 6
Alt Table
StatusErrorProgram
0.7b
(expm1.f64 (log1p.f64 (pow.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3) 1/3)))
3.3b
(expm1.f64 (pow.f64 (cbrt.f64 (log1p.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) 3))
62.2b
(/.f64 (-.f64 (*.f64 (*.f64 (PI.f64) 1/2) (*.f64 (PI.f64) 1/2)) (*.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)) (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) (fma.f64 (PI.f64) 1/2 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))
2.2b
(expm1.f64 (-.f64 (log1p.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 3)) (log.f64 (+.f64 1 (-.f64 (pow.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))) 2) (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))))))
2.2b
(fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 2) (cbrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))))
2.4b
(+.f64 (fma.f64 (PI.f64) 1/2 (neg.f64 (*.f64 (cbrt.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (*.f64 (cbrt.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (cbrt.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) (*.f64 (cbrt.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (cbrt.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) (*.f64 (cbrt.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (*.f64 (cbrt.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) (cbrt.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))))))
Compiler

Compiled 1435 to 1085 computations (24.4% saved)

regimes351.0ms (4.7%)

Accuracy

Total 0.0b remaining (3%)

Threshold costs 0.0b (3%)

Counts
91 → 1
Compiler

Compiled 9289 to 7064 computations (24% saved)

simplify2.0ms (0%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0164294967295
1194294967295
Stop Event
saturated

end216.0ms (2.9%)

Compiler

Compiled 304 to 233 computations (23.4% saved)

Profiling

Loading profile data...