Details

Time bar (total: 5.2s)

analyze24.0ms (0.5%)

Algorithm
search
Search
TrueOtherFalseIter
0%25%75%0
0%25%75%1
12.5%12.5%75%2
12.5%12.5%75%3
18.7%6.2%75%4
21.8%3.1%75%5
23.4%1.6%75%6
23.4%1.6%75%7
24.2%0.8%75%8
24.2%0.8%75%9
24.6%0.4%75%10
24.6%0.4%75%11
24.8%0.2%75%12
24.8%0.2%75%13
24.9%0.1%75%14
Compiler

Compiled 20 to 14 computations (30% saved)

sample90.0ms (1.7%)

Algorithm
intervals
Results
32.0ms61×body1024valid
15.0ms150×body128valid
8.0ms27×body512valid
5.0ms256×pre128true
3.0ms18×body256valid
Compiler

Compiled 35 to 25 computations (28.6% saved)

simplify7.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-/l*_binary64
associate-/r/_binary64
fma-def_binary64
+-commutative_binary64
Counts
1 → 2
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01017
11715
22315
32615
42715
52615

prune3.0ms (0.1%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
0.1b
Counts
3 → 1
Alt Table
StatusErrorProgram
0.1b
(/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))
Compiler

Compiled 47 to 28 computations (40.4% saved)

localize10.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(sin.f64 v)
0.0b
(/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))
0.1b
(*.f64 e (sin.f64 v))

series43.0ms (0.8%)

Counts
3 → 32
Calls

3 calls:

33.0ms
(/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))
8.0ms
(*.f64 e (sin.f64 v))
3.0ms
(sin.f64 v)

rewrite10.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
10×add-cbrt-cube_binary64
10×add-exp-log_binary64
add-sqr-sqrt_binary64
*-un-lft-identity_binary64
add-cube-cbrt_binary64
Counts
3 → 52
Calls

3 calls:

4.0ms
(/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))
3.0ms
(*.f64 e (sin.f64 v))
1.0ms
(sin.f64 v)

simplify76.0ms (1.5%)

Algorithm
egg-herbie
Rules
590×associate-/r*_binary64
500×fma-def_binary64
460×fma-neg_binary64
310×cancel-sign-sub-inv_binary64
287×associate-/r/_binary64
Counts
84 → 96
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01861794
15021638
219851594
349071594
451781594

prune96.0ms (1.9%)

Pruning

7 alts after pruning (6 fresh and 1 done)

PrunedKeptTotal
New90696
Fresh000
Picked011
Done000
Total90797
Error
0.0b
Counts
97 → 7
Alt Table
StatusErrorProgram
0.4b
(/.f64 (*.f64 (sqrt.f64 e) (*.f64 (sqrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
1.1b
(/.f64 (*.f64 (*.f64 (cbrt.f64 e) (cbrt.f64 e)) (*.f64 (cbrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
1.1b
(/.f64 (*.f64 (*.f64 (cbrt.f64 (*.f64 e (sin.f64 v))) (cbrt.f64 (*.f64 e (sin.f64 v)))) (cbrt.f64 (*.f64 e (sin.f64 v)))) (fma.f64 e (cos.f64 v) 1))
6.1b
(/.f64 (*.f64 e (cbrt.f64 (pow.f64 (sin.f64 v) 3))) (fma.f64 e (cos.f64 v) 1))
0.1b
(/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))
21.5b
(*.f64 (sqrt.f64 (/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))) (sqrt.f64 (/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))))
29.6b
(/.f64 (*.f64 (*.f64 e (sqrt.f64 (sin.f64 v))) (sqrt.f64 (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
Compiler

Compiled 2277 to 1194 computations (47.6% saved)

localize10.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(sin.f64 v)
0.0b
(/.f64 (*.f64 (sqrt.f64 e) (*.f64 (sqrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
0.2b
(*.f64 (sqrt.f64 e) (*.f64 (sqrt.f64 e) (sin.f64 v)))
0.3b
(*.f64 (sqrt.f64 e) (sin.f64 v))

series70.0ms (1.3%)

Counts
3 → 44
Calls

3 calls:

45.0ms
(/.f64 (*.f64 (sqrt.f64 e) (*.f64 (sqrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
14.0ms
(*.f64 (sqrt.f64 e) (sin.f64 v))
10.0ms
(*.f64 (sqrt.f64 e) (*.f64 (sqrt.f64 e) (sin.f64 v)))

rewrite22.0ms (0.4%)

Algorithm
rewrite-expression-head
Rules
19×add-cbrt-cube_binary64
19×add-exp-log_binary64
14×add-sqr-sqrt_binary64
12×associate-*l*_binary64
10×*-un-lft-identity_binary64
Counts
3 → 72
Calls

3 calls:

7.0ms
(/.f64 (*.f64 (sqrt.f64 e) (*.f64 (sqrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
7.0ms
(*.f64 (sqrt.f64 e) (*.f64 (sqrt.f64 e) (sin.f64 v)))
4.0ms
(*.f64 (sqrt.f64 e) (sin.f64 v))

simplify88.0ms (1.7%)

Algorithm
egg-herbie
Rules
572×fma-def_binary64
463×fma-neg_binary64
330×cancel-sign-sub-inv_binary64
321×associate-/l/_binary64
214×associate-*r*_binary64
Counts
116 → 133
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02112164
15881939
223991885
345741885
449551885

prune134.0ms (2.6%)

Pruning

8 alts after pruning (6 fresh and 2 done)

PrunedKeptTotal
New1473150
Fresh235
Picked011
Done011
Total1498157
Error
0.0b
Counts
157 → 8
Alt Table
StatusErrorProgram
0.4b
(/.f64 (*.f64 (sqrt.f64 e) (*.f64 (sqrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
1.1b
(/.f64 (*.f64 (*.f64 (cbrt.f64 e) (cbrt.f64 e)) (*.f64 (cbrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
0.9b
(/.f64 (*.f64 (sqrt.f64 e) (*.f64 (*.f64 (sqrt.f64 e) (*.f64 (cbrt.f64 (sin.f64 v)) (cbrt.f64 (sin.f64 v)))) (cbrt.f64 (sin.f64 v)))) (fma.f64 e (cos.f64 v) 1))
6.1b
(/.f64 (*.f64 e (cbrt.f64 (pow.f64 (sin.f64 v) 3))) (fma.f64 e (cos.f64 v) 1))
0.1b
(/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))
21.5b
(*.f64 (sqrt.f64 (/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))) (sqrt.f64 (/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))))
0.8b
(/.f64 (*.f64 (sqrt.f64 (*.f64 (cbrt.f64 e) (cbrt.f64 e))) (*.f64 (sqrt.f64 (cbrt.f64 e)) (*.f64 (sqrt.f64 e) (sin.f64 v)))) (fma.f64 e (cos.f64 v) 1))
0.5b
(/.f64 (*.f64 (sqrt.f64 (sqrt.f64 e)) (*.f64 (sqrt.f64 e) (*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e))))) (fma.f64 e (cos.f64 v) 1))
Compiler

Compiled 3693 to 1630 computations (55.9% saved)

localize14.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f64 (sqrt.f64 e))
0.2b
(*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e)))
0.2b
(*.f64 (sqrt.f64 (sqrt.f64 e)) (*.f64 (sqrt.f64 e) (*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e)))))
0.3b
(*.f64 (sqrt.f64 e) (*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e))))

series406.0ms (7.8%)

Counts
4 → 68
Calls

4 calls:

225.0ms
(*.f64 (sqrt.f64 e) (*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e))))
151.0ms
(*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e)))
19.0ms
(sqrt.f64 (sqrt.f64 e))
10.0ms
(*.f64 (sqrt.f64 (sqrt.f64 e)) (*.f64 (sqrt.f64 e) (*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e)))))

rewrite31.0ms (0.6%)

Algorithm
rewrite-expression-head
Rules
34×sqrt-prod_binary64
23×add-sqr-sqrt_binary64
22×pow1_binary64
20×add-cbrt-cube_binary64
20×add-exp-log_binary64
Counts
4 → 101
Calls

4 calls:

11.0ms
(*.f64 (sqrt.f64 (sqrt.f64 e)) (*.f64 (sqrt.f64 e) (*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e)))))
7.0ms
(*.f64 (sqrt.f64 e) (*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e))))
7.0ms
(*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e)))
1.0ms
(sqrt.f64 (sqrt.f64 e))

simplify103.0ms (2%)

Algorithm
egg-herbie
Rules
795×fma-neg_binary64
526×cancel-sign-sub-inv_binary64
493×*-commutative_binary64
299×fma-def_binary64
290×distribute-rgt-neg-in_binary64
Counts
169 → 150
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01502429
13711885
212741837
325411837
446811837
550091837

prune160.0ms (3.1%)

Pruning

8 alts after pruning (5 fresh and 3 done)

PrunedKeptTotal
New1702172
Fresh235
Picked011
Done022
Total1728180
Error
0b
Counts
180 → 8
Alt Table
StatusErrorProgram
0.5b
(/.f64 (*.f64 (sqrt.f64 (sqrt.f64 e)) (*.f64 (sqrt.f64 e) (*.f64 (*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e)))) (sqrt.f64 (sqrt.f64 (cbrt.f64 e)))))) (fma.f64 e (cos.f64 v) 1))
0.4b
(/.f64 (*.f64 (sqrt.f64 e) (*.f64 (sqrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
1.1b
(/.f64 (*.f64 (*.f64 (cbrt.f64 e) (cbrt.f64 e)) (*.f64 (cbrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
0.9b
(/.f64 (*.f64 (sqrt.f64 e) (*.f64 (*.f64 (sqrt.f64 e) (*.f64 (cbrt.f64 (sin.f64 v)) (cbrt.f64 (sin.f64 v)))) (cbrt.f64 (sin.f64 v)))) (fma.f64 e (cos.f64 v) 1))
0.6b
(/.f64 (*.f64 (sqrt.f64 (sqrt.f64 (*.f64 (cbrt.f64 e) (cbrt.f64 e)))) (*.f64 (*.f64 (sin.f64 v) (pow.f64 (sqrt.f64 (sqrt.f64 e)) 3)) (sqrt.f64 (sqrt.f64 (cbrt.f64 e))))) (fma.f64 e (cos.f64 v) 1))
0.1b
(/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))
21.5b
(*.f64 (sqrt.f64 (/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))) (sqrt.f64 (/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))))
0.5b
(/.f64 (*.f64 (sqrt.f64 (sqrt.f64 e)) (*.f64 (sqrt.f64 e) (*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e))))) (fma.f64 e (cos.f64 v) 1))
Compiler

Compiled 4499 to 1597 computations (64.5% saved)

localize20.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.3b
(*.f64 (sqrt.f64 e) (*.f64 (*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e)))) (sqrt.f64 (sqrt.f64 (cbrt.f64 e)))))
0.3b
(*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e))))
0.3b
(*.f64 (*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e)))) (sqrt.f64 (sqrt.f64 (cbrt.f64 e))))
0.6b
(cbrt.f64 e)

series744.0ms (14.4%)

Counts
4 → 80
Calls

4 calls:

424.0ms
(*.f64 (*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e)))) (sqrt.f64 (sqrt.f64 (cbrt.f64 e))))
265.0ms
(*.f64 (sqrt.f64 e) (*.f64 (*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e)))) (sqrt.f64 (sqrt.f64 (cbrt.f64 e)))))
31.0ms
(cbrt.f64 e)
25.0ms
(*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e))))

rewrite38.0ms (0.7%)

Algorithm
rewrite-expression-head
Rules
34×sqrt-prod_binary64
30×add-sqr-sqrt_binary64
27×associate-*r*_binary64
20×add-cbrt-cube_binary64
20×add-exp-log_binary64
Counts
4 → 104
Calls

4 calls:

11.0ms
(*.f64 (sqrt.f64 e) (*.f64 (*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e)))) (sqrt.f64 (sqrt.f64 (cbrt.f64 e)))))
11.0ms
(*.f64 (*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e)))) (sqrt.f64 (sqrt.f64 (cbrt.f64 e))))
6.0ms
(*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e))))
1.0ms
(cbrt.f64 e)

simplify151.0ms (2.9%)

Algorithm
egg-herbie
Rules
639×fma-neg_binary64
540×cancel-sign-sub-inv_binary64
346×unswap-sqr_binary64
338×associate-*r*_binary64
336×associate-*l*_binary64
Counts
184 → 183
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
02213860
15043027
216682785
330202542
447482528
549482528
649652528

prune181.0ms (3.5%)

Pruning

8 alts after pruning (4 fresh and 4 done)

PrunedKeptTotal
New2010201
Fresh044
Picked011
Done033
Total2018209
Error
0b
Counts
209 → 8
Alt Table
StatusErrorProgram
0.5b
(/.f64 (*.f64 (sqrt.f64 (sqrt.f64 e)) (*.f64 (sqrt.f64 e) (*.f64 (*.f64 (sin.f64 v) (sqrt.f64 (fabs.f64 (cbrt.f64 e)))) (sqrt.f64 (sqrt.f64 (cbrt.f64 e)))))) (fma.f64 e (cos.f64 v) 1))
0.4b
(/.f64 (*.f64 (sqrt.f64 e) (*.f64 (sqrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
1.1b
(/.f64 (*.f64 (*.f64 (cbrt.f64 e) (cbrt.f64 e)) (*.f64 (cbrt.f64 e) (sin.f64 v))) (fma.f64 e (cos.f64 v) 1))
0.9b
(/.f64 (*.f64 (sqrt.f64 e) (*.f64 (*.f64 (sqrt.f64 e) (*.f64 (cbrt.f64 (sin.f64 v)) (cbrt.f64 (sin.f64 v)))) (cbrt.f64 (sin.f64 v)))) (fma.f64 e (cos.f64 v) 1))
0.6b
(/.f64 (*.f64 (sqrt.f64 (sqrt.f64 (*.f64 (cbrt.f64 e) (cbrt.f64 e)))) (*.f64 (*.f64 (sin.f64 v) (pow.f64 (sqrt.f64 (sqrt.f64 e)) 3)) (sqrt.f64 (sqrt.f64 (cbrt.f64 e))))) (fma.f64 e (cos.f64 v) 1))
0.1b
(/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))
21.5b
(*.f64 (sqrt.f64 (/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))) (sqrt.f64 (/.f64 (*.f64 e (sin.f64 v)) (fma.f64 e (cos.f64 v) 1))))
0.5b
(/.f64 (*.f64 (sqrt.f64 (sqrt.f64 e)) (*.f64 (sqrt.f64 e) (*.f64 (sin.f64 v) (sqrt.f64 (sqrt.f64 e))))) (fma.f64 e (cos.f64 v) 1))
Compiler

Compiled 6534 to 2496 computations (61.8% saved)

regimes184.0ms (3.5%)

Accuracy

Total 0.1b remaining (76.6%)

Threshold costs 0.1b (76.6%)

Counts
59 → 1
Compiler

Compiled 3701 to 2249 computations (39.2% saved)

simplify2.0ms (0%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0915
11215
21115

end0.0ms (0%)

Compiler

Compiled 12 to 8 computations (33.3% saved)

sample2.5s (47.6%)

Algorithm
intervals
Results
1.0s1950×body1024valid
420.0ms4538×body128valid
276.0ms999×body512valid
177.0ms8000×pre128true
93.0ms511×body256valid
2.0msbody2048valid
Compiler

Compiled 208 to 130 computations (37.5% saved)

Profiling

Loading profile data...