Details

Time bar (total: 12.5s)

analyze518.0ms (4.1%)

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
50%50%0.1%5
50%50%0.1%6
50%37.5%12.6%7
50%37.5%12.6%8
50%31.2%18.8%9
50%31.2%18.8%10
50%28.1%22%11
50%28.1%22%12
50%26.5%23.5%13
50%26.5%23.5%14
Compiler

Compiled 15 to 12 computations (20% saved)

sample6.7s (53.7%)

Results
3.5s5012×body1024valid
1.2s1959×body1024invalid
695.0ms1743×body512valid
404.0ms406×body2048valid
348.0ms988×body512invalid
182.0ms693×body256valid
136.0ms511×body256invalid
117.0ms798×body128invalid
60.0ms402×body128valid
Compiler

Compiled 44 to 35 computations (20.5% saved)

simplify81.0ms (0.6%)

Algorithm
egg-herbie
Rules
626×associate-/l*_binary64
509×div-sub_binary64
462×times-frac_binary64
386×sub-neg_binary64
367×associate-/r*_binary64
Counts
1 → 2
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01218
12218
24918
311118
420817
536217
669217
7151317
8372617
9428717
10485717
11474917

prune3.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New112
Fresh011
Picked000
Done000
Total123
Error
57.2b
Counts
3 → 1
Alt Table
StatusErrorProgram
57.2b
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im)))
Compiler

Compiled 53 to 38 computations (28.3% saved)

localize8.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(exp.f64 im)
0.0b
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im)))
6.3b
(-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im))

series21.0ms (0.2%)

Counts
3 → 40
Calls

3 calls:

18.0ms
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im)))
2.0ms
(-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im))
1.0ms
(exp.f64 im)

rewrite63.0ms (0.5%)

Algorithm
rewrite-expression-head
Rules
234×prod-diff_binary64
140×*-un-lft-identity_binary64
140×add-sqr-sqrt_binary64
136×add-cube-cbrt_binary64
130×exp-sum_binary64
Counts
3 → 223
Calls

3 calls:

15.0ms
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im)))
10.0ms
(-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im))
1.0ms
(exp.f64 im)

simplify185.0ms (1.5%)

Algorithm
egg-herbie
Rules
853×fma-neg_binary64
437×exp-prod_binary64
348×cancel-sign-sub-inv_binary64
343×associate-*l*_binary64
337×associate-*r*_binary64
Counts
263 → 284
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
04006418
16355651
223034617
342064611
451954611

prune305.0ms (2.4%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New2822284
Fresh000
Picked011
Done000
Total2823285
Error
0.1b
Counts
285 → 3
Alt Table
StatusErrorProgram
57.7b
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (log.f64 (exp.f64 (exp.f64 im)))))
1.0b
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
57.2b
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im)))
Compiler

Compiled 10579 to 4072 computations (61.5% saved)

localize21.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))
0.0b
(fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))
0.1b
(*.f64 1/2520 (pow.f64 im 7))
0.1b
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))

series67.0ms (0.5%)

Counts
4 → 48
Calls

4 calls:

54.0ms
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
5.0ms
(*.f64 1/2520 (pow.f64 im 7))
4.0ms
(fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))
3.0ms
(fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))

rewrite15.0ms (0.1%)

Algorithm
rewrite-expression-head
Rules
17×associate-*r*_binary64
15×add-sqr-sqrt_binary64
14×add-exp-log_binary64
11×add-cbrt-cube_binary64
10×*-un-lft-identity_binary64
Counts
4 → 77
Calls

4 calls:

5.0ms
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
5.0ms
(*.f64 1/2520 (pow.f64 im 7))
0.0ms
(fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))
0.0ms
(fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))

simplify78.0ms (0.6%)

Algorithm
egg-herbie
Rules
810×distribute-rgt-in_binary64
274×associate-*r*_binary64
263×associate-*l*_binary64
245×cancel-sign-sub-inv_binary64
190×fma-def_binary64
Counts
125 → 135
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02553370
16743038
225052944
356822944

prune181.0ms (1.4%)

Pruning

9 alts after pruning (7 fresh and 2 done)

PrunedKeptTotal
New1296135
Fresh011
Picked011
Done011
Total1299138
Error
0.0b
Counts
138 → 9
Alt Table
StatusErrorProgram
57.7b
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (log.f64 (exp.f64 (exp.f64 im)))))
2.3b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
32.8b
(*.f64 (*.f64 (*.f64 1/2 (cos.f64 re)) (sqrt.f64 (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))) (sqrt.f64 (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))))
57.2b
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im)))
32.6b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (sqrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))) (sqrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
1.0b
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
31.7b
(*.f64 (sqrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))) (sqrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))))
2.3b
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (*.f64 (*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))))
2.5b
(*.f64 (*.f64 (cbrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))) (cbrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re))))) (cbrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))))
Compiler

Compiled 5138 to 3936 computations (23.4% saved)

localize17.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))))
0.3b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
0.5b
(*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
0.7b
(cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))

series934.0ms (7.5%)

Counts
4 → 72
Calls

4 calls:

840.0ms
(*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))))
56.0ms
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
30.0ms
(*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
7.0ms
(cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))

rewrite40.0ms (0.3%)

Algorithm
rewrite-expression-head
Rules
41×pow1_binary64
36×add-exp-log_binary64
23×pow-prod-down_binary64
23×add-sqr-sqrt_binary64
22×cbrt-unprod_binary64
Counts
4 → 111
Calls

4 calls:

13.0ms
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
7.0ms
(*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))))
5.0ms
(*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
1.0ms
(cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))

simplify191.0ms (1.5%)

Algorithm
egg-herbie
Rules
498×times-frac_binary64
424×associate-*r*_binary64
405×associate-*l*_binary64
334×fma-neg_binary64
316×fma-def_binary64
Counts
183 → 248
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
041510353
111579111
241358149
352858149

prune619.0ms (5%)

Pruning

11 alts after pruning (8 fresh and 3 done)

PrunedKeptTotal
New3242326
Fresh066
Picked011
Done022
Total32411335
Error
0.0b
Counts
335 → 11
Alt Table
StatusErrorProgram
33.1b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (sqrt.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))) (pow.f64 (sqrt.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))) 3))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
32.6b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (sqrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))) (sqrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
57.7b
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (log.f64 (exp.f64 (exp.f64 im)))))
2.3b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
32.8b
(*.f64 (*.f64 (*.f64 1/2 (cos.f64 re)) (sqrt.f64 (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))) (sqrt.f64 (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))))
57.2b
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im)))
1.0b
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
31.7b
(*.f64 (sqrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))) (sqrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))))
2.3b
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (*.f64 (*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))))
2.5b
(*.f64 (*.f64 (cbrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))) (cbrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re))))) (cbrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))))
33.1b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (*.f64 (cbrt.f64 (sqrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))) (cbrt.f64 (sqrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
Compiler

Compiled 24814 to 19570 computations (21.1% saved)

localize18.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (*.f64 (*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))))
0.3b
(*.f64 (*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))
0.5b
(*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))
0.7b
(cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))

series125.0ms (1%)

Counts
4 → 60
Calls

4 calls:

56.0ms
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (*.f64 (*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))))
31.0ms
(cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))
31.0ms
(*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))
6.0ms
(*.f64 (*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))

rewrite28.0ms (0.2%)

Algorithm
rewrite-expression-head
Rules
35×pow1_binary64
28×add-sqr-sqrt_binary64
23×cbrt-prod_binary64
22×associate-*r*_binary64
18×*-un-lft-identity_binary64
Counts
4 → 123
Calls

4 calls:

6.0ms
(*.f64 (*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))
5.0ms
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (*.f64 (*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))))
4.0ms
(*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))
1.0ms
(cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))

simplify170.0ms (1.4%)

Algorithm
egg-herbie
Rules
347×fma-neg_binary64
340×times-frac_binary64
336×associate-*r*_binary64
325×associate-*l*_binary64
232×*-commutative_binary64
Counts
183 → 240
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
03626099
19875523
233815141
348825137
449435137

prune482.0ms (3.9%)

Pruning

10 alts after pruning (7 fresh and 3 done)

PrunedKeptTotal
New3171318
Fresh167
Picked101
Done033
Total31910329
Error
0.0b
Counts
329 → 10
Alt Table
StatusErrorProgram
33.1b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (sqrt.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))) (pow.f64 (sqrt.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))) 3))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
32.6b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (sqrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))) (sqrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
57.7b
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (log.f64 (exp.f64 (exp.f64 im)))))
2.3b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (*.f64 (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))) (cbrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
32.8b
(*.f64 (*.f64 (*.f64 -1/2 (cos.f64 re)) (sqrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))) (sqrt.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (*.f64 (*.f64 (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cbrt.f64 (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))))
1.0b
(*.f64 (*.f64 1/2 (cos.f64 re)) (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))
32.8b
(*.f64 (*.f64 (*.f64 1/2 (cos.f64 re)) (sqrt.f64 (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7)))))))) (sqrt.f64 (neg.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))))))
57.2b
(*.f64 (*.f64 1/2 (cos.f64 re)) (-.f64 (exp.f64 (-.f64 0 im)) (exp.f64 im)))
31.7b
(*.f64 (sqrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))) (sqrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))))
2.5b
(*.f64 (*.f64 (cbrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))) (cbrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re))))) (cbrt.f64 (*.f64 -1/2 (*.f64 (fma.f64 1/60 (pow.f64 im 5) (fma.f64 1/3 (pow.f64 im 3) (fma.f64 im 2 (*.f64 1/2520 (pow.f64 im 7))))) (cos.f64 re)))))
Compiler

Compiled 18535 to 14715 computations (20.6% saved)

regimes1.3s (10.1%)

Accuracy

Total 0.6b remaining (92%)

Threshold costs 0.6b (92%)

Counts
121 → 1
Compiler

Compiled 33969 to 27456 computations (19.2% saved)

simplify4.0ms (0%)

Algorithm
egg-herbie
Rules
21×*-commutative_binary64
17×+-commutative_binary64
14×sub-neg_binary64
14×neg-sub0_binary64
14×neg-mul-1_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
02541
14339
26739
310439
413939
515539
616339
716539
816039

end354.0ms (2.8%)

Compiler

Compiled 536 to 430 computations (19.8% saved)

Profiling

Loading profile data...