Details

Time bar (total: 14.1s)

analyze2.3s (16.5%)

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
0%99.9%0.1%5
0%99.9%0.1%6
6.2%93.6%0.1%7
9.4%90.5%0.1%8
14%85.8%0.1%9
19.5%80.4%0.1%10
20.7%79.2%0.1%11
22%77.8%0.1%12
23.5%76.4%0.1%13
23.8%76%0.1%14
Compiler

Compiled 13 to 9 computations (30.8% saved)

sample4.7s (33.3%)

Results
2.9s3582×body1024valid
677.0ms1387×body512valid
583.0ms2427×body128valid
338.0ms216×body2048valid
193.0ms644×body256valid
1.0msbody1024invalid
Compiler

Compiled 38 to 26 computations (31.6% saved)

simplify6.0ms (0%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0914
11314
21714
32014
42114
52114

prune2.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New112
Fresh011
Picked000
Done000
Total123
Error
14.5b
Counts
3 → 1
Alt Table
StatusErrorProgram
14.5b
(/.f64 (*.f64 r (sin.f64 b)) (cos.f64 (+.f64 a b)))
Compiler

Compiled 45 to 27 computations (40% saved)

localize7.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(*.f64 r (sin.f64 b))
0.2b
(/.f64 (*.f64 r (sin.f64 b)) (cos.f64 (+.f64 a b)))
3.7b
(cos.f64 (+.f64 a b))

series58.0ms (0.4%)

Counts
3 → 68
Calls

3 calls:

46.0ms
(/.f64 (*.f64 r (sin.f64 b)) (cos.f64 (+.f64 a b)))
7.0ms
(*.f64 r (sin.f64 b))
4.0ms
(cos.f64 (+.f64 a b))

rewrite228.0ms (1.6%)

Algorithm
egg-rewrite
Rules
60×egg
49×egg
43×egg
Counts
3 → 152
Calls

3 calls:

92.0ms
(/.f64 (*.f64 r (sin.f64 b)) (cos.f64 (+.f64 a b)))
84.0ms
(*.f64 r (sin.f64 b))
49.0ms
(cos.f64 (+.f64 a b))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
056
11156
215486
350676
0914
120014
2279914
3479214
4500914
056
1976
211146
347366
462426

simplify76.0ms (0.5%)

Algorithm
egg-herbie
Rules
833×times-frac_binary64
659×associate-/l*_binary64
533×fma-def_binary64
310×associate-/r*_binary64
177×fma-neg_binary64
Counts
220 → 188
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01311221
13871211
213521163
349131163
449721163

prune388.0ms (2.7%)

Pruning

13 alts after pruning (13 fresh and 0 done)

PrunedKeptTotal
New17513188
Fresh000
Picked101
Done000
Total17613189
Error
0.0b
Counts
189 → 13
Alt Table
StatusErrorProgram
34.3b
(*.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) (*.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) (/.f64 1 (cos.f64 (+.f64 b a)))))
43.1b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sqrt.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (sqrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.3b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
29.1b
(fma.f64 (/.f64 b (cos.f64 a)) r (/.f64 (*.f64 (sin.f64 a) (*.f64 b (*.f64 b r))) (pow.f64 (cos.f64 a) 2)))
15.2b
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 r (sin.f64 b))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 1 (*.f64 (cos.f64 a) (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))))))))
14.5b
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (/.f64 (-.f64 (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (+.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (/.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 3) (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)) (+.f64 (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) (+.f64 (*.f64 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))))))
0.5b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))) (cbrt.f64 (*.f64 (sin.f64 a) (sin.f64 b))))))))
0.8b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (*.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b)))) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
29.0b
(fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)))
14.7b
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
Compiler

Compiled 4940 to 1451 computations (70.6% saved)

localize17.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 r (sin.f64 b))
0.2b
(*.f64 (sin.f64 a) (sin.f64 b))
0.2b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
51.8b
(fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))

series184.0ms (1.3%)

Counts
3 → 72
Calls

3 calls:

131.0ms
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
43.0ms
(fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))
10.0ms
(*.f64 (sin.f64 a) (sin.f64 b))

rewrite215.0ms (1.5%)

Algorithm
egg-rewrite
Rules
62×egg
35×egg
24×egg
Counts
3 → 121
Calls

3 calls:

82.0ms
(*.f64 (sin.f64 a) (sin.f64 b))
80.0ms
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
50.0ms
(fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0818
116713
2185513
3573413
01646
134829
2418829
3496829
068
11238
215448
348898
450618

simplify95.0ms (0.7%)

Algorithm
egg-herbie
Rules
833×times-frac_binary64
664×associate-/l*_binary64
499×fma-def_binary64
310×associate-/r*_binary64
184×fma-neg_binary64
Counts
193 → 151
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01311471
13801461
212981401
348621391
449841391
549771391

prune593.0ms (4.2%)

Pruning

15 alts after pruning (15 fresh and 0 done)

PrunedKeptTotal
New2457252
Fresh4812
Picked101
Done000
Total25015265
Error
0.0b
Counts
265 → 15
Alt Table
StatusErrorProgram
14.5b
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (/.f64 (-.f64 (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (+.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.3b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (/.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 3) (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)) (+.f64 (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) (+.f64 (*.f64 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))))))
1.2b
(/.f64 (pow.f64 (cbrt.f64 (*.f64 r (sin.f64 b))) 3) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
14.7b
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
34.2b
(/.f64 (cbrt.f64 (pow.f64 (*.f64 r (sin.f64 b)) 3)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1))))
34.3b
(*.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) (*.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) (/.f64 1 (cos.f64 (+.f64 b a)))))
0.8b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (*.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b)))) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
15.2b
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 r (sin.f64 b))))
27.1b
(/.f64 (pow.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) 2) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
29.0b
(fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)))
Compiler

Compiled 9114 to 2196 computations (75.9% saved)

localize18.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)))))
0.3b
(pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)
27.6b
(cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3))
51.8b
(fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)))

series220.0ms (1.6%)

Counts
4 → 108
Calls

4 calls:

154.0ms
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)))))
32.0ms
(pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)
25.0ms
(fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)))
9.0ms
(cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3))

rewrite274.0ms (1.9%)

Algorithm
egg-rewrite
Rules
62×egg
39×egg
34×egg
24×egg
Counts
4 → 159
Calls

4 calls:

117.0ms
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)))))
54.0ms
(fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)))
49.0ms
(cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3))
48.0ms
(pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01118
121613
2231413
3533213
098
11728
220058
352618
0811
117011
2196511
3517811
01946
139639
2444639
3498639
4527039

simplify112.0ms (0.8%)

Algorithm
egg-herbie
Rules
842×fma-def_binary64
833×times-frac_binary64
340×fma-neg_binary64
301×cancel-sign-sub-inv_binary64
192×unswap-sqr_binary64
Counts
267 → 205
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01632079
14852061
218182029
347402017
449912013
549532013

prune349.0ms (2.5%)

Pruning

15 alts after pruning (14 fresh and 1 done)

PrunedKeptTotal
New2050205
Fresh01414
Picked011
Done000
Total20515220
Error
0.0b
Counts
220 → 15
Alt Table
StatusErrorProgram
14.5b
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (/.f64 (-.f64 (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (+.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.3b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (/.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 3) (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)) (+.f64 (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) (+.f64 (*.f64 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))))))
1.2b
(/.f64 (pow.f64 (cbrt.f64 (*.f64 r (sin.f64 b))) 3) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
14.7b
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
34.2b
(/.f64 (cbrt.f64 (pow.f64 (*.f64 r (sin.f64 b)) 3)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1))))
34.3b
(*.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) (*.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) (/.f64 1 (cos.f64 (+.f64 b a)))))
0.8b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (*.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b)))) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
15.2b
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 r (sin.f64 b))))
27.1b
(/.f64 (pow.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) 2) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
29.0b
(fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)))
Compiler

Compiled 8240 to 2120 computations (74.3% saved)

localize21.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (sin.f64 a) (sin.f64 b))
0.2b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
2.4b
(-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1)
51.8b
(fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))

series1.6s (11.4%)

Counts
2 → 60
Calls

2 calls:

1.1s
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
551.0ms
(-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1)

rewrite154.0ms (1.1%)

Algorithm
egg-rewrite
Rules
56×egg
55×egg
Counts
2 → 111
Calls

2 calls:

87.0ms
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
64.0ms
(-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1)
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0108
11858
222138
364598
02046
140439
2443024
3567424

simplify102.0ms (0.7%)

Algorithm
egg-herbie
Rules
833×times-frac_binary64
664×associate-/l*_binary64
499×fma-def_binary64
310×associate-/r*_binary64
184×fma-neg_binary64
Counts
171 → 140
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01301543
13791533
212981473
348621463
449841463
549771463

prune456.0ms (3.2%)

Pruning

14 alts after pruning (13 fresh and 1 done)

PrunedKeptTotal
New2631264
Fresh11213
Picked101
Done011
Total26514279
Error
0.0b
Counts
279 → 14
Alt Table
StatusErrorProgram
15.2b
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 r (sin.f64 b))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (-.f64 (exp.f64 (log1p.f64 (cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)))) 1))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
14.5b
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (/.f64 (-.f64 (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (+.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.3b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (/.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 3) (pow.f64 (*.f64 (sin.f64 a) (sin.f64 b)) 3)) (+.f64 (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) (+.f64 (*.f64 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))))))
1.2b
(/.f64 (pow.f64 (cbrt.f64 (*.f64 r (sin.f64 b))) 3) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
14.7b
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
34.2b
(/.f64 (cbrt.f64 (pow.f64 (*.f64 r (sin.f64 b)) 3)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
0.4b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (-.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) 1))))
34.3b
(*.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) (*.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) (/.f64 1 (cos.f64 (+.f64 b a)))))
0.8b
(/.f64 (*.f64 r (sin.f64 b)) (+.f64 (fma.f64 (*.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b)))) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
27.1b
(/.f64 (pow.f64 (sqrt.f64 (*.f64 r (sin.f64 b))) 2) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 a) (sin.f64 b)))))
29.0b
(fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)))
Compiler

Compiled 9653 to 2865 computations (70.3% saved)

regimes1.7s (11.7%)

Accuracy

Total 0.2b remaining (77.1%)

Threshold costs 0.2b (77.1%)

Counts
314 → 1
Compiler

Compiled 36692 to 20042 computations (45.4% saved)

simplify4.0ms (0%)

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

Useful iterations: 3 (0.0ms)

IterNodesCost
02060
13260
24060
34558
44858
54958
64658

end257.0ms (1.8%)

Compiler

Compiled 515 to 261 computations (49.3% saved)

Profiling

Loading profile data...