Details

Time bar (total: 6.1s)

analyze1.2s (19.1%)

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.8s (61.2%)

Results
2.3s4127×body2048valid
844.0ms2037×body1024valid
324.0ms1035×body512valid
111.0ms506×body256valid
72.0ms549×body128valid
1.0msbody4096valid
1.0msbody128invalid
Compiler

Compiled 47 to 32 computations (31.9% saved)

simplify26.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.8b
Counts
3 → 1
Alt Table
StatusErrorProgram
0.8b
(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)))

series7.0ms (0.1%)

Counts
2 → 24
Calls

2 calls:

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

rewrite51.0ms (0.8%)

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:

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

simplify28.0ms (0.5%)

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

prune76.0ms (1.2%)

Pruning

4 alts after pruning (4 fresh and 0 done)

PrunedKeptTotal
New79483
Fresh000
Picked101
Done000
Total80484
Error
0.7b
Counts
84 → 4
Alt Table
StatusErrorProgram
0.8b
(acos.f64 (*.f64 (fma.f64 v (*.f64 v -5) 1) (/.f64 1 (fma.f64 v v -1))))
1.7b
(pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 3)
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))))))))
0.9b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
Compiler

Compiled 2645 to 1934 computations (26.9% saved)

localize8.0ms (0.1%)

Local error

Found 3 expressions with local error:

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

series7.0ms (0.1%)

Counts
3 → 36
Calls

3 calls:

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

rewrite48.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
474×log-prod_binary64
268×pow2_binary64
189×pow1/3_binary64
185×expm1-udef_binary64
185×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01140
122140
2256440
Stop Event
node limit
Counts
3 → 101
Calls

3 calls:

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

simplify31.0ms (0.5%)

Algorithm
egg-herbie
Rules
695×fma-def_binary64
356×fma-neg_binary64
306×associate-*l*_binary64
245×cancel-sign-sub-inv_binary64
209×associate-*r*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
054590
1156566
2477559
31494559
Stop Event
node limit
Counts
137 → 131

prune105.0ms (1.7%)

Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New1301131
Fresh123
Picked011
Done000
Total1314135
Error
0.7b
Counts
135 → 4
Alt Table
StatusErrorProgram
0.8b
(acos.f64 (*.f64 (fma.f64 v (*.f64 v -5) 1) (/.f64 1 (fma.f64 v v -1))))
1.7b
(pow.f64 (cbrt.f64 (acos.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 3)
2.6b
(+.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 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)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))
0.9b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
Compiler

Compiled 3111 to 2307 computations (25.8% 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))

rewrite38.0ms (0.6%)

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:

37.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

prune50.0ms (0.8%)

Pruning

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New32335
Fresh112
Picked101
Done011
Total34539
Error
0.7b
Counts
39 → 5
Alt Table
StatusErrorProgram
0.8b
(acos.f64 (*.f64 (fma.f64 v (*.f64 v -5) 1) (/.f64 1 (fma.f64 v v -1))))
2.4b
(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 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))
2.6b
(+.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 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)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))
1.8b
(pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 3)
61.9b
(/.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))))
Compiler

Compiled 1556 to 1177 computations (24.4% saved)

localize8.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.7b
(acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))
1.0b
(cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))
1.5b
(pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 3)

series90.0ms (1.5%)

Counts
2 → 24
Calls

2 calls:

52.0ms
(pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 3)
38.0ms
(cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))

rewrite46.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
819×log1p-expm1-u_binary64
819×expm1-log1p-u_binary64
180×prod-diff_binary64
94×add-sqr-sqrt_binary64
92×add-cbrt-cube_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01130
122430
2227130
Stop Event
node limit
Counts
2 → 60
Calls

2 calls:

44.0ms
(cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))
44.0ms
(pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 3)

simplify39.0ms (0.6%)

Algorithm
egg-herbie
Rules
953×fma-def_binary64
704×unswap-sqr_binary64
603×associate-*l*_binary64
402×associate-*r*_binary64
211×distribute-rgt-out_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
010360
123360
243360
389360
4202360
5645360
62400360
74873360
Stop Event
node limit
Counts
84 → 61

prune90.0ms (1.5%)

Pruning

8 alts after pruning (7 fresh and 1 done)

PrunedKeptTotal
New92496
Fresh033
Picked101
Done011
Total938101
Error
0.7b
Counts
101 → 8
Alt Table
StatusErrorProgram
2.4b
(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 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))
2.4b
(pow.f64 (-.f64 (exp.f64 (log1p.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))) 1) 3)
0.8b
(acos.f64 (*.f64 (fma.f64 v (*.f64 v -5) 1) (/.f64 1 (fma.f64 v v -1))))
2.4b
(pow.f64 (cbrt.f64 (fma.f64 (sqrt.f64 (*.f64 (PI.f64) 1/2)) (sqrt.f64 (*.f64 (PI.f64) 1/2)) (neg.f64 (asin.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))) 3)
2.4b
(pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1)))) 3) 3)
2.4b
(*.f64 (pow.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))) 2)) 3) (cbrt.f64 (acos.f64 (fma.f64 4 (fma.f64 v v (pow.f64 v 4)) -1))))
2.6b
(+.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (PI.f64) 1/2)) 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)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1))))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2) (*.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) (pow.f64 (cbrt.f64 (asin.f64 (/.f64 (fma.f64 v (*.f64 v -5) 1) (fma.f64 v v -1)))) 2))))
61.9b
(/.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))))
Compiler

Compiled 3455 to 2663 computations (22.9% saved)

regimes230.0ms (3.8%)

Accuracy

Total 0.0b remaining (5.3%)

Threshold costs 0.0b (5.3%)

Counts
50 → 1
Compiler

Compiled 6126 to 4649 computations (24.1% saved)

simplify2.0ms (0%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01120
11520
Stop Event
saturated

end210.0ms (3.4%)

Compiler

Compiled 305 to 236 computations (22.6% saved)

Profiling

Loading profile data...