Details

Time bar (total: 21.6s)

analyze465.0ms (2.2%)

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
16.4%83.5%0.1%10
19.1%80.7%0.1%11
20.5%79.4%0.1%12
Compiler

Compiled 13 to 9 computations (30.8% saved)

sample3.7s (17.2%)

Results
2.3s3668×body1024valid
704.0ms2918×body256valid
520.0ms1475×body512valid
199.0ms195×body2048valid
0.0msbody1024invalid
0.0msbody256invalid

preprocess15.0ms (0.1%)

Algorithm
egg-herbie
Rules
12×*-commutative_binary64
associate-/l*_binary64
associate-*r/_binary64
associate-*l/_binary64
associate-/r/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02356
13956
25556
36956
47356
033
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
2
Call 2
Inputs
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(*.f64 a (/.f64 (sin.f64 b) (cos.f64 (+.f64 r b))))
(*.f64 b (/.f64 (sin.f64 r) (cos.f64 (+.f64 a r))))
(*.f64 r (/.f64 (sin.f64 a) (cos.f64 (+.f64 b a))))
Outputs
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 a (/.f64 (sin.f64 b) (cos.f64 (+.f64 r b))))
(*.f64 (sin.f64 b) (/.f64 a (cos.f64 (+.f64 r b))))
(*.f64 b (/.f64 (sin.f64 r) (cos.f64 (+.f64 a r))))
(*.f64 b (/.f64 (sin.f64 r) (cos.f64 (+.f64 r a))))
(/.f64 (sin.f64 r) (/.f64 (cos.f64 (+.f64 r a)) b))
(*.f64 r (/.f64 (sin.f64 a) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 r (sin.f64 a)) (cos.f64 (+.f64 b a)))
Compiler

Compiled 15 to 11 computations (26.7% saved)

simplify6.0ms (0%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-/l*_binary64
+-commutative_binary64
associate-*r/_binary64
associate-*l/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0914
11314
21714
32114
42214
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
Outputs
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))

eval1.0ms (0%)

Compiler

Compiled 21 to 12 computations (42.9% saved)

prune3.0ms (0%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
17.6b
Counts
3 → 1
Alt Table
Click to see full alt table
StatusErrorProgram
17.6b
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
Compiler

Compiled 12 to 8 computations (33.3% saved)

localize12.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
0.2b
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
2.9b
(cos.f64 (+.f64 b a))
Compiler

Compiled 31 to 8 computations (74.2% saved)

series18.0ms (0.1%)

Counts
3 → 84
Calls

21 calls:

TimeVariablePointExpression
2.0ms
a
@inf
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
1.0ms
r
@0
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
1.0ms
a
@-inf
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
1.0ms
b
@0
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
1.0ms
b
@0
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))

rewrite82.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
583×prod-diff_binary64
538×log-prod_binary64
345×pow-prod-down_binary64
288×pow2_binary64
214×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0931
120031
2287631
Stop Event
node limit
Counts
3 → 133
Calls
Call 1
Inputs
(cos.f64 (+.f64 b a))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 (exp.f64 (log1p.f64 (+.f64 b a)))) (cos.f64 1)) (*.f64 (sin.f64 (exp.f64 (log1p.f64 (+.f64 b a)))) (sin.f64 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 (/.f64 (*.f64 b b) (-.f64 b a))) (cos.f64 (/.f64 (*.f64 a a) (-.f64 b a)))) (*.f64 (sin.f64 (/.f64 (*.f64 b b) (-.f64 b a))) (sin.f64 (/.f64 (*.f64 a a) (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (cos.f64 (+.f64 b a)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (cos.f64 (+.f64 b a))))) (log.f64 (sqrt.f64 (exp.f64 (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (cos.f64 (+.f64 b a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cos.f64 (+.f64 b a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3)) (+.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (+.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2) (*.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2)) (cos.f64 (-.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cos.f64 (+.f64 b a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 (+.f64 b a)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cos.f64 (+.f64 b a))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 (+.f64 b a)) 1 (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (cbrt.f64 (cos.f64 (+.f64 b a))) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (sqrt.f64 (cos.f64 (+.f64 b a))) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 a) (cos.f64 b) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (sin.f64 b)) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) -2) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cos.f64 (+.f64 b a)) -1/2) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (sin.f64 b) r)) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) 1) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (sin.f64 b)) r) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 (sin.f64 b))) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 1))))))

simplify64.0ms (0.3%)

Algorithm
egg-herbie
Rules
904×fma-def_binary64
521×times-frac_binary64
471×associate-/l*_binary64
437×associate-*l/_binary64
359×associate-*r/_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01781827
15851745
221051658
Stop Event
node limit
Counts
217 → 187
Calls
Call 1
Inputs
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 b)
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (cos.f64 b))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 b r) (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
Outputs
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) b)))
(-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (fma.f64 -1 (*.f64 (sin.f64 a) b) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)))))
(+.f64 (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b)) (*.f64 (cos.f64 a) (*.f64 (*.f64 b b) -1/2)))
(+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(+.f64 (cos.f64 a) (fma.f64 -1 (*.f64 (sin.f64 a) b) (fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b))))))
(+.f64 (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b)) (fma.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)) (*.f64 (pow.f64 b 3) (*.f64 (sin.f64 a) 1/6))))
(+.f64 (*.f64 (sin.f64 a) (+.f64 (neg.f64 b) (*.f64 1/6 (pow.f64 b 3)))) (fma.f64 (cos.f64 a) (*.f64 (*.f64 b b) -1/2) (cos.f64 a)))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (+.f64 a b))
(cos.f64 b)
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (cos.f64 b))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (cos.f64 b))
(-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b)))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b)))
(-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))
(-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b))))
(-.f64 (fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b))) (*.f64 a (sin.f64 b)))
(fma.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b) (*.f64 (sin.f64 b) (+.f64 (neg.f64 a) (*.f64 1/6 (pow.f64 a 3)))))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a b))
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)))
(fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b))))
(fma.f64 (pow.f64 b 3) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (fma.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (neg.f64 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))))) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3)))))))))
(-.f64 (fma.f64 (pow.f64 b 3) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a)))) (*.f64 (pow.f64 b 4) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3 (*.f64 (/.f64 (neg.f64 (sin.f64 a)) (cos.f64 a)) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a (/.f64 (sin.f64 b) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))) (*.f64 (*.f64 a a) (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)))))
(+.f64 (-.f64 (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))) (*.f64 (*.f64 a a) (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (fma.f64 (neg.f64 (pow.f64 a 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))) (fma.f64 (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) -1/3))) (neg.f64 (pow.f64 a 3)) (/.f64 (sin.f64 b) (cos.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 b (/.f64 (cos.f64 a) r))
(*.f64 (/.f64 b (cos.f64 a)) r)
(*.f64 (/.f64 r (cos.f64 a)) b)
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))))
(+.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (*.f64 b b) r)))
(fma.f64 (/.f64 b (cos.f64 a)) r (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (*.f64 (pow.f64 b 3) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (*.f64 b b) r)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 b (cos.f64 a)) r)))
(fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (fma.f64 (/.f64 b (cos.f64 a)) r (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (fma.f64 (pow.f64 b 3) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (neg.f64 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))) (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) r)) -1/3)))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (*.f64 b b) r)) (-.f64 (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 b (cos.f64 a)) r)) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) r) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(-.f64 (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (fma.f64 (/.f64 b (cos.f64 a)) r (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) r) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)))
(fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (*.f64 (/.f64 a (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2)) r))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (-.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r))))))
(fma.f64 (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r))) (*.f64 a (neg.f64 a)) (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (*.f64 (/.f64 a (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2)) r)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (*.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2)) -1/3))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (-.f64 (-.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r))))) (*.f64 (pow.f64 a 3) (fma.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) r) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r))))))))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r) (-.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (*.f64 a a) (+.f64 (*.f64 (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) -1/3)) r)) a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)

eval56.0ms (0.3%)

Compiler

Compiled 4478 to 1528 computations (65.9% saved)

prune81.0ms (0.4%)

Pruning

46 alts after pruning (46 fresh and 0 done)

PrunedKeptTotal
New14146187
Fresh000
Picked101
Done000
Total14246188
Error
0.1b
Counts
188 → 46
Alt Table
Click to see full alt table
StatusErrorProgram
18.3b
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
18.0b
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
28.8b
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
48.4b
(pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)
32.3b
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
1.0b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))
30.0b
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
35.5b
(*.f64 r (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a)))))
30.0b
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
31.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
21.3b
(*.f64 r (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
44.5b
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))
0.5b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (/.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3)) (+.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (+.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2) (*.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))))))
31.6b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
32.7b
(/.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))
30.0b
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
40.8b
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
25.0b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
31.7b
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
41.4b
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))
17.7b
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
33.2b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))
41.4b
(cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))
17.6b
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
17.7b
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
0.9b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
54.9b
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))
17.7b
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
25.1b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2))))))
31.5b
(*.f64 (/.f64 r (cos.f64 a)) b)
17.7b
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
31.5b
(/.f64 (*.f64 b r) (cos.f64 a))
30.6b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))))
44.2b
(sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))
17.7b
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
17.8b
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
29.5b
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
0.5b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2))))))
30.2b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
35.8b
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
18.3b
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
31.5b
(*.f64 r (/.f64 b (cos.f64 a)))
37.4b
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
Compiler

Compiled 2036 to 1182 computations (41.9% saved)

localize21.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (cos.f64 b) (cos.f64 a))
0.2b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
0.2b
(*.f64 (sin.f64 b) (sin.f64 a))
0.2b
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))
Compiler

Compiled 65 to 12 computations (81.5% saved)

series24.0ms (0.1%)

Counts
4 → 108
Calls

27 calls:

TimeVariablePointExpression
5.0ms
a
@inf
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
2.0ms
b
@inf
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))
2.0ms
r
@0
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
2.0ms
a
@inf
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))
1.0ms
b
@-inf
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))

rewrite82.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
794×log-prod_binary64
552×fma-def_binary64
285×fma-neg_binary64
273×expm1-udef_binary64
273×log1p-udef_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01365
129241
2421241
Stop Event
node limit
Counts
4 → 104
Calls
Call 1
Inputs
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))
(*.f64 (sin.f64 b) (sin.f64 a))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 (cos.f64 b) (cos.f64 a))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (sin.f64 b)) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (cos.f64 (-.f64 a b)) (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (*.f64 (cos.f64 (-.f64 a b)) (cos.f64 (+.f64 b a)))) (cos.f64 (-.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b))) (cbrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (cos.f64 (-.f64 a b)) 2) (/.f64 (cos.f64 (+.f64 b a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 2 (-.f64 (cos.f64 (-.f64 a b)) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (cos.f64 (-.f64 a b)) (cos.f64 (+.f64 b a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (cos.f64 (-.f64 a b)) (cos.f64 (+.f64 b a)))) -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (sin.f64 b) r)) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) 1) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (sin.f64 b)) r) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 (sin.f64 b))) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (cos.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))) (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (cos.f64 b) (cos.f64 a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 2 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (-.f64 a b)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (-.f64 a b))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (-.f64 a b)))) -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (cos.f64 b) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (cos.f64 b) (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (cos.f64 b) (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (cos.f64 b) (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 1))))))

simplify74.0ms (0.3%)

Algorithm
egg-herbie
Rules
497×times-frac_binary64
456×associate-/l*_binary64
447×associate-*l/_binary64
367×associate-*r/_binary64
303×distribute-rgt-in_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02022726
16582643
223762560
Stop Event
node limit
Counts
212 → 169
Calls
Call 1
Inputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(*.f64 (sin.f64 a) b)
(+.f64 (*.f64 -1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 (sin.f64 a) b))
(+.f64 (*.f64 -1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (+.f64 (*.f64 (sin.f64 a) b) (*.f64 1/120 (*.f64 (sin.f64 a) (pow.f64 b 5)))))
(+.f64 (*.f64 -1/5040 (*.f64 (sin.f64 a) (pow.f64 b 7))) (+.f64 (*.f64 -1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (+.f64 (*.f64 (sin.f64 a) b) (*.f64 1/120 (*.f64 (sin.f64 a) (pow.f64 b 5))))))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 b) a)
(+.f64 (*.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (*.f64 (sin.f64 b) a))
(+.f64 (*.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 1/120 (*.f64 (sin.f64 b) (pow.f64 a 5))) (*.f64 (sin.f64 b) a)))
(+.f64 (*.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1/5040 (*.f64 (sin.f64 b) (pow.f64 a 7))) (+.f64 (*.f64 1/120 (*.f64 (sin.f64 b) (pow.f64 a 5))) (*.f64 (sin.f64 b) a))))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 b r) (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))
(+.f64 (*.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4))) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (*.f64 -1/720 (*.f64 (cos.f64 a) (pow.f64 b 6))) (+.f64 (*.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4))) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(cos.f64 b)
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (cos.f64 b))) (cos.f64 b)))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 a 6) (cos.f64 b))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (cos.f64 b))) (cos.f64 b))))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
Outputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (fma.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (neg.f64 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))))) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3)))))))))
(-.f64 (+.f64 (/.f64 b (cos.f64 a)) (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b)))) (*.f64 (pow.f64 b 4) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3 (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (neg.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))))
(+.f64 (-.f64 (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (fma.f64 (neg.f64 (pow.f64 a 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))) (-.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 (pow.f64 a 3) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)))))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(*.f64 (sin.f64 a) b)
(*.f64 b (sin.f64 a))
(+.f64 (*.f64 -1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 (sin.f64 a) b))
(fma.f64 -1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (*.f64 b (sin.f64 a)))
(fma.f64 (*.f64 (sin.f64 a) -1/6) (pow.f64 b 3) (*.f64 b (sin.f64 a)))
(*.f64 (sin.f64 a) (+.f64 b (*.f64 (pow.f64 b 3) -1/6)))
(+.f64 (*.f64 -1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (+.f64 (*.f64 (sin.f64 a) b) (*.f64 1/120 (*.f64 (sin.f64 a) (pow.f64 b 5)))))
(fma.f64 -1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (fma.f64 (sin.f64 a) b (*.f64 1/120 (*.f64 (sin.f64 a) (pow.f64 b 5)))))
(fma.f64 (*.f64 (sin.f64 a) -1/6) (pow.f64 b 3) (fma.f64 b (sin.f64 a) (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 5) 1/120))))
(fma.f64 -1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (*.f64 (sin.f64 a) (+.f64 b (*.f64 1/120 (pow.f64 b 5)))))
(+.f64 (*.f64 -1/5040 (*.f64 (sin.f64 a) (pow.f64 b 7))) (+.f64 (*.f64 -1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (+.f64 (*.f64 (sin.f64 a) b) (*.f64 1/120 (*.f64 (sin.f64 a) (pow.f64 b 5))))))
(fma.f64 -1/5040 (*.f64 (sin.f64 a) (pow.f64 b 7)) (fma.f64 -1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (fma.f64 (sin.f64 a) b (*.f64 1/120 (*.f64 (sin.f64 a) (pow.f64 b 5))))))
(fma.f64 -1/5040 (*.f64 (sin.f64 a) (pow.f64 b 7)) (fma.f64 (*.f64 (sin.f64 a) -1/6) (pow.f64 b 3) (fma.f64 b (sin.f64 a) (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 5) 1/120)))))
(+.f64 (*.f64 (sin.f64 a) (+.f64 b (*.f64 1/120 (pow.f64 b 5)))) (*.f64 (sin.f64 a) (+.f64 (*.f64 (pow.f64 b 3) -1/6) (*.f64 (pow.f64 b 7) -1/5040))))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 b) a)
(*.f64 a (sin.f64 b))
(+.f64 (*.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (*.f64 (sin.f64 b) a))
(fma.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (*.f64 a (sin.f64 b)))
(fma.f64 a (sin.f64 b) (*.f64 (sin.f64 b) (*.f64 (pow.f64 a 3) -1/6)))
(*.f64 (sin.f64 b) (+.f64 a (*.f64 (pow.f64 a 3) -1/6)))
(+.f64 (*.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 1/120 (*.f64 (sin.f64 b) (pow.f64 a 5))) (*.f64 (sin.f64 b) a)))
(fma.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 1/120 (*.f64 (sin.f64 b) (pow.f64 a 5)) (*.f64 a (sin.f64 b))))
(fma.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 a (sin.f64 b) (*.f64 (sin.f64 b) (*.f64 (pow.f64 a 5) 1/120))))
(fma.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (*.f64 (sin.f64 b) (+.f64 a (*.f64 1/120 (pow.f64 a 5)))))
(+.f64 (*.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1/5040 (*.f64 (sin.f64 b) (pow.f64 a 7))) (+.f64 (*.f64 1/120 (*.f64 (sin.f64 b) (pow.f64 a 5))) (*.f64 (sin.f64 b) a))))
(fma.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 -1/5040 (*.f64 (sin.f64 b) (pow.f64 a 7)) (fma.f64 1/120 (*.f64 (sin.f64 b) (pow.f64 a 5)) (*.f64 a (sin.f64 b)))))
(fma.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 -1/5040 (*.f64 (sin.f64 b) (pow.f64 a 7)) (fma.f64 a (sin.f64 b) (*.f64 (sin.f64 b) (*.f64 (pow.f64 a 5) 1/120)))))
(+.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/6 (pow.f64 a 3)) (*.f64 1/120 (pow.f64 a 5)))) (*.f64 (sin.f64 b) (+.f64 a (*.f64 -1/5040 (pow.f64 a 7)))))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(*.f64 (sin.f64 a) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 b (/.f64 (cos.f64 a) r))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))))
(+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))) (/.f64 b (/.f64 (cos.f64 a) r))))
(+.f64 (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (/.f64 b (/.f64 (cos.f64 a) r))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (neg.f64 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))) (cos.f64 a)) (*.f64 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2)) -1/3)))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (-.f64 (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))) (/.f64 b (/.f64 (cos.f64 a) r))) (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (*.f64 (*.f64 (sin.f64 a) r) -1/3) (pow.f64 (cos.f64 a) 2)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))))))))
(-.f64 (+.f64 (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (/.f64 b (/.f64 (cos.f64 a) r)))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (*.f64 (sin.f64 a) -1/3) (pow.f64 (cos.f64 a) 2)) r) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r))))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)))
(+.f64 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (-.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)) r)))))
(+.f64 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r) (*.f64 (*.f64 a a) (neg.f64 (fma.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) r)) -1/3))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))
(+.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (-.f64 (-.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)) r)))) (*.f64 (pow.f64 a 3) (fma.f64 (/.f64 r (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)) r)))))))
(+.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (-.f64 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (*.f64 a a) (+.f64 (*.f64 (fma.f64 (*.f64 (/.f64 r (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r))))) a) (fma.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))
(+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b))))
(fma.f64 (*.f64 (cos.f64 a) -1/2) (*.f64 b b) (cos.f64 a))
(*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a))
(+.f64 (*.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4))) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(fma.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4)) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)))))
(fma.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4)) (fma.f64 (*.f64 (cos.f64 a) -1/2) (*.f64 b b) (cos.f64 a)))
(+.f64 (cos.f64 a) (*.f64 (cos.f64 a) (+.f64 (*.f64 1/24 (pow.f64 b 4)) (*.f64 -1/2 (*.f64 b b)))))
(+.f64 (*.f64 -1/720 (*.f64 (cos.f64 a) (pow.f64 b 6))) (+.f64 (*.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4))) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(fma.f64 -1/720 (*.f64 (cos.f64 a) (pow.f64 b 6)) (fma.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4)) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b))))))
(fma.f64 -1/720 (*.f64 (cos.f64 a) (pow.f64 b 6)) (fma.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4)) (fma.f64 (*.f64 (cos.f64 a) -1/2) (*.f64 b b) (cos.f64 a))))
(+.f64 (*.f64 (+.f64 (*.f64 1/24 (pow.f64 b 4)) 1) (cos.f64 a)) (*.f64 (cos.f64 a) (+.f64 (*.f64 (*.f64 b b) -1/2) (*.f64 (pow.f64 b 6) -1/720))))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(cos.f64 b)
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))
(fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b))
(*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (cos.f64 b))) (cos.f64 b)))
(fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (fma.f64 1/24 (*.f64 (cos.f64 b) (pow.f64 a 4)) (cos.f64 b)))
(+.f64 (cos.f64 b) (*.f64 (cos.f64 b) (+.f64 (*.f64 -1/2 (*.f64 a a)) (*.f64 1/24 (pow.f64 a 4)))))
(*.f64 (cos.f64 b) (+.f64 (*.f64 -1/2 (*.f64 a a)) (+.f64 (*.f64 1/24 (pow.f64 a 4)) 1)))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 a 6) (cos.f64 b))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (cos.f64 b))) (cos.f64 b))))
(fma.f64 -1/720 (*.f64 (cos.f64 b) (pow.f64 a 6)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (fma.f64 1/24 (*.f64 (cos.f64 b) (pow.f64 a 4)) (cos.f64 b))))
(+.f64 (fma.f64 1/24 (*.f64 (cos.f64 b) (pow.f64 a 4)) (cos.f64 b)) (*.f64 (cos.f64 b) (+.f64 (*.f64 -1/720 (pow.f64 a 6)) (*.f64 -1/2 (*.f64 a a)))))
(+.f64 (*.f64 (cos.f64 b) (+.f64 (*.f64 -1/720 (pow.f64 a 6)) (*.f64 (*.f64 a a) (+.f64 -1/2 (*.f64 1/24 (*.f64 a a)))))) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))
(*.f64 (cos.f64 a) (cos.f64 b))

localize8.0ms (0%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(*.f64 r (/.f64 b (cos.f64 a)))
0.2b
(/.f64 b (cos.f64 a))
Compiler

Compiled 18 to 6 computations (66.7% saved)

series11.0ms (0%)

Counts
2 → 40
Calls

15 calls:

TimeVariablePointExpression
1.0ms
a
@0
(*.f64 r (/.f64 b (cos.f64 a)))
1.0ms
r
@0
(*.f64 r (/.f64 b (cos.f64 a)))
1.0ms
b
@0
(*.f64 r (/.f64 b (cos.f64 a)))
1.0ms
a
@inf
(*.f64 r (/.f64 b (cos.f64 a)))
1.0ms
b
@inf
(/.f64 b (cos.f64 a))

rewrite58.0ms (0.3%)

Algorithm
batch-egg-rewrite
Rules
776×pow1_binary64
714×add-log-exp_binary64
714×log1p-expm1-u_binary64
714×expm1-log1p-u_binary64
697×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0715
114415
2189615
Stop Event
node limit
Counts
2 → 53
Calls
Call 1
Inputs
(/.f64 b (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 b (/.f64 1 (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 b (cos.f64 a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 b (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 b (cos.f64 a))) (pow.f64 (cbrt.f64 (/.f64 b (cos.f64 a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 b (cos.f64 a))) 2) (cbrt.f64 (/.f64 b (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 b) 2) (*.f64 (cbrt.f64 b) (/.f64 1 (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 b (cos.f64 a))) (sqrt.f64 (/.f64 b (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 b) (*.f64 (sqrt.f64 b) (/.f64 1 (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 b) (/.f64 1 (neg.f64 (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 a)) b)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 b) 2) 1) (/.f64 (cbrt.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 b) 1) (/.f64 (sqrt.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (/.f64 b (cbrt.f64 (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 b) 2) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (/.f64 b (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (/.f64 (sqrt.f64 b) (cbrt.f64 (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (cos.f64 a))) (/.f64 b (sqrt.f64 (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 b) 2) (sqrt.f64 (cos.f64 a))) (/.f64 (cbrt.f64 b) (sqrt.f64 (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 b (cos.f64 a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 b (cos.f64 a))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 b (cos.f64 a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 a) b) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 b (neg.f64 (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 b (cos.f64 a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 b (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 b 3) (pow.f64 (cos.f64 a) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 b (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 b (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 b (cos.f64 a))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 a) b))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 b r) (cos.f64 a))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 b r)) (neg.f64 (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 b r) 1) (cos.f64 a))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 b r) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 b) r) (neg.f64 (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 b)) (neg.f64 (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 b (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 b (cos.f64 a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))))))

simplify50.0ms (0.2%)

Algorithm
egg-herbie
Rules
692×distribute-rgt-in_binary64
579×fma-def_binary64
541×distribute-lft-neg-in_binary64
538×distribute-rgt-neg-in_binary64
448×associate-*l*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
061511
1212472
2862452
34256442
Stop Event
node limit
Counts
93 → 70
Calls
Call 1
Inputs
b
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) b)) b)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 1/24 b) (*.f64 -1/4 b)))) b))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 1/24 b) (*.f64 -1/4 b)))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 6) (+.f64 (*.f64 1/48 b) (+.f64 (*.f64 1/2 (+.f64 (*.f64 1/24 b) (*.f64 -1/4 b))) (*.f64 -1/720 b))))) b)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r b)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) (*.f64 r b))) (*.f64 r b))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) (*.f64 r b))) (+.f64 (*.f64 r b) (*.f64 -1 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 -1/4 (*.f64 b r)) (*.f64 1/24 (*.f64 r b)))))))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) (*.f64 r b))) (+.f64 (*.f64 r b) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 6) (+.f64 (*.f64 1/2 (+.f64 (*.f64 -1/4 (*.f64 b r)) (*.f64 1/24 (*.f64 r b)))) (+.f64 (*.f64 -1/720 (*.f64 r b)) (*.f64 1/48 (*.f64 b r)))))) (*.f64 -1 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 -1/4 (*.f64 b r)) (*.f64 1/24 (*.f64 r b))))))))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
Outputs
b
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) b)) b)
(fma.f64 1/2 (*.f64 b (*.f64 a a)) b)
(*.f64 b (fma.f64 1/2 (*.f64 a a) 1))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 1/24 b) (*.f64 -1/4 b)))) b))
(fma.f64 1/2 (*.f64 b (*.f64 a a)) (fma.f64 -1 (*.f64 (pow.f64 a 4) (*.f64 b -5/24)) b))
(fma.f64 1/2 (*.f64 b (*.f64 a a)) (-.f64 b (*.f64 b (*.f64 -5/24 (pow.f64 a 4)))))
(fma.f64 b (*.f64 1/2 (*.f64 a a)) (fma.f64 (pow.f64 a 4) (*.f64 b 5/24) b))
(*.f64 b (-.f64 (fma.f64 1/2 (*.f64 a a) 1) (*.f64 (pow.f64 a 4) -5/24)))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 1/24 b) (*.f64 -1/4 b)))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 6) (+.f64 (*.f64 1/48 b) (+.f64 (*.f64 1/2 (+.f64 (*.f64 1/24 b) (*.f64 -1/4 b))) (*.f64 -1/720 b))))) b)))
(fma.f64 1/2 (*.f64 b (*.f64 a a)) (fma.f64 -1 (*.f64 (pow.f64 a 4) (*.f64 b -5/24)) (fma.f64 -1 (*.f64 (pow.f64 a 6) (fma.f64 1/48 b (fma.f64 1/2 (*.f64 b -5/24) (*.f64 b -1/720)))) b)))
(fma.f64 1/2 (*.f64 b (*.f64 a a)) (-.f64 (-.f64 b (*.f64 (pow.f64 a 6) (fma.f64 b 1/48 (fma.f64 b -1/720 (*.f64 b -5/48))))) (*.f64 b (*.f64 -5/24 (pow.f64 a 4)))))
(-.f64 (fma.f64 b (*.f64 1/2 (*.f64 a a)) (fma.f64 (pow.f64 a 4) (*.f64 b 5/24) b)) (*.f64 (pow.f64 a 6) (fma.f64 b 1/48 (*.f64 b -19/180))))
(-.f64 (*.f64 b (-.f64 (fma.f64 1/2 (*.f64 a a) 1) (*.f64 (pow.f64 a 4) -5/24))) (*.f64 (pow.f64 a 6) (fma.f64 b -1/720 (*.f64 b -1/12))))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(*.f64 r b)
(*.f64 b r)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) (*.f64 r b))) (*.f64 r b))
(fma.f64 1/2 (*.f64 (*.f64 a a) (*.f64 b r)) (*.f64 b r))
(*.f64 (+.f64 (*.f64 1/2 (*.f64 a a)) 1) (*.f64 b r))
(*.f64 (*.f64 b r) (fma.f64 1/2 (*.f64 a a) 1))
(*.f64 b (*.f64 (fma.f64 1/2 (*.f64 a a) 1) r))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) (*.f64 r b))) (+.f64 (*.f64 r b) (*.f64 -1 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 -1/4 (*.f64 b r)) (*.f64 1/24 (*.f64 r b)))))))
(fma.f64 1/2 (*.f64 (*.f64 a a) (*.f64 b r)) (fma.f64 r b (neg.f64 (*.f64 (pow.f64 a 4) (fma.f64 -1/4 (*.f64 b r) (*.f64 1/24 (*.f64 b r)))))))
(-.f64 (*.f64 (+.f64 (*.f64 1/2 (*.f64 a a)) 1) (*.f64 b r)) (*.f64 (pow.f64 a 4) (*.f64 (*.f64 b r) -5/24)))
(fma.f64 (pow.f64 a 4) (*.f64 (*.f64 b r) 5/24) (*.f64 (*.f64 b r) (fma.f64 1/2 (*.f64 a a) 1)))
(*.f64 (*.f64 b r) (-.f64 (fma.f64 1/2 (*.f64 a a) 1) (*.f64 (pow.f64 a 4) -5/24)))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 a 2) (*.f64 r b))) (+.f64 (*.f64 r b) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 6) (+.f64 (*.f64 1/2 (+.f64 (*.f64 -1/4 (*.f64 b r)) (*.f64 1/24 (*.f64 r b)))) (+.f64 (*.f64 -1/720 (*.f64 r b)) (*.f64 1/48 (*.f64 b r)))))) (*.f64 -1 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 -1/4 (*.f64 b r)) (*.f64 1/24 (*.f64 r b))))))))
(fma.f64 1/2 (*.f64 (*.f64 a a) (*.f64 b r)) (fma.f64 r b (fma.f64 -1 (*.f64 (pow.f64 a 6) (fma.f64 1/2 (fma.f64 -1/4 (*.f64 b r) (*.f64 1/24 (*.f64 b r))) (fma.f64 -1/720 (*.f64 b r) (*.f64 1/48 (*.f64 b r))))) (neg.f64 (*.f64 (pow.f64 a 4) (fma.f64 -1/4 (*.f64 b r) (*.f64 1/24 (*.f64 b r))))))))
(fma.f64 1/2 (*.f64 a (*.f64 a (*.f64 b r))) (fma.f64 b r (neg.f64 (fma.f64 (pow.f64 a 6) (fma.f64 1/2 (*.f64 (*.f64 b r) -5/24) (*.f64 (*.f64 b r) 7/360)) (*.f64 (pow.f64 a 4) (*.f64 (*.f64 b r) -5/24))))))
(-.f64 (fma.f64 (pow.f64 a 4) (*.f64 (*.f64 b r) 5/24) (*.f64 (*.f64 b r) (fma.f64 1/2 (*.f64 a a) 1))) (*.f64 (pow.f64 a 6) (fma.f64 b (*.f64 1/48 r) (*.f64 (*.f64 b r) -19/180))))
(-.f64 (*.f64 (*.f64 b r) (-.f64 (fma.f64 1/2 (*.f64 a a) 1) (*.f64 (pow.f64 a 4) -5/24))) (*.f64 (pow.f64 a 6) (fma.f64 b (*.f64 1/48 r) (*.f64 (*.f64 b r) -19/180))))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))

localize16.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
0.2b
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
0.3b
(pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)
2.9b
(cos.f64 (+.f64 b a))
Compiler

Compiled 43 to 13 computations (69.8% saved)

series12.0ms (0.1%)

Counts
3 → 84
Calls

21 calls:

TimeVariablePointExpression
2.0ms
b
@-inf
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
1.0ms
b
@-inf
(pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)
1.0ms
b
@0
(pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)
1.0ms
b
@inf
(pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)
1.0ms
a
@inf
(pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)

rewrite70.0ms (0.3%)

Algorithm
batch-egg-rewrite
Rules
590×log-prod_binary64
583×prod-diff_binary64
326×pow2_binary64
226×pow1/3_binary64
221×expm1-udef_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01142
124036
2326036
Stop Event
node limit
Counts
3 → 106
Calls
Call 1
Inputs
(pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (cbrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (cbrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (sqrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (pow.f64 (/.f64 1 (sin.f64 b)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))) (neg.f64 (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -1 (neg.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (/.f64 (cos.f64 (+.f64 b a)) (cbrt.f64 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (sqrt.f64 (sin.f64 b)) (/.f64 (cos.f64 (+.f64 b a)) (sqrt.f64 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (sin.f64 b)) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (sqrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (sin.f64 b) 1) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (/.f64 1 (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 1 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 2)) (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (sin.f64 b)) (/.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cos.f64 (+.f64 b a)) (/.f64 1 (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (*.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (/.f64 1 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 2) (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (*.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (/.f64 1 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) (sqrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (cos.f64 (+.f64 b a))) (/.f64 1 (neg.f64 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sin.f64 b)) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) 1) (/.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 1) (/.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (sin.f64 b)) 2)) (/.f64 (cos.f64 (+.f64 b a)) (cbrt.f64 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)) (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)) (/.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (cbrt.f64 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (sin.f64 b))) (/.f64 (cos.f64 (+.f64 b a)) (sqrt.f64 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (sqrt.f64 (sin.f64 b))) (/.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (sqrt.f64 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (cos.f64 (+.f64 b a)) 3) (pow.f64 (sin.f64 b) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (cos.f64 (+.f64 b a)) (neg.f64 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (cos.f64 (+.f64 b a)) 3) (pow.f64 (sin.f64 b) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 1))))))

simplify67.0ms (0.3%)

Algorithm
egg-herbie
Rules
794×fma-def_binary64
590×times-frac_binary64
515×associate-/l*_binary64
472×associate-*l/_binary64
405×associate-*r/_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01801899
15701836
220941754
Stop Event
node limit
Counts
190 → 161
Calls
Call 1
Inputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/3 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/3 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (cos.f64 a))) (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 -1/6 (cos.f64 a)))) (pow.f64 (cos.f64 a) 3))))) (+.f64 (*.f64 (-.f64 (*.f64 1/3 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (cos.f64 a) b)
(+.f64 (*.f64 -1 (sin.f64 a)) (/.f64 (cos.f64 a) b))
(+.f64 (*.f64 b (-.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 -1/6 (cos.f64 a)))) (+.f64 (*.f64 -1 (sin.f64 a)) (/.f64 (cos.f64 a) b)))
(+.f64 (*.f64 (-.f64 (*.f64 1/24 (cos.f64 a)) (+.f64 (*.f64 -1/6 (-.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 -1/6 (cos.f64 a)))) (*.f64 1/120 (cos.f64 a)))) (pow.f64 b 3)) (+.f64 (*.f64 b (-.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 -1/6 (cos.f64 a)))) (+.f64 (*.f64 -1 (sin.f64 a)) (/.f64 (cos.f64 a) b))))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) (sin.f64 b))
(/.f64 (cos.f64 b) (sin.f64 b))
(+.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (*.f64 -1 a))
(+.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (+.f64 (*.f64 -1 a) (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 a 2) (cos.f64 b)) (sin.f64 b)))))
(+.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (+.f64 (*.f64 1/6 (pow.f64 a 3)) (+.f64 (*.f64 -1 a) (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 a 2) (cos.f64 b)) (sin.f64 b))))))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 b r) (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
Outputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)))
(fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/3 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/3 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b))))
(fma.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/3 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (cos.f64 a))) (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 -1/6 (cos.f64 a)))) (pow.f64 (cos.f64 a) 3))))) (+.f64 (*.f64 (-.f64 (*.f64 1/3 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (/.f64 1/3 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 3) (*.f64 (cos.f64 a) -1/3))))) (fma.f64 (-.f64 (/.f64 1/3 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(+.f64 (/.f64 b (cos.f64 a)) (-.f64 (fma.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 3)) (*.f64 (cos.f64 a) -1/3)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))
(fma.f64 (pow.f64 b 4) (neg.f64 (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (/.f64 -1/3 (cos.f64 a)) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (fma.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a (/.f64 (sin.f64 b) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)) (*.f64 a (*.f64 a (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))))
(+.f64 (-.f64 (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)) (*.f64 a (*.f64 a (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (fma.f64 (neg.f64 (pow.f64 a 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))) (fma.f64 (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3)) (neg.f64 (pow.f64 a 3)) (/.f64 (sin.f64 b) (cos.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (cos.f64 a) b)
(+.f64 (*.f64 -1 (sin.f64 a)) (/.f64 (cos.f64 a) b))
(fma.f64 -1 (sin.f64 a) (/.f64 (cos.f64 a) b))
(-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a))
(+.f64 (*.f64 b (-.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 -1/6 (cos.f64 a)))) (+.f64 (*.f64 -1 (sin.f64 a)) (/.f64 (cos.f64 a) b)))
(fma.f64 b (*.f64 (cos.f64 a) -1/3) (fma.f64 -1 (sin.f64 a) (/.f64 (cos.f64 a) b)))
(fma.f64 b (*.f64 (cos.f64 a) -1/3) (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)))
(-.f64 (fma.f64 b (*.f64 (cos.f64 a) -1/3) (/.f64 (cos.f64 a) b)) (sin.f64 a))
(+.f64 (*.f64 (-.f64 (*.f64 1/24 (cos.f64 a)) (+.f64 (*.f64 -1/6 (-.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 -1/6 (cos.f64 a)))) (*.f64 1/120 (cos.f64 a)))) (pow.f64 b 3)) (+.f64 (*.f64 b (-.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 -1/6 (cos.f64 a)))) (+.f64 (*.f64 -1 (sin.f64 a)) (/.f64 (cos.f64 a) b))))
(fma.f64 (-.f64 (*.f64 (cos.f64 a) 1/24) (fma.f64 -1/6 (*.f64 (cos.f64 a) -1/3) (*.f64 (cos.f64 a) 1/120))) (pow.f64 b 3) (fma.f64 b (*.f64 (cos.f64 a) -1/3) (fma.f64 -1 (sin.f64 a) (/.f64 (cos.f64 a) b))))
(fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (cos.f64 a) 1/24) (fma.f64 (cos.f64 a) 1/120 (*.f64 (cos.f64 a) 1/18))) (fma.f64 b (*.f64 (cos.f64 a) -1/3) (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a))))
(fma.f64 (pow.f64 b 3) (+.f64 (*.f64 (cos.f64 a) -1/72) (*.f64 (cos.f64 a) -1/120)) (-.f64 (fma.f64 b (*.f64 (cos.f64 a) -1/3) (/.f64 (cos.f64 a) b)) (sin.f64 a)))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 b) (sin.f64 b))
(+.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (*.f64 -1 a))
(+.f64 (neg.f64 a) (/.f64 (cos.f64 b) (sin.f64 b)))
(-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a)
(+.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (+.f64 (*.f64 -1 a) (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 a 2) (cos.f64 b)) (sin.f64 b)))))
(+.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (fma.f64 -1 a (*.f64 -1/2 (/.f64 (*.f64 a a) (/.f64 (sin.f64 b) (cos.f64 b))))))
(+.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) (/.f64 -1/2 (/.f64 (sin.f64 b) (*.f64 (cos.f64 b) (*.f64 a a)))))
(fma.f64 -1/2 (*.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (*.f64 a a)) (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a))
(+.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (+.f64 (*.f64 1/6 (pow.f64 a 3)) (+.f64 (*.f64 -1 a) (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 a 2) (cos.f64 b)) (sin.f64 b))))))
(+.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (fma.f64 1/6 (pow.f64 a 3) (fma.f64 -1 a (*.f64 -1/2 (/.f64 (*.f64 a a) (/.f64 (sin.f64 b) (cos.f64 b)))))))
(+.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (fma.f64 (pow.f64 a 3) 1/6 (-.f64 (/.f64 -1/2 (/.f64 (sin.f64 b) (*.f64 (cos.f64 b) (*.f64 a a)))) a)))
(fma.f64 (pow.f64 a 3) 1/6 (fma.f64 -1/2 (*.f64 (/.f64 (cos.f64 b) (sin.f64 b)) (*.f64 a a)) (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a)))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 a b)) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) (sin.f64 b))
(/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 b (cos.f64 a)) r)
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))))
(+.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))))
(fma.f64 (/.f64 b (cos.f64 a)) r (*.f64 (/.f64 (*.f64 b (*.f64 b r)) (pow.f64 (cos.f64 a) 2)) (sin.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))) (+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 b (cos.f64 a)) r)))
(fma.f64 (/.f64 b (cos.f64 a)) r (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 r (pow.f64 (cos.f64 a) 3)) (pow.f64 (sin.f64 a) 2))) (*.f64 (/.f64 (*.f64 b (*.f64 b r)) (pow.f64 (cos.f64 a) 2)) (sin.f64 a))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))) (+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (neg.f64 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))) (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) r)) -1/3)))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (-.f64 (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 b (cos.f64 a)) r)) (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (*.f64 (sin.f64 a) -1/3) (/.f64 (pow.f64 (cos.f64 a) 2) r)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(-.f64 (fma.f64 (/.f64 b (cos.f64 a)) r (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 r (pow.f64 (cos.f64 a) 3)) (pow.f64 (sin.f64 a) 2))) (*.f64 (/.f64 (*.f64 b (*.f64 b r)) (pow.f64 (cos.f64 a) 2)) (sin.f64 a)))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (*.f64 -1/3 (sin.f64 a)) (pow.f64 (cos.f64 a) 2)) r) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 r (pow.f64 (cos.f64 a) 3)) (pow.f64 (sin.f64 a) 2)))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r) (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (*.f64 a (*.f64 a (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)))))))
(fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (fma.f64 (fma.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r))) (*.f64 a (neg.f64 a)) (*.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a) r)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) r)) -1/3))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (-.f64 (-.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 a (*.f64 a (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)))))) (*.f64 (pow.f64 a 3) (fma.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r))))))))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r) (-.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (*.f64 a a) (+.f64 (*.f64 a (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r))) (/.f64 (*.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) -1/3) (pow.f64 (cos.f64 b) 2)))) (fma.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 r (cos.f64 (+.f64 b a))) (sin.f64 b))

localize21.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
0.2b
(/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)))
0.4b
(pow.f64 (cos.f64 (+.f64 b a)) 2)
2.9b
(cos.f64 (+.f64 b a))
Compiler

Compiled 51 to 21 computations (58.8% saved)

series8.0ms (0%)

Counts
3 → 84
Calls

21 calls:

TimeVariablePointExpression
1.0ms
b
@0
(pow.f64 (cos.f64 (+.f64 b a)) 2)
1.0ms
a
@0
(pow.f64 (cos.f64 (+.f64 b a)) 2)
1.0ms
b
@-inf
(pow.f64 (cos.f64 (+.f64 b a)) 2)
1.0ms
a
@-inf
(pow.f64 (cos.f64 (+.f64 b a)) 2)
1.0ms
a
@inf
(pow.f64 (cos.f64 (+.f64 b a)) 2)

rewrite67.0ms (0.3%)

Algorithm
batch-egg-rewrite
Rules
596×log-prod_binary64
589×prod-diff_binary64
326×pow2_binary64
231×fma-def_binary64
228×pow1/3_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01234
126534
2331234
Stop Event
node limit
Counts
3 → 93
Calls
Call 1
Inputs
(pow.f64 (cos.f64 (+.f64 b a)) 2)
(/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (pow.f64 (cos.f64 (+.f64 b a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))) 2)) (log.f64 (cbrt.f64 (exp.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)))) (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (cos.f64 (+.f64 b a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (*.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 4)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (*.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 3) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cos.f64 (+.f64 b a)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (cos.f64 (*.f64 2 (+.f64 b a))) (cos.f64 (-.f64 (+.f64 b a) (+.f64 b a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 2 (log.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (log.f64 (cos.f64 (+.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (sin.f64 b)) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (sin.f64 b) r)) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) 1) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (sin.f64 b)) r) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 (sin.f64 b))) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 1))))))

simplify60.0ms (0.3%)

Algorithm
egg-herbie
Rules
525×times-frac_binary64
462×associate-/l*_binary64
449×associate-*l/_binary64
371×associate-*r/_binary64
327×distribute-rgt-in_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01901984
16331897
224141834
Stop Event
node limit
Counts
177 → 146
Calls
Call 1
Inputs
(pow.f64 (cos.f64 a) 2)
(+.f64 (pow.f64 (cos.f64 a) 2) (*.f64 -2 (*.f64 (sin.f64 a) (*.f64 (cos.f64 a) b))))
(+.f64 (pow.f64 (cos.f64 a) 2) (+.f64 (*.f64 -2 (*.f64 (sin.f64 a) (*.f64 (cos.f64 a) b))) (*.f64 (+.f64 (pow.f64 (sin.f64 a) 2) (*.f64 -1 (pow.f64 (cos.f64 a) 2))) (pow.f64 b 2))))
(+.f64 (pow.f64 (cos.f64 a) 2) (+.f64 (*.f64 (pow.f64 b 3) (+.f64 (*.f64 (sin.f64 a) (cos.f64 a)) (*.f64 1/3 (*.f64 (sin.f64 a) (cos.f64 a))))) (+.f64 (*.f64 -2 (*.f64 (sin.f64 a) (*.f64 (cos.f64 a) b))) (*.f64 (+.f64 (pow.f64 (sin.f64 a) 2) (*.f64 -1 (pow.f64 (cos.f64 a) 2))) (pow.f64 b 2)))))
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) 2)
(pow.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) 2)
(pow.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) 2)
(pow.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) 2)
(pow.f64 (cos.f64 b) 2)
(+.f64 (pow.f64 (cos.f64 b) 2) (*.f64 -2 (*.f64 (sin.f64 b) (*.f64 a (cos.f64 b)))))
(+.f64 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2))) (+.f64 (pow.f64 (cos.f64 b) 2) (*.f64 -2 (*.f64 (sin.f64 b) (*.f64 a (cos.f64 b))))))
(+.f64 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2))) (+.f64 (pow.f64 (cos.f64 b) 2) (+.f64 (*.f64 -2 (*.f64 (sin.f64 b) (*.f64 a (cos.f64 b)))) (*.f64 (pow.f64 a 3) (+.f64 (*.f64 (sin.f64 b) (cos.f64 b)) (*.f64 1/3 (*.f64 (sin.f64 b) (cos.f64 b))))))))
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) 2)
(pow.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) 2)
(pow.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) 2)
(pow.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) 2)
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 b r) (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
Outputs
(pow.f64 (cos.f64 a) 2)
(+.f64 (pow.f64 (cos.f64 a) 2) (*.f64 -2 (*.f64 (sin.f64 a) (*.f64 (cos.f64 a) b))))
(fma.f64 -2 (*.f64 (cos.f64 a) (*.f64 b (sin.f64 a))) (pow.f64 (cos.f64 a) 2))
(*.f64 (cos.f64 a) (+.f64 (*.f64 (*.f64 -2 (sin.f64 a)) b) (cos.f64 a)))
(+.f64 (pow.f64 (cos.f64 a) 2) (+.f64 (*.f64 -2 (*.f64 (sin.f64 a) (*.f64 (cos.f64 a) b))) (*.f64 (+.f64 (pow.f64 (sin.f64 a) 2) (*.f64 -1 (pow.f64 (cos.f64 a) 2))) (pow.f64 b 2))))
(+.f64 (pow.f64 (cos.f64 a) 2) (fma.f64 -2 (*.f64 (sin.f64 a) (*.f64 (cos.f64 a) b)) (*.f64 (+.f64 (pow.f64 (sin.f64 a) 2) (neg.f64 (pow.f64 (cos.f64 a) 2))) (*.f64 b b))))
(+.f64 (pow.f64 (cos.f64 a) 2) (fma.f64 -2 (*.f64 (cos.f64 a) (*.f64 b (sin.f64 a))) (*.f64 b (*.f64 b (-.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 2))))))
(+.f64 (*.f64 (cos.f64 a) (+.f64 (*.f64 (*.f64 -2 (sin.f64 a)) b) (cos.f64 a))) (*.f64 b (*.f64 b (-.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (pow.f64 (cos.f64 a) 2) (+.f64 (*.f64 (pow.f64 b 3) (+.f64 (*.f64 (sin.f64 a) (cos.f64 a)) (*.f64 1/3 (*.f64 (sin.f64 a) (cos.f64 a))))) (+.f64 (*.f64 -2 (*.f64 (sin.f64 a) (*.f64 (cos.f64 a) b))) (*.f64 (+.f64 (pow.f64 (sin.f64 a) 2) (*.f64 -1 (pow.f64 (cos.f64 a) 2))) (pow.f64 b 2)))))
(+.f64 (pow.f64 (cos.f64 a) 2) (fma.f64 (pow.f64 b 3) (*.f64 4/3 (*.f64 (cos.f64 a) (sin.f64 a))) (fma.f64 -2 (*.f64 (sin.f64 a) (*.f64 (cos.f64 a) b)) (*.f64 (+.f64 (pow.f64 (sin.f64 a) 2) (neg.f64 (pow.f64 (cos.f64 a) 2))) (*.f64 b b)))))
(+.f64 (pow.f64 (cos.f64 a) 2) (fma.f64 (pow.f64 b 3) (*.f64 (*.f64 (cos.f64 a) (sin.f64 a)) 4/3) (fma.f64 -2 (*.f64 (cos.f64 a) (*.f64 b (sin.f64 a))) (*.f64 b (*.f64 b (-.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 2)))))))
(+.f64 (pow.f64 (cos.f64 a) 2) (fma.f64 (pow.f64 b 3) (*.f64 (cos.f64 a) (*.f64 4/3 (sin.f64 a))) (*.f64 b (+.f64 (*.f64 -2 (*.f64 (cos.f64 a) (sin.f64 a))) (*.f64 (-.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 2)) b)))))
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (-.f64 a (*.f64 -1 b))) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 b) 2)
(+.f64 (pow.f64 (cos.f64 b) 2) (*.f64 -2 (*.f64 (sin.f64 b) (*.f64 a (cos.f64 b)))))
(fma.f64 -2 (*.f64 (cos.f64 b) (*.f64 a (sin.f64 b))) (pow.f64 (cos.f64 b) 2))
(*.f64 (cos.f64 b) (+.f64 (cos.f64 b) (*.f64 -2 (*.f64 a (sin.f64 b)))))
(+.f64 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2))) (+.f64 (pow.f64 (cos.f64 b) 2) (*.f64 -2 (*.f64 (sin.f64 b) (*.f64 a (cos.f64 b))))))
(fma.f64 (*.f64 a a) (fma.f64 -1 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2)) (+.f64 (pow.f64 (cos.f64 b) 2) (*.f64 -2 (*.f64 (sin.f64 b) (*.f64 a (cos.f64 b))))))
(fma.f64 (*.f64 a a) (-.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (fma.f64 -2 (*.f64 (cos.f64 b) (*.f64 a (sin.f64 b))) (pow.f64 (cos.f64 b) 2)))
(fma.f64 (*.f64 a a) (-.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (cos.f64 b) (+.f64 (cos.f64 b) (*.f64 -2 (*.f64 a (sin.f64 b))))))
(+.f64 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2))) (+.f64 (pow.f64 (cos.f64 b) 2) (+.f64 (*.f64 -2 (*.f64 (sin.f64 b) (*.f64 a (cos.f64 b)))) (*.f64 (pow.f64 a 3) (+.f64 (*.f64 (sin.f64 b) (cos.f64 b)) (*.f64 1/3 (*.f64 (sin.f64 b) (cos.f64 b))))))))
(fma.f64 (*.f64 a a) (fma.f64 -1 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2)) (+.f64 (pow.f64 (cos.f64 b) 2) (fma.f64 -2 (*.f64 (sin.f64 b) (*.f64 a (cos.f64 b))) (*.f64 (pow.f64 a 3) (*.f64 4/3 (*.f64 (cos.f64 b) (sin.f64 b)))))))
(fma.f64 (*.f64 a a) (-.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (fma.f64 (cos.f64 b) (cos.f64 b) (fma.f64 -2 (*.f64 (cos.f64 b) (*.f64 a (sin.f64 b))) (*.f64 (pow.f64 a 3) (*.f64 (*.f64 4/3 (sin.f64 b)) (cos.f64 b))))))
(+.f64 (*.f64 (cos.f64 b) (+.f64 (cos.f64 b) (*.f64 -2 (*.f64 a (sin.f64 b))))) (*.f64 (*.f64 a a) (+.f64 (*.f64 (*.f64 (cos.f64 b) (*.f64 4/3 (sin.f64 b))) a) (-.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)))))
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(pow.f64 (cos.f64 (-.f64 b (*.f64 -1 a))) 2)
(pow.f64 (cos.f64 (+.f64 a b)) 2)
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (*.f64 b b)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (/.f64 (*.f64 (sin.f64 a) (*.f64 b b)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (fma.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (neg.f64 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))))) (/.f64 (*.f64 (sin.f64 a) (*.f64 b b)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))))
(-.f64 (+.f64 (/.f64 b (cos.f64 a)) (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b)))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 (/.f64 a (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)))))
(-.f64 (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (pow.f64 a 3) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))) (*.f64 (pow.f64 a 3) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)))))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 b (cos.f64 a)) r)
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (/.f64 (*.f64 b (*.f64 b r)) (/.f64 (pow.f64 (cos.f64 a) 2) (sin.f64 a))))
(+.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b (*.f64 b r)))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 b (*.f64 b r)) (/.f64 (pow.f64 (cos.f64 a) 2) (sin.f64 a))) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r)) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 b (cos.f64 a)) r)))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b (*.f64 b r)))) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (*.f64 (/.f64 b (cos.f64 a)) r)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))) (neg.f64 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))) (*.f64 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2)) -1/3)))))))
(+.f64 (/.f64 (*.f64 b (*.f64 b r)) (/.f64 (pow.f64 (cos.f64 a) 2) (sin.f64 a))) (-.f64 (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r)) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 b (cos.f64 a)) r)) (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (*.f64 (sin.f64 a) -1/3) (/.f64 (pow.f64 (cos.f64 a) 2) r)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r)) (pow.f64 (cos.f64 a) 3))))))))
(-.f64 (+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b (*.f64 b r)))) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (*.f64 (/.f64 b (cos.f64 a)) r))) (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) r) -1/3)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))))
(+.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)))
(+.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (*.f64 (/.f64 a (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2)) r))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))
(+.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (-.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (*.f64 (*.f64 a a) (-.f64 (/.f64 (*.f64 (sin.f64 b) -1/2) (/.f64 (cos.f64 b) r)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))))))
(+.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r) (*.f64 (neg.f64 a) (*.f64 a (fma.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (cos.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) r)) -1/3))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))
(+.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (-.f64 (-.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (*.f64 a a) (-.f64 (/.f64 (*.f64 (sin.f64 b) -1/2) (/.f64 (cos.f64 b) r)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))))) (*.f64 (pow.f64 a 3) (fma.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (*.f64 (sin.f64 b) -1/2) (/.f64 (cos.f64 b) r)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))))))))
(+.f64 (*.f64 (*.f64 (/.f64 a (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2)) r) (-.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (*.f64 a a) (+.f64 (*.f64 a (fma.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) r) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))))) (fma.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))

localize23.0ms (0.1%)

Local error

Found 4 expressions with local error:

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

Compiled 64 to 12 computations (81.3% saved)

series30.0ms (0.1%)

Counts
4 → 108
Calls

27 calls:

TimeVariablePointExpression
13.0ms
a
@0
(*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a))
1.0ms
a
@-inf
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a))))
1.0ms
a
@inf
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a))))
1.0ms
r
@0
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
1.0ms
b
@inf
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a))))

rewrite118.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
653×log-prod_binary64
333×pow2_binary64
299×prod-diff_binary64
254×pow-unpow_binary64
236×pow1/3_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01377
126669
2349439
Stop Event
node limit
Counts
4 → 249
Calls
Call 1
Inputs
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a))))
(*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a))
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
(fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 0 (neg.f64 (cos.f64 (+.f64 b a)))) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) -2) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cos.f64 (+.f64 b a)) -1/2) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (cos.f64 (-.f64 a b)) (cos.f64 (+.f64 a b))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (sin.f64 a) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 (sin.f64 b) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (sin.f64 a) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 (sin.f64 b) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (sin.f64 b) r)) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) 1) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (*.f64 (cos.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (sin.f64 b) (sin.f64 a) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 -1 (*.f64 (sin.f64 b) (sin.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 1) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)) (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)) (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)) (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)) (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)) (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)) (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)) (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)) (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)) (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)) (*.f64 (cbrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))) (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))) (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))) (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))) (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))) (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))) (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))) (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))) (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))) (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 a))) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))) (*.f64 (sqrt.f64 (sin.f64 a)) (*.f64 (sin.f64 b) (sqrt.f64 (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (*.f64 (sqrt.f64 (cos.f64 b)) (sqrt.f64 (cos.f64 a))) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (cos.f64 (+.f64 b a)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (cos.f64 (+.f64 b a))))) (log.f64 (sqrt.f64 (exp.f64 (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (cos.f64 (+.f64 b a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cos.f64 (+.f64 b a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3)) (+.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (-.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2) (*.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2)) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cos.f64 (+.f64 b a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 (+.f64 b a)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (exp.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (exp.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (+.f64 1 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 (sin.f64 a)) (sin.f64 b)) (exp.f64 (*.f64 (cos.f64 b) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (exp.f64 (*.f64 (cos.f64 b) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (+.f64 1 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cos.f64 (+.f64 b a))))) (#(struct:change #<rule egg-rr> (2) ((x cos.f64 (-.f64 b a))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cos.f64 (+.f64 b a))) 1))))))

simplify84.0ms (0.4%)

Algorithm
egg-herbie
Rules
497×times-frac_binary64
452×associate-/l*_binary64
437×associate-*l/_binary64
359×associate-*r/_binary64
303×distribute-rgt-in_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01982979
16522833
223332734
Stop Event
node limit
Counts
357 → 317
Calls
Call 1
Inputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 -1 (*.f64 (sin.f64 a) b))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/120 (*.f64 (sin.f64 a) (pow.f64 b 5)))))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/5040 (*.f64 (sin.f64 a) (pow.f64 b 7))) (*.f64 -1/120 (*.f64 (sin.f64 a) (pow.f64 b 5))))))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 b) a))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (*.f64 -1 (*.f64 (sin.f64 b) a)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (*.f64 -1/120 (*.f64 (sin.f64 b) (pow.f64 a 5)))))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 -1/120 (*.f64 (sin.f64 b) (pow.f64 a 5))) (*.f64 1/5040 (*.f64 (sin.f64 b) (pow.f64 a 7))))))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 b r) (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(cos.f64 b)
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (cos.f64 b))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
Outputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 b b) (/.f64 (pow.f64 (cos.f64 a) 2) (sin.f64 a))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (/.f64 (*.f64 b b) (/.f64 (pow.f64 (cos.f64 a) 2) (sin.f64 a)))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (fma.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (neg.f64 (/.f64 (*.f64 (sin.f64 a) (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a)))))) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (-.f64 (/.f64 (*.f64 b b) (/.f64 (pow.f64 (cos.f64 a) 2) (sin.f64 a))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3)))))))))
(+.f64 (/.f64 b (cos.f64 a)) (-.f64 (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b))) (*.f64 (pow.f64 b 4) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3 (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (neg.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))) (*.f64 a (*.f64 a (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))))
(+.f64 (-.f64 (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))) (*.f64 a (*.f64 a (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (fma.f64 (neg.f64 (pow.f64 a 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))) (fma.f64 (neg.f64 (pow.f64 a 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)))) (/.f64 (sin.f64 b) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(*.f64 -1 (*.f64 (sin.f64 a) b))
(neg.f64 (*.f64 b (sin.f64 a)))
(*.f64 b (neg.f64 (sin.f64 a)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (neg.f64 (*.f64 b (sin.f64 a))))
(-.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 3) 1/6)) (*.f64 b (sin.f64 a)))
(*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/120 (*.f64 (sin.f64 a) (pow.f64 b 5)))))
(fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (fma.f64 -1 (*.f64 b (sin.f64 a)) (*.f64 -1/120 (*.f64 (sin.f64 a) (pow.f64 b 5)))))
(fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (-.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 5) -1/120)) (*.f64 b (sin.f64 a))))
(fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 5) -1/120) b)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/5040 (*.f64 (sin.f64 a) (pow.f64 b 7))) (*.f64 -1/120 (*.f64 (sin.f64 a) (pow.f64 b 5))))))
(fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (fma.f64 -1 (*.f64 b (sin.f64 a)) (fma.f64 1/5040 (*.f64 (sin.f64 a) (pow.f64 b 7)) (*.f64 -1/120 (*.f64 (sin.f64 a) (pow.f64 b 5))))))
(fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (-.f64 (fma.f64 -1/120 (*.f64 (sin.f64 a) (pow.f64 b 5)) (*.f64 (pow.f64 b 7) (*.f64 (sin.f64 a) 1/5040))) (*.f64 b (sin.f64 a))))
(+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (sin.f64 a) (+.f64 (*.f64 -1/120 (pow.f64 b 5)) (*.f64 1/5040 (pow.f64 b 7)))))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 b) a))
(neg.f64 (*.f64 a (sin.f64 b)))
(*.f64 (sin.f64 b) (neg.f64 a))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (*.f64 -1 (*.f64 (sin.f64 b) a)))
(fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (neg.f64 (*.f64 a (sin.f64 b))))
(fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (*.f64 (sin.f64 b) (neg.f64 a)))
(*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (*.f64 -1/120 (*.f64 (sin.f64 b) (pow.f64 a 5)))))
(fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 -1 (*.f64 a (sin.f64 b)) (*.f64 -1/120 (*.f64 (sin.f64 b) (pow.f64 a 5)))))
(fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (-.f64 (*.f64 (*.f64 -1/120 (pow.f64 a 5)) (sin.f64 b)) (*.f64 a (sin.f64 b))))
(fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (*.f64 (sin.f64 b) (-.f64 (*.f64 -1/120 (pow.f64 a 5)) a)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 -1/120 (*.f64 (sin.f64 b) (pow.f64 a 5))) (*.f64 1/5040 (*.f64 (sin.f64 b) (pow.f64 a 7))))))
(fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 -1 (*.f64 a (sin.f64 b)) (fma.f64 -1/120 (*.f64 (sin.f64 b) (pow.f64 a 5)) (*.f64 1/5040 (*.f64 (sin.f64 b) (pow.f64 a 7))))))
(fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (-.f64 (fma.f64 -1/120 (*.f64 (sin.f64 b) (pow.f64 a 5)) (*.f64 (pow.f64 a 7) (*.f64 (sin.f64 b) 1/5040))) (*.f64 a (sin.f64 b))))
(+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/120 (pow.f64 a 5)) (*.f64 1/5040 (pow.f64 a 7)))))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)))
(neg.f64 (*.f64 (sin.f64 a) (sin.f64 b)))
(*.f64 (sin.f64 a) (neg.f64 (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 b (/.f64 (cos.f64 a) r))
(*.f64 (/.f64 r (cos.f64 a)) b)
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (*.f64 (/.f64 r (cos.f64 a)) b) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))))
(+.f64 (*.f64 (/.f64 r (cos.f64 a)) b) (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 r (cos.f64 a)) b)))
(+.f64 (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (*.f64 (/.f64 r (cos.f64 a)) b)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (neg.f64 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))) (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) r)) -1/3)))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (-.f64 (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 r (cos.f64 a)) b)) (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (*.f64 (*.f64 (sin.f64 a) r) -1/3) (pow.f64 (cos.f64 a) 2)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))))))))
(-.f64 (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (*.f64 (/.f64 r (cos.f64 a)) b)) (-.f64 (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) r) -1/3)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r))))) (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r)))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))))
(+.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)))
(+.f64 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a) r))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))
(+.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (-.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)) (/.f64 r (/.f64 (pow.f64 (cos.f64 b) 3) (pow.f64 (sin.f64 b) 3)))))))
(+.f64 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (-.f64 (*.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a) r) (*.f64 a (*.f64 a (-.f64 (*.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) r))))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) r)) -1/3))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))
(+.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (-.f64 (-.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)) (/.f64 r (/.f64 (pow.f64 (cos.f64 b) 3) (pow.f64 (sin.f64 b) 3)))))) (*.f64 (pow.f64 a 3) (fma.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) r) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)) (/.f64 r (/.f64 (pow.f64 (cos.f64 b) 3) (pow.f64 (sin.f64 b) 3)))))))))
(+.f64 (*.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a) r) (-.f64 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (*.f64 a a) (+.f64 (*.f64 (fma.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) r) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) r)))) a) (-.f64 (*.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) r))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (cos.f64 a) (neg.f64 (*.f64 b (sin.f64 a))))
(-.f64 (cos.f64 a) (*.f64 b (sin.f64 a)))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (fma.f64 -1 (*.f64 b (sin.f64 a)) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)))))
(+.f64 (cos.f64 a) (fma.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)) (*.f64 b (neg.f64 (sin.f64 a)))))
(+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(+.f64 (cos.f64 a) (fma.f64 -1 (*.f64 b (sin.f64 a)) (fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b))))))
(+.f64 (-.f64 (cos.f64 a) (*.f64 b (sin.f64 a))) (fma.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)) (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 3) 1/6))))
(+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(cos.f64 b)
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (cos.f64 b))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (cos.f64 b))
(-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b)))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b)))
(-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b))))
(-.f64 (fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b))) (*.f64 a (sin.f64 b)))
(+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))

eval621.0ms (2.9%)

Compiler

Compiled 25819 to 8740 computations (66.1% saved)

prune344.0ms (1.6%)

Pruning

67 alts after pruning (64 fresh and 3 done)

PrunedKeptTotal
New970611031
Fresh38341
Picked011
Done224
Total1010671077
Error
0.0b
Counts
1077 → 67
Alt Table
Click to see full alt table
StatusErrorProgram
17.7b
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
41.5b
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
31.6b
(/.f64 b (/.f64 (cos.f64 a) r))
31.5b
(/.f64 (*.f64 r b) (cos.f64 a))
35.8b
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
0.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 3) (*.f64 (sin.f64 b) (sin.f64 a)))))
27.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
18.3b
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
29.6b
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
30.0b
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
30.0b
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
54.5b
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
18.3b
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
0.4b
(*.f64 r (pow.f64 (-.f64 (/.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (sin.f64 b)) (/.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (sin.f64 b))) -1))
17.5b
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
0.4b
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
23.7b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
32.0b
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
53.8b
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
30.9b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
51.6b
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
31.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
35.4b
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 a) 2))))
25.0b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
37.4b
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
1.8b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))) (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))))) (*.f64 (sin.f64 b) (sin.f64 a)))))
35.3b
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 b) 2))))
40.2b
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
53.5b
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
28.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
17.7b
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
44.0b
(*.f64 r b)
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (expm1.f64 (log1p.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
30.0b
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
31.5b
(*.f64 (/.f64 r (cos.f64 a)) b)
28.8b
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
30.0b
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3)))))
40.8b
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
26.6b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
45.8b
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
53.6b
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
18.2b
(*.f64 r (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 3) -1))
33.2b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))))
17.8b
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
31.7b
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
53.8b
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
31.5b
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
0.4b
(*.f64 r (pow.f64 (/.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))) (sin.f64 b)) -1))
36.4b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))
53.8b
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
17.6b
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
17.7b
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
31.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
31.6b
(/.f64 r (/.f64 (cos.f64 a) b))
0.5b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cbrt.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3)) (*.f64 (sin.f64 b) (sin.f64 a)))))
18.0b
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
30.5b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
17.7b
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
31.7b
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b (*.f64 b r)))) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (*.f64 (/.f64 b (cos.f64 a)) r)))
48.7b
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
31.5b
(*.f64 r (/.f64 b (cos.f64 a)))
0.6b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (log.f64 (+.f64 1 (expm1.f64 (*.f64 (cos.f64 b) (cos.f64 a))))) (*.f64 (sin.f64 b) (sin.f64 a)))))
28.7b
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
Compiler

Compiled 2215 to 1474 computations (33.5% saved)

localize24.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (cos.f64 b) (cos.f64 a))
0.2b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
0.2b
(*.f64 (sin.f64 b) (sin.f64 a))
0.2b
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))
Compiler

Compiled 84 to 14 computations (83.3% saved)

series7.0ms (0%)

Counts
2 → 60
Calls

15 calls:

TimeVariablePointExpression
2.0ms
b
@0
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
1.0ms
b
@0
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))
0.0ms
a
@0
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
0.0ms
a
@0
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))
0.0ms
b
@inf
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))

rewrite81.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
818×log-prod_binary64
438×fma-def_binary64
284×expm1-udef_binary64
284×log1p-udef_binary64
247×fma-neg_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01549
130525
2428825
Stop Event
node limit
Counts
2 → 65
Calls
Call 1
Inputs
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (sin.f64 b)) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (cos.f64 (-.f64 a b)) (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (*.f64 (cos.f64 (-.f64 a b)) (cos.f64 (+.f64 b a)))) (cos.f64 (-.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (sin.f64 b) r)) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) 1) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (sin.f64 b)) r) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 (sin.f64 b))) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 1))))))

simplify77.0ms (0.4%)

Algorithm
egg-herbie
Rules
680×fma-def_binary64
497×times-frac_binary64
450×associate-*l/_binary64
443×associate-/l*_binary64
371×associate-*r/_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01462104
14882029
218391955
Stop Event
node limit
Counts
125 → 99
Calls
Call 1
Inputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 b r) (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
Outputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(fma.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (fma.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (neg.f64 (/.f64 (*.f64 (sin.f64 a) (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a)))))) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (-.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3)))))))))
(-.f64 (fma.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a)))) (*.f64 (pow.f64 b 4) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3 (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (neg.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a (/.f64 (sin.f64 b) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))) (*.f64 a (*.f64 a (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))))
(+.f64 (-.f64 (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))) (*.f64 a (*.f64 a (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (fma.f64 (neg.f64 (pow.f64 a 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 (pow.f64 a 3) (neg.f64 (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) -1/3)))) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a)))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 b (/.f64 (cos.f64 a) r))
(*.f64 (/.f64 r (cos.f64 a)) b)
(*.f64 (/.f64 b (cos.f64 a)) r)
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (*.f64 (/.f64 r (cos.f64 a)) b) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))))
(fma.f64 (/.f64 b (cos.f64 a)) r (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 r (cos.f64 a)) b)))
(fma.f64 (/.f64 b (cos.f64 a)) r (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r)))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (neg.f64 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))) (*.f64 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2)) -1/3)))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (-.f64 (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 r (cos.f64 a)) b)) (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (*.f64 (*.f64 (sin.f64 a) r) -1/3) (pow.f64 (cos.f64 a) 2)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(-.f64 (fma.f64 (/.f64 b (cos.f64 a)) r (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))))) (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (*.f64 (sin.f64 a) r) (/.f64 (pow.f64 (cos.f64 a) 2) -1/3)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))))
(fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (/.f64 (*.f64 a r) (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)) r)))))
(fma.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (*.f64 (sin.f64 b) r)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) r)) (*.f64 a (neg.f64 a)) (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (/.f64 (*.f64 a r) (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) r)) -1/3))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (-.f64 (-.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)) r)))) (*.f64 (pow.f64 a 3) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) r)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)) r)))))))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r) (-.f64 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (*.f64 a a) (+.f64 (*.f64 a (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (*.f64 (sin.f64 b) r)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) r)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) -1/3)) r))) (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (*.f64 (sin.f64 b) r)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) r))))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))) r))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))

localize4.0ms (0%)

Compiler

Compiled 8 to 4 computations (50% saved)

localize15.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
0.2b
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
2.9b
(cos.f64 (+.f64 b a))
Compiler

Compiled 40 to 9 computations (77.5% saved)

series5.0ms (0%)

Counts
1 → 36
Calls

9 calls:

TimeVariablePointExpression
1.0ms
b
@0
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
1.0ms
a
@0
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
1.0ms
r
@0
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
1.0ms
b
@-inf
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
1.0ms
a
@inf
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))

rewrite54.0ms (0.3%)

Algorithm
batch-egg-rewrite
Rules
583×prod-diff_binary64
544×log-prod_binary64
287×pow2_binary64
222×fma-def_binary64
213×pow-unpow_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01016
122414
2323714
Stop Event
node limit
Counts
1 → 29
Calls
Call 1
Inputs
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 0 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (sin.f64 b)) r) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (sin.f64 b)) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 (sin.f64 b))) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 (sin.f64 b))) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))))))

simplify65.0ms (0.3%)

Algorithm
egg-herbie
Rules
416×associate-*r*_binary64
405×times-frac_binary64
373×associate-*l*_binary64
336×associate-/l*_binary64
303×distribute-neg-frac_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01001024
1332981
21078937
36275926
Stop Event
node limit
Counts
65 → 49
Calls
Call 1
Inputs
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (*.f64 -1 (/.f64 (*.f64 r b) (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 r b) (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 r b) (cos.f64 a))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2))) (*.f64 (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4)))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))) (pow.f64 a 2)) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))) (pow.f64 a 2)) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))) (*.f64 (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))) (pow.f64 a 3)))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a)))))
Outputs
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 r b) (cos.f64 a)))
(neg.f64 (/.f64 r (/.f64 (cos.f64 a) b)))
(/.f64 (*.f64 (neg.f64 b) r) (cos.f64 a))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(+.f64 (*.f64 -1 (/.f64 (*.f64 r b) (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2))))
(*.f64 -1 (+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 r (*.f64 b b))))))
(-.f64 (/.f64 (*.f64 (neg.f64 b) r) (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))))
(neg.f64 (fma.f64 (/.f64 r (cos.f64 a)) b (*.f64 (*.f64 b (*.f64 b r)) (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 r b) (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)))))
(fma.f64 -1 (*.f64 (pow.f64 b 3) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))) (*.f64 -1 (+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 r (*.f64 b b)))))))
(-.f64 (-.f64 (/.f64 (*.f64 (neg.f64 b) r) (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r)))) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))
(neg.f64 (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 r (/.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (sin.f64 a) 2)))) (fma.f64 (/.f64 r (cos.f64 a)) b (*.f64 (*.f64 b (*.f64 b r)) (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 r b) (cos.f64 a))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2))) (*.f64 (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4)))))
(fma.f64 -1 (*.f64 (pow.f64 b 3) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))) (fma.f64 -1 (/.f64 r (/.f64 (cos.f64 a) b)) (fma.f64 -1 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 r (*.f64 b b)))) (*.f64 (fma.f64 1/6 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) r)) (fma.f64 -1 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))) (/.f64 (*.f64 -1/2 (*.f64 r (sin.f64 a))) (pow.f64 (cos.f64 a) 2)))) (pow.f64 b 4)))))
(-.f64 (-.f64 (fma.f64 (fma.f64 1/6 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) r) (-.f64 (/.f64 (*.f64 (*.f64 r -1/2) (sin.f64 a)) (pow.f64 (cos.f64 a) 2)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))) (pow.f64 b 4) (/.f64 (neg.f64 (*.f64 (sin.f64 a) (*.f64 b (*.f64 b r)))) (pow.f64 (cos.f64 a) 2))) (/.f64 (*.f64 b r) (cos.f64 a))) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))
(fma.f64 -1 (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 r (/.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (sin.f64 a) 2)))) (fma.f64 (/.f64 r (cos.f64 a)) b (*.f64 (*.f64 b (*.f64 b r)) (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))))) (*.f64 (-.f64 (*.f64 (*.f64 r (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) -1/3) (*.f64 (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 r (/.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (sin.f64 a) 2)))) (/.f64 (sin.f64 a) (cos.f64 a)))) (pow.f64 b 4)))
(-.f64 (*.f64 (-.f64 (*.f64 (*.f64 r (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) -1/3) (*.f64 (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 r (/.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (sin.f64 a) 2)))) (/.f64 (sin.f64 a) (cos.f64 a)))) (pow.f64 b 4)) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 r (/.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (sin.f64 a) 2)))) (fma.f64 (/.f64 r (cos.f64 a)) b (*.f64 (*.f64 b (*.f64 b r)) (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))
(/.f64 (neg.f64 (sin.f64 b)) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 b))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(fma.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 r a)) (pow.f64 (cos.f64 b) 2)) (neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))
(-.f64 (/.f64 (neg.f64 (sin.f64 b)) (/.f64 (cos.f64 b) r)) (/.f64 (*.f64 r (*.f64 a (pow.f64 (sin.f64 b) 2))) (pow.f64 (cos.f64 b) 2)))
(neg.f64 (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (*.f64 r a) (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)))))
(+.f64 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))) (pow.f64 a 2)) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(fma.f64 (fma.f64 -1 (/.f64 (*.f64 r (pow.f64 (sin.f64 b) 3)) (pow.f64 (cos.f64 b) 3)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))) (*.f64 a a) (fma.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 r a)) (pow.f64 (cos.f64 b) 2)) (neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))
(-.f64 (fma.f64 (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)) r)) (*.f64 a a) (/.f64 (neg.f64 (*.f64 r (*.f64 a (pow.f64 (sin.f64 b) 2)))) (pow.f64 (cos.f64 b) 2))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))
(-.f64 (*.f64 (fma.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (/.f64 (neg.f64 (pow.f64 (sin.f64 b) 3)) (pow.f64 (cos.f64 b) 3)) r)) (*.f64 a a)) (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (*.f64 r a) (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)))))
(-.f64 (*.f64 (fma.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (/.f64 (neg.f64 r) (pow.f64 (/.f64 (cos.f64 b) (sin.f64 b)) 3))) (*.f64 a a)) (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (*.f64 r a) (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)))))
(+.f64 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))) (pow.f64 a 2)) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))) (*.f64 (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))) (pow.f64 a 3)))))
(fma.f64 (fma.f64 -1 (/.f64 (*.f64 r (pow.f64 (sin.f64 b) 3)) (pow.f64 (cos.f64 b) 3)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))) (*.f64 a a) (fma.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 r a)) (pow.f64 (cos.f64 b) 2)) (fma.f64 -1 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1 (/.f64 (*.f64 r (pow.f64 (sin.f64 b) 3)) (pow.f64 (cos.f64 b) 3)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) r)) -1/3)) (pow.f64 a 3)))))
(fma.f64 (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)) r)) (*.f64 a a) (-.f64 (-.f64 (*.f64 (fma.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) r) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)) r)))) (pow.f64 a 3)) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (/.f64 (*.f64 r (*.f64 a (pow.f64 (sin.f64 b) 2))) (pow.f64 (cos.f64 b) 2))))
(fma.f64 a (*.f64 a (fma.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (/.f64 (neg.f64 (pow.f64 (sin.f64 b) 3)) (pow.f64 (cos.f64 b) 3)) r))) (-.f64 (*.f64 (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (/.f64 (neg.f64 (pow.f64 (sin.f64 b) 3)) (pow.f64 (cos.f64 b) 3)) r)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 r -1/3))) (pow.f64 a 3)) (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (*.f64 r a) (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))
(-.f64 (*.f64 (*.f64 a a) (+.f64 (*.f64 a (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (/.f64 (neg.f64 r) (pow.f64 (/.f64 (cos.f64 b) (sin.f64 b)) 3))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 r -1/3)))) (fma.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (/.f64 (neg.f64 r) (pow.f64 (/.f64 (cos.f64 b) (sin.f64 b)) 3))))) (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (*.f64 r a) (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 b a)) r)))
(neg.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) (neg.f64 r)) (cos.f64 (+.f64 b a)))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 (+.f64 b a))) r)

localize19.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
0.2b
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
2.9b
(cos.f64 (+.f64 b a))
2.9b
(log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
Compiler

Compiled 50 to 10 computations (80% saved)

series6.0ms (0%)

Counts
2 → 48
Calls

12 calls:

TimeVariablePointExpression
1.0ms
a
@0
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
1.0ms
b
@0
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
1.0ms
b
@0
(log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
0.0ms
a
@0
(log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
0.0ms
b
@inf
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))

rewrite84.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
583×prod-diff_binary64
579×unpow-prod-down_binary64
452×log-prod_binary64
252×pow2_binary64
216×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0924
118224
2251624
Stop Event
node limit
Counts
2 → 149
Calls
Call 1
Inputs
(log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 1/2 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (*.f64 1/2 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (*.f64 2 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 2 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (pow.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (sin.f64 b)) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (sin.f64 b)) (pow.f64 (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (pow.f64 (/.f64 1 (sin.f64 b)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 1/2 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) -2) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cos.f64 (+.f64 b a)) -1/2) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) 1) 1) (pow.f64 (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) 1) (pow.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) -2) 1) (pow.f64 (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) 1) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) 1) (pow.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cos.f64 (+.f64 b a)) -1/2) 1) (pow.f64 (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (sqrt.f64 (cos.f64 (+.f64 b a)))) 1) (pow.f64 (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)) 1/3) (pow.f64 (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2) (sin.f64 b)) 1/3) (cbrt.f64 (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2) (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)) 1/3) (cbrt.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1/3) (cbrt.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2) 3) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 2) -1) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) 1) -1) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (sin.f64 b)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 1) -1) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (sin.f64 b)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) -2) -1) (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (cbrt.f64 (sin.f64 b))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)) -1) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (cbrt.f64 (sin.f64 b))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)) -1) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (cbrt.f64 (sin.f64 b))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (sin.f64 b) -1/2) -1) (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sqrt.f64 (sin.f64 b))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (sqrt.f64 (sin.f64 b))) -1) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (sqrt.f64 (sin.f64 b))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (sqrt.f64 (sin.f64 b))) -1) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (sqrt.f64 (sin.f64 b))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (/.f64 (cos.f64 (+.f64 b a)) (cbrt.f64 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (sqrt.f64 (sin.f64 b)) (/.f64 (cos.f64 (+.f64 b a)) (sqrt.f64 (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (sin.f64 b)) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -1 (neg.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (neg.f64 (sin.f64 b))) (neg.f64 (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (sin.f64 b) 1) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) 2)) (log.f64 (cbrt.f64 (exp.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (log.f64 (sqrt.f64 (exp.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2) (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 (/.f64 1 (cos.f64 (+.f64 b a)))) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (exp.f64 (sin.f64 b))) 2) (/.f64 1 (cos.f64 (+.f64 b a)))) (pow.f64 (cbrt.f64 (exp.f64 (sin.f64 b))) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (exp.f64 (sin.f64 b))) (/.f64 1 (cos.f64 (+.f64 b a)))) (pow.f64 (sqrt.f64 (exp.f64 (sin.f64 b))) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)) 1/3) (pow.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2) (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) 1/3) (cbrt.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2) (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) 1/3) (cbrt.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) 2) 3) (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (exp.f64 1) (*.f64 1/2 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (pow.f64 (exp.f64 1) (*.f64 1/2 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (exp.f64 1) (*.f64 2 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (pow.f64 (exp.f64 1) (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (pow.f64 (exp.f64 1) (/.f64 (sin.f64 b) (neg.f64 (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 (exp.f64 1) (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (pow.f64 (exp.f64 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)) (*.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2)) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (*.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (exp.f64 (sin.f64 b))) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) 1) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (/.f64 1 (cos.f64 (+.f64 b a)))) 2)) (cbrt.f64 (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (sin.f64 b)) (sqrt.f64 (/.f64 1 (cos.f64 (+.f64 b a))))) (sqrt.f64 (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)) 1) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)) (cbrt.f64 (sin.f64 b))) (cbrt.f64 (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)) (cbrt.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2))) (cbrt.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)) (cbrt.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (cbrt.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)) (pow.f64 (cbrt.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (cbrt.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)) (sqrt.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (sqrt.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (cbrt.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (sqrt.f64 (sin.f64 b))) (sqrt.f64 (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (sqrt.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2))) (sqrt.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (sqrt.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (sqrt.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (/.f64 1 (cos.f64 (+.f64 b a)))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) 1)) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (/.f64 (sqrt.f64 (sin.f64 b)) 1)) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) -2)) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2))) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2))) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (pow.f64 (cos.f64 (+.f64 b a)) -1/2)) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (exp.f64 1) (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (sqrt.f64 (cos.f64 (+.f64 b a))))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))))

simplify69.0ms (0.3%)

Algorithm
egg-herbie
Rules
574×fma-def_binary64
503×times-frac_binary64
309×associate-*l/_binary64
308×associate-/l*_binary64
290×associate-+r+_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01361398
14411351
216511234
Stop Event
node limit
Counts
197 → 183
Calls
Call 1
Inputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
1
(+.f64 (/.f64 b (cos.f64 a)) 1)
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (+.f64 (*.f64 1/2 (/.f64 1 (pow.f64 (cos.f64 a) 2))) (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (pow.f64 b 2)) 1))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (+.f64 (*.f64 1/2 (/.f64 1 (pow.f64 (cos.f64 a) 2))) (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (pow.f64 b 2)) (+.f64 1 (*.f64 (-.f64 (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 3)) (+.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (*.f64 1/6 (/.f64 1 (pow.f64 (cos.f64 a) 3))))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))) (pow.f64 (cos.f64 b) 2)) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 (pow.f64 a 2) (*.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (+.f64 (*.f64 -1 (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (*.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 4) (pow.f64 (cos.f64 b) 4)))))) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(+.f64 (*.f64 (+.f64 (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 6) (pow.f64 (cos.f64 b) 6))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (pow.f64 (cos.f64 b) 2))) (*.f64 -1 (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)))))))) (*.f64 (pow.f64 a 3) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))) (+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 (pow.f64 a 2) (*.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (+.f64 (*.f64 -1 (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (*.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 4) (pow.f64 (cos.f64 b) 4)))))) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a)))))
Outputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(fma.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (fma.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (neg.f64 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))))) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (-.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3)))))))))
(-.f64 (fma.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a)))) (*.f64 (pow.f64 b 4) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3 (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (neg.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a (/.f64 (sin.f64 b) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)) (*.f64 a (*.f64 a (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))))
(fma.f64 (*.f64 a a) (fma.f64 1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))))
(+.f64 (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)) (*.f64 a (*.f64 a (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (fma.f64 (neg.f64 (pow.f64 a 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (sin.f64 b) (cos.f64 b))))
(fma.f64 (pow.f64 a 3) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) 1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)))) (fma.f64 (*.f64 a a) (fma.f64 1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a (/.f64 (sin.f64 b) (cos.f64 b)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))
1
(+.f64 (/.f64 b (cos.f64 a)) 1)
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (+.f64 (*.f64 1/2 (/.f64 1 (pow.f64 (cos.f64 a) 2))) (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (pow.f64 b 2)) 1))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (/.f64 1/2 (pow.f64 (cos.f64 a) 2))) (*.f64 b b) 1))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (/.f64 1/2 (pow.f64 (cos.f64 a) 2))) 1))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 b (*.f64 b (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (/.f64 1/2 (pow.f64 (cos.f64 a) 2)))) 1))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (+.f64 (*.f64 1/2 (/.f64 1 (pow.f64 (cos.f64 a) 2))) (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (pow.f64 b 2)) (+.f64 1 (*.f64 (-.f64 (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 3)) (+.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (*.f64 1/6 (/.f64 1 (pow.f64 (cos.f64 a) 3))))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (fma.f64 (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (/.f64 1/2 (pow.f64 (cos.f64 a) 2))) (*.f64 b b) 1) (*.f64 (pow.f64 b 3) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 3)) (-.f64 (+.f64 (/.f64 1/2 (cos.f64 a)) (/.f64 1/6 (pow.f64 (cos.f64 a) 3))) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (/.f64 1/2 (pow.f64 (cos.f64 a) 2))) (fma.f64 (pow.f64 b 3) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 3)) (+.f64 (/.f64 1/6 (pow.f64 (cos.f64 a) 3)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))))) 1)))
(+.f64 (fma.f64 (pow.f64 b 3) (+.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 3)) (/.f64 1/6 (pow.f64 (cos.f64 a) 3)))) 1) (fma.f64 b (*.f64 b (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (/.f64 1/2 (pow.f64 (cos.f64 a) 2)))) (/.f64 b (cos.f64 a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))) (pow.f64 (cos.f64 b) 2)) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))))
(+.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 (pow.f64 a 2) (*.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (+.f64 (*.f64 -1 (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (*.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 4) (pow.f64 (cos.f64 b) 4)))))) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))) (fma.f64 (*.f64 a a) (*.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (fma.f64 -1 (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))) (*.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 4) (pow.f64 (cos.f64 b) 4))))) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(+.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))) (fma.f64 (*.f64 a a) (*.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (-.f64 (*.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 4) (pow.f64 (cos.f64 b) 4))) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))) (*.f64 (+.f64 (*.f64 (*.f64 a a) (fma.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 4) (pow.f64 (cos.f64 b) 4)) (fma.f64 1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)))) 1) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(+.f64 (*.f64 (+.f64 (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 6) (pow.f64 (cos.f64 b) 6))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (pow.f64 (cos.f64 b) 2))) (*.f64 -1 (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)))))))) (*.f64 (pow.f64 a 3) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))) (+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 (pow.f64 a 2) (*.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (+.f64 (*.f64 -1 (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (*.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 4) (pow.f64 (cos.f64 b) 4)))))) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))))
(fma.f64 (fma.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 6) (pow.f64 (cos.f64 b) 6)) (fma.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (pow.f64 (cos.f64 b) 2)) (neg.f64 (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3))))) (*.f64 (pow.f64 a 3) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))) (+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))) (fma.f64 (*.f64 a a) (*.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (fma.f64 -1 (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))) (*.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 4) (pow.f64 (cos.f64 b) 4))))) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))))
(+.f64 (fma.f64 (*.f64 a a) (*.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (-.f64 (*.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 4) (pow.f64 (cos.f64 b) 4))) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))) (fma.f64 (-.f64 (fma.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 6) (pow.f64 (cos.f64 b) 6)) (/.f64 (neg.f64 (pow.f64 (sin.f64 b) 2)) (/.f64 (pow.f64 (cos.f64 b) 2) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (pow.f64 a 3) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))))
(fma.f64 (pow.f64 a 3) (*.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))) (-.f64 (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 6) (pow.f64 (cos.f64 b) 6))) (+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) -1/3)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) (+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (/.f64 (sin.f64 b) (cos.f64 b))))))) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))) (*.f64 (+.f64 (*.f64 (*.f64 a a) (fma.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 4) (pow.f64 (cos.f64 b) 4)) (fma.f64 1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)))) 1) (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b))))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a)))))
(exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))

localize54.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.4b
(/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a))))
2.9b
(*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))
4.1b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
7.1b
(+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))
Compiler

Compiled 137 to 78 computations (43.1% saved)

series44.0ms (0.2%)

Counts
4 → 108
Calls

27 calls:

TimeVariablePointExpression
18.0ms
a
@inf
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
2.0ms
r
@0
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
2.0ms
b
@inf
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
2.0ms
b
@-inf
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
2.0ms
a
@inf
(+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))

rewrite236.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
417×fma-neg_binary64
408×log1p-udef_binary64
407×expm1-udef_binary64
239×add-sqr-sqrt_binary64
231×pow1_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
022112
1480112
26301112
Stop Event
node limit
Counts
4 → 117
Calls
Call 1
Inputs
(+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (-.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) (/.f64 (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 2) (-.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) (pow.f64 (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 2) (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) (sqrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 3) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (*.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 2)) (/.f64 1 (-.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (*.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))))) (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 3) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (-.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 3) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 3)) (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (*.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 3) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 3)) (+.f64 (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 2) (-.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (*.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 2)) (-.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 3) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 3))) (neg.f64 (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (*.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 2))) (neg.f64 (-.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 2) (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2)) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (sin.f64 a) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 a) (fma.f64 -1/2 (*.f64 b b) 1) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))) 2) (cbrt.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sqrt.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))) (sqrt.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (*.f64 r (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (sin.f64 b)) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 r (sin.f64 b))) (neg.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 r (sin.f64 b)) 1) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 r (sin.f64 b)) (pow.f64 (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 2)) (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 r (sin.f64 b)) (sqrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) (sqrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (sin.f64 b)) r) (neg.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 (sin.f64 b))) (neg.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 (pow.f64 b 3) 1/6) (sin.f64 a)) (*.f64 (neg.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 3) 1/6)) (*.f64 (sin.f64 a) (neg.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 (pow.f64 (pow.f64 b 3) 3) 1/216 (neg.f64 (pow.f64 b 3))) (sin.f64 a)) (+.f64 (*.f64 (pow.f64 b 6) 1/36) (*.f64 b (fma.f64 (pow.f64 b 3) 1/6 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 (pow.f64 b 6) 1/36 (neg.f64 (*.f64 b b))) (sin.f64 a)) (fma.f64 (pow.f64 b 3) 1/6 b))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 a) (fma.f64 (pow.f64 (pow.f64 b 3) 3) 1/216 (neg.f64 (pow.f64 b 3)))) (+.f64 (*.f64 (pow.f64 b 6) 1/36) (*.f64 b (fma.f64 (pow.f64 b 3) 1/6 b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 a) (fma.f64 (pow.f64 b 6) 1/36 (neg.f64 (*.f64 b b)))) (fma.f64 (pow.f64 b 3) 1/6 b))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (sin.f64 a)) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) 2) (cbrt.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) (sqrt.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (sin.f64 b)) (/.f64 1 (neg.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 2)) (/.f64 (sin.f64 b) (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (pow.f64 (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) (/.f64 (sin.f64 b) (sqrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (sqrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 3) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 3))) (+.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (*.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (-.f64 (pow.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) 2) (pow.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) 2))) (-.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (neg.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))))) 1))))))

simplify143.0ms (0.7%)

Algorithm
egg-herbie
Rules
612×distribute-rgt-in_binary64
597×distribute-lft-in_binary64
318×fma-def_binary64
242×associate-*r*_binary64
210×*-commutative_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
03134880
110764619
242724431
Stop Event
node limit
Counts
225 → 213
Calls
Call 1
Inputs
(+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))
(+.f64 1 (+.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a) (*.f64 -1/2 (pow.f64 b 2))))
(+.f64 1 (+.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a) (+.f64 (*.f64 -1/2 (pow.f64 b 2)) (*.f64 -1/2 (*.f64 (pow.f64 a 2) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))))
(+.f64 1 (+.f64 (*.f64 -1/6 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 3))) (+.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a) (+.f64 (*.f64 -1/2 (pow.f64 b 2)) (*.f64 -1/2 (*.f64 (pow.f64 a 2) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))))))))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b)) (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b)) (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b)) (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b)) (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 b r) (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3))))
(+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))))
(+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -36 (/.f64 (*.f64 (sin.f64 b) r) (sin.f64 a))) (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (pow.f64 (sin.f64 a) 3)))) (pow.f64 b 5))) (+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4))))))
(+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -36 (/.f64 (*.f64 (sin.f64 b) r) (sin.f64 a))) (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (pow.f64 (sin.f64 a) 3)))) (pow.f64 b 5))) (+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (pow.f64 (sin.f64 a) 2))) (+.f64 (*.f64 3 (/.f64 (*.f64 (+.f64 (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (pow.f64 (sin.f64 a) 3))) (*.f64 -36 (/.f64 (*.f64 (sin.f64 b) r) (sin.f64 a)))) (cos.f64 a)) (sin.f64 a))) (*.f64 -108 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (pow.f64 (sin.f64 a) 2))))) (pow.f64 b 6))) (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))))))
(*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3))))
(+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))))
(+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 5)))) (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 5)))))))
(+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (pow.f64 (sin.f64 a) 2))) (+.f64 (*.f64 -3 (/.f64 (*.f64 (cos.f64 a) (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) r) (sin.f64 a))) (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (pow.f64 (sin.f64 a) 3))))) (sin.f64 a))) (*.f64 -108 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (pow.f64 (sin.f64 a) 2))))) (pow.f64 b 6))) (+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 5)))) (*.f64 36 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 5))))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) (*.f64 a r))) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3)))) (pow.f64 a 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) (*.f64 a r))) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3)))) (pow.f64 a 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) (*.f64 a r))) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (+.f64 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3))))) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (*.f64 -1/6 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))))))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a)
(+.f64 (*.f64 -1/6 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 3))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a))
(+.f64 (*.f64 1/120 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 5))) (+.f64 (*.f64 -1/6 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 3))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a)))
(+.f64 (*.f64 1/120 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 5))) (+.f64 (*.f64 -1/6 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 3))) (+.f64 (*.f64 -1/5040 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 7))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a))))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 -1 (*.f64 (sin.f64 a) b))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3))))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (*.f64 -1 (/.f64 (+.f64 (*.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a))) (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (pow.f64 (sin.f64 a) 3)))) (pow.f64 b 5)))))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (pow.f64 (sin.f64 a) 2))) (+.f64 (*.f64 3 (/.f64 (*.f64 (cos.f64 a) (+.f64 (*.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a))) (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (pow.f64 (sin.f64 a) 3))))) (sin.f64 a))) (*.f64 -108 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (pow.f64 (sin.f64 a) 2))))) (pow.f64 b 6))) (*.f64 -1 (/.f64 (+.f64 (*.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a))) (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (pow.f64 (sin.f64 a) 3)))) (pow.f64 b 5))))))
(*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3))))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 5)))) (*.f64 36 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 5)))))))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -3 (/.f64 (*.f64 (cos.f64 a) (+.f64 (*.f64 36 (/.f64 (sin.f64 b) (sin.f64 a))) (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (pow.f64 (sin.f64 a) 3))))) (sin.f64 a))) (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (pow.f64 (sin.f64 a) 2))) (*.f64 -108 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (pow.f64 (sin.f64 a) 2))))) (pow.f64 b 6))) (+.f64 (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 5)))) (*.f64 36 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 5))))))))
(/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) a)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3)))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) a)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3))))) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (*.f64 -1/6 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3)))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) a)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
Outputs
(+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))
(+.f64 1 (*.f64 -1/2 (*.f64 b b)))
(fma.f64 -1/2 (*.f64 b b) 1)
(+.f64 1 (+.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a) (*.f64 -1/2 (pow.f64 b 2))))
(+.f64 1 (fma.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) a (*.f64 -1/2 (*.f64 b b))))
(+.f64 1 (fma.f64 -1/2 (*.f64 b b) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a)))
(+.f64 (fma.f64 -1/2 (*.f64 b b) 1) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) a))
(+.f64 1 (+.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a) (+.f64 (*.f64 -1/2 (pow.f64 b 2)) (*.f64 -1/2 (*.f64 (pow.f64 a 2) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))))
(+.f64 1 (fma.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) a (*.f64 -1/2 (+.f64 (*.f64 b b) (*.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 a a))))))
(+.f64 1 (fma.f64 -1/2 (fma.f64 b b (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (*.f64 a a))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a)))
(+.f64 1 (fma.f64 -1/2 (fma.f64 b b (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (*.f64 a a))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) a)))
(+.f64 1 (+.f64 (*.f64 -1/6 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 3))) (+.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a) (+.f64 (*.f64 -1/2 (pow.f64 b 2)) (*.f64 -1/2 (*.f64 (pow.f64 a 2) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))))))))
(+.f64 1 (fma.f64 -1/6 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 a 3)) (fma.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) a (*.f64 -1/2 (+.f64 (*.f64 b b) (*.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 a a)))))))
(+.f64 1 (fma.f64 -1/6 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 3)) (fma.f64 -1/2 (fma.f64 b b (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (*.f64 a a))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a))))
(+.f64 1 (+.f64 (*.f64 -1/2 (fma.f64 b b (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (*.f64 a a)))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (+.f64 a (*.f64 -1/6 (pow.f64 a 3))))))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (cos.f64 a) (neg.f64 (*.f64 b (sin.f64 a))))
(-.f64 (cos.f64 a) (*.f64 b (sin.f64 a)))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (fma.f64 -1 (*.f64 b (sin.f64 a)) (*.f64 -1/2 (*.f64 (*.f64 b b) (cos.f64 a)))))
(+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)))
(-.f64 (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a)) (*.f64 b (sin.f64 a)))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)))
(*.f64 (*.f64 1/6 (sin.f64 a)) (pow.f64 b 3))
(*.f64 1/6 (*.f64 (pow.f64 b 3) (sin.f64 a)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))
(fma.f64 1/6 (*.f64 (pow.f64 b 3) (sin.f64 a)) (*.f64 -1/2 (*.f64 (*.f64 b b) (cos.f64 a))))
(fma.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 b b) (*.f64 1/6 (*.f64 (pow.f64 b 3) (sin.f64 a))))
(*.f64 (*.f64 b b) (+.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 (*.f64 1/6 (sin.f64 a)) b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(fma.f64 -1 (*.f64 b (sin.f64 a)) (fma.f64 1/6 (*.f64 (pow.f64 b 3) (sin.f64 a)) (*.f64 -1/2 (*.f64 (*.f64 b b) (cos.f64 a)))))
(+.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)) (*.f64 -1/2 (*.f64 b (*.f64 b (cos.f64 a)))))
(+.f64 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)) (*.f64 -1/2 (*.f64 (*.f64 b b) (cos.f64 a))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)))
(*.f64 (*.f64 1/6 (sin.f64 a)) (pow.f64 b 3))
(*.f64 1/6 (*.f64 (pow.f64 b 3) (sin.f64 a)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))
(fma.f64 1/6 (*.f64 (pow.f64 b 3) (sin.f64 a)) (*.f64 -1/2 (*.f64 (*.f64 b b) (cos.f64 a))))
(fma.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 b b) (*.f64 1/6 (*.f64 (pow.f64 b 3) (sin.f64 a))))
(*.f64 (*.f64 b b) (+.f64 (*.f64 -1/2 (cos.f64 a)) (*.f64 (*.f64 1/6 (sin.f64 a)) b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(fma.f64 -1 (*.f64 b (sin.f64 a)) (fma.f64 1/6 (*.f64 (pow.f64 b 3) (sin.f64 a)) (*.f64 -1/2 (*.f64 (*.f64 b b) (cos.f64 a)))))
(+.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)) (*.f64 -1/2 (*.f64 b (*.f64 b (cos.f64 a)))))
(+.f64 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)) (*.f64 -1/2 (*.f64 (*.f64 b b) (cos.f64 a))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))
(fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b)) (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b)) (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b)) (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b)) (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))))
(+.f64 (*.f64 (/.f64 r (cos.f64 a)) b) (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) r) (*.f64 b b))))
(+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r)))) (*.f64 (pow.f64 b 3) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) r) (*.f64 b b))) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 r (cos.f64 a)) b)))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (/.f64 r (/.f64 (cos.f64 a) b))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(+.f64 (+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r)))) (fma.f64 (pow.f64 b 3) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (neg.f64 (*.f64 (fma.f64 -1 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))) (*.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) r)) -1/3)) (pow.f64 b 4)))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) r) (*.f64 b b))) (-.f64 (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 r (cos.f64 a)) b)) (*.f64 (-.f64 (/.f64 (*.f64 (sin.f64 a) -1/3) (/.f64 (pow.f64 (cos.f64 a) 2) r)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (pow.f64 b 4))))
(-.f64 (+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (/.f64 r (/.f64 (cos.f64 a) b)))) (*.f64 (-.f64 (/.f64 (*.f64 (sin.f64 a) -1/3) (/.f64 (pow.f64 (cos.f64 a) 2) r)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)))) (pow.f64 b 4)))
(*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 6 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r (pow.f64 b 3))))
(*.f64 6 (*.f64 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) r))
(*.f64 (/.f64 6 (pow.f64 b 3)) (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)))
(+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))))
(fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r (pow.f64 b 3))) (*.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 a) r) (pow.f64 b 4)))))
(fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) r) (*.f64 18 (/.f64 (sin.f64 b) (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a)) (/.f64 (pow.f64 b 4) r)))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (/.f64 r (pow.f64 b 4))) (*.f64 (/.f64 6 (pow.f64 b 3)) (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r))))
(+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -36 (/.f64 (*.f64 (sin.f64 b) r) (sin.f64 a))) (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (pow.f64 (sin.f64 a) 3)))) (pow.f64 b 5))) (+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4))))))
(fma.f64 -1 (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)) (*.f64 -54 (/.f64 (*.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) r) (pow.f64 (sin.f64 a) 3)))) (pow.f64 b 5)) (fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r (pow.f64 b 3))) (*.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 a) r) (pow.f64 b 4))))))
(-.f64 (fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) r) (*.f64 18 (/.f64 (sin.f64 b) (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a)) (/.f64 (pow.f64 b 4) r))))) (/.f64 (fma.f64 -36 (/.f64 r (/.f64 (sin.f64 a) (sin.f64 b))) (*.f64 -54 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 r (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 5)))
(-.f64 (fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (/.f64 r (pow.f64 b 4))) (*.f64 (/.f64 6 (pow.f64 b 3)) (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)))) (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)) (/.f64 (*.f64 -54 (*.f64 r (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)))) (pow.f64 (sin.f64 a) 3))) (pow.f64 b 5)))
(+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -36 (/.f64 (*.f64 (sin.f64 b) r) (sin.f64 a))) (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (pow.f64 (sin.f64 a) 3)))) (pow.f64 b 5))) (+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (pow.f64 (sin.f64 a) 2))) (+.f64 (*.f64 3 (/.f64 (*.f64 (+.f64 (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (pow.f64 (sin.f64 a) 3))) (*.f64 -36 (/.f64 (*.f64 (sin.f64 b) r) (sin.f64 a)))) (cos.f64 a)) (sin.f64 a))) (*.f64 -108 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (pow.f64 (sin.f64 a) 2))))) (pow.f64 b 6))) (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))))))
(fma.f64 -1 (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)) (*.f64 -54 (/.f64 (*.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) r) (pow.f64 (sin.f64 a) 3)))) (pow.f64 b 5)) (fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r (pow.f64 b 3))) (fma.f64 -1 (/.f64 (fma.f64 36 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (*.f64 (cos.f64 a) r))) (fma.f64 3 (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)) (*.f64 -54 (/.f64 (*.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) r) (pow.f64 (sin.f64 a) 3)))) (/.f64 (sin.f64 a) (cos.f64 a))) (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (*.f64 (cos.f64 a) r))) -108))) (pow.f64 b 6)) (*.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 a) r) (pow.f64 b 4)))))))
(-.f64 (fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) r) (-.f64 (*.f64 18 (/.f64 (sin.f64 b) (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a)) (/.f64 (pow.f64 b 4) r)))) (/.f64 (fma.f64 36 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) r)) (fma.f64 3 (*.f64 (/.f64 (fma.f64 -36 (/.f64 r (/.f64 (sin.f64 a) (sin.f64 b))) (*.f64 -54 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 r (pow.f64 (cos.f64 a) 2))))) (sin.f64 a)) (cos.f64 a)) (/.f64 (*.f64 (*.f64 -108 (*.f64 (cos.f64 a) r)) (sin.f64 b)) (pow.f64 (sin.f64 a) 2)))) (pow.f64 b 6)))) (/.f64 (fma.f64 -36 (/.f64 r (/.f64 (sin.f64 a) (sin.f64 b))) (*.f64 -54 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 r (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 5)))
(-.f64 (-.f64 (fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (/.f64 r (pow.f64 b 4))) (*.f64 (/.f64 6 (pow.f64 b 3)) (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)))) (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)) (/.f64 (*.f64 -54 (*.f64 r (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)))) (pow.f64 (sin.f64 a) 3))) (pow.f64 b 5))) (/.f64 (+.f64 (*.f64 3 (*.f64 (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)) (/.f64 (*.f64 -54 (*.f64 r (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)))) (pow.f64 (sin.f64 a) 3))) (sin.f64 a)) (cos.f64 a))) (*.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) r)) -72)) (pow.f64 b 6)))
(*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 6 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r (pow.f64 b 3))))
(*.f64 6 (*.f64 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) r))
(*.f64 (/.f64 6 (pow.f64 b 3)) (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)))
(+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))))
(fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r (pow.f64 b 3))) (*.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 a) r) (pow.f64 b 4)))))
(fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) r) (*.f64 18 (/.f64 (sin.f64 b) (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a)) (/.f64 (pow.f64 b 4) r)))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (/.f64 r (pow.f64 b 4))) (*.f64 (/.f64 6 (pow.f64 b 3)) (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r))))
(+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 5)))) (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 5)))))))
(fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r (pow.f64 b 3))) (fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 a) r) (pow.f64 b 4))) (fma.f64 54 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (*.f64 r (pow.f64 (cos.f64 a) 2)) (pow.f64 b 5))) (*.f64 36 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r (pow.f64 b 5)))))))
(fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) r) (fma.f64 18 (/.f64 (sin.f64 b) (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a)) (/.f64 (pow.f64 b 4) r))) (fma.f64 36 (/.f64 (/.f64 r (/.f64 (sin.f64 a) (sin.f64 b))) (pow.f64 b 5)) (*.f64 (/.f64 54 (pow.f64 b 5)) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 r (pow.f64 (cos.f64 a) 2)))))))
(+.f64 (fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (/.f64 r (pow.f64 b 4))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 (/.f64 (*.f64 r (pow.f64 (cos.f64 a) 2)) (pow.f64 b 5)) 54))) (*.f64 (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)) (+.f64 (/.f64 36 (pow.f64 b 5)) (/.f64 6 (pow.f64 b 3)))))
(+.f64 (*.f64 6 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (pow.f64 (sin.f64 a) 2))) (+.f64 (*.f64 -3 (/.f64 (*.f64 (cos.f64 a) (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) r) (sin.f64 a))) (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (pow.f64 (sin.f64 a) 3))))) (sin.f64 a))) (*.f64 -108 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (pow.f64 (sin.f64 a) 2))))) (pow.f64 b 6))) (+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) r)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) r)) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 5)))) (*.f64 36 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) (pow.f64 b 5))))))))
(fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r (pow.f64 b 3))) (fma.f64 -1 (/.f64 (fma.f64 36 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (*.f64 (cos.f64 a) r))) (fma.f64 -3 (/.f64 (cos.f64 a) (/.f64 (sin.f64 a) (fma.f64 36 (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)) (*.f64 (/.f64 (*.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) r) (pow.f64 (sin.f64 a) 3)) 54)))) (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (*.f64 (cos.f64 a) r))) -108))) (pow.f64 b 6)) (fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 a) r) (pow.f64 b 4))) (fma.f64 54 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (*.f64 r (pow.f64 (cos.f64 a) 2)) (pow.f64 b 5))) (*.f64 36 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r (pow.f64 b 5))))))))
(fma.f64 6 (*.f64 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) r) (-.f64 (fma.f64 18 (/.f64 (sin.f64 b) (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a)) (/.f64 (pow.f64 b 4) r))) (fma.f64 36 (/.f64 (/.f64 r (/.f64 (sin.f64 a) (sin.f64 b))) (pow.f64 b 5)) (*.f64 (/.f64 54 (pow.f64 b 5)) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 r (pow.f64 (cos.f64 a) 2)))))) (/.f64 (fma.f64 36 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) r)) (fma.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) r)) -108 (*.f64 -3 (*.f64 (/.f64 (cos.f64 a) (sin.f64 a)) (fma.f64 (/.f64 r (/.f64 (sin.f64 a) (sin.f64 b))) 36 (/.f64 (*.f64 (*.f64 (sin.f64 b) (*.f64 r (pow.f64 (cos.f64 a) 2))) 54) (pow.f64 (sin.f64 a) 3))))))) (pow.f64 b 6))))
(-.f64 (+.f64 (fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (/.f64 r (pow.f64 b 4))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 (/.f64 (*.f64 r (pow.f64 (cos.f64 a) 2)) (pow.f64 b 5)) 54))) (*.f64 (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)) (+.f64 (/.f64 36 (pow.f64 b 5)) (/.f64 6 (pow.f64 b 3))))) (/.f64 (+.f64 (*.f64 -3 (*.f64 (/.f64 (cos.f64 a) (sin.f64 a)) (fma.f64 (/.f64 (sin.f64 b) (/.f64 (sin.f64 a) r)) 36 (/.f64 (*.f64 (*.f64 r (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2))) 54) (pow.f64 (sin.f64 a) 3))))) (*.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) r)) -72)) (pow.f64 b 6)))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (*.f64 b b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1/2 (*.f64 b b) 1))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 -1/2 (*.f64 b b) 1) r))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) (*.f64 a r))) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))))
(fma.f64 -1 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 2) (*.f64 (sin.f64 b) (*.f64 a r)))) (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (*.f64 b b)))))
(-.f64 (/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1/2 (*.f64 b b) 1)) (*.f64 (/.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (*.f64 (sin.f64 b) r))))
(-.f64 (/.f64 (sin.f64 b) (/.f64 (fma.f64 -1/2 (*.f64 b b) 1) r)) (*.f64 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (*.f64 (sin.f64 b) r))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3)))) (pow.f64 a 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) (*.f64 a r))) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (*.f64 b b)))) (neg.f64 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 3) (*.f64 (sin.f64 b) r)))))) (fma.f64 -1 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 2) (*.f64 (sin.f64 b) (*.f64 a r)))) (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (*.f64 b b))))))
(-.f64 (-.f64 (/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1/2 (*.f64 b b) 1)) (*.f64 (/.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (*.f64 (sin.f64 b) r)))) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1/2 (*.f64 b b) 1))) (/.f64 (*.f64 (sin.f64 b) r) (/.f64 (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 3) (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2))))))
(-.f64 (-.f64 (/.f64 (sin.f64 b) (/.f64 (fma.f64 -1/2 (*.f64 b b) 1) r)) (*.f64 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (*.f64 (sin.f64 b) r)))) (*.f64 (*.f64 a a) (*.f64 (/.f64 (sin.f64 b) (/.f64 (fma.f64 -1/2 (*.f64 b b) 1) r)) (-.f64 -1/2 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2))))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3)))) (pow.f64 a 2))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) (*.f64 a r))) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (+.f64 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3))))) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (*.f64 -1/6 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))))))))))
(fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (*.f64 b b)))) (neg.f64 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 3) (*.f64 (sin.f64 b) r)))))) (+.f64 (fma.f64 -1 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 2) (*.f64 (sin.f64 b) (*.f64 a r)))) (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (*.f64 b b))))) (neg.f64 (*.f64 (pow.f64 a 3) (fma.f64 -1 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (/.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (fma.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (+.f64 1 (*.f64 -1/2 (*.f64 b b)))) (neg.f64 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 3) (*.f64 (sin.f64 b) r))))))) (*.f64 (/.f64 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (*.f64 (sin.f64 b) r)) (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 2)) 1/3))))))
(-.f64 (-.f64 (-.f64 (/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1/2 (*.f64 b b) 1)) (*.f64 (/.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (*.f64 (sin.f64 b) r)))) (*.f64 (pow.f64 a 3) (-.f64 (/.f64 (*.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) r)) 1/3) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 (/.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (fma.f64 -1/2 (*.f64 b b) 1)) (-.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1/2 (*.f64 b b) 1))) (/.f64 (*.f64 (sin.f64 b) r) (/.f64 (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 3) (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2)))))))) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1/2 (*.f64 b b) 1))) (/.f64 (*.f64 (sin.f64 b) r) (/.f64 (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 3) (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2))))))
(-.f64 (-.f64 (-.f64 (/.f64 (sin.f64 b) (/.f64 (fma.f64 -1/2 (*.f64 b b) 1) r)) (*.f64 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (*.f64 (sin.f64 b) r)))) (*.f64 (*.f64 a a) (*.f64 (/.f64 (sin.f64 b) (/.f64 (fma.f64 -1/2 (*.f64 b b) 1) r)) (-.f64 -1/2 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)))))) (*.f64 (pow.f64 a 3) (-.f64 (*.f64 (*.f64 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 (sin.f64 b) r)) 1/3) (*.f64 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (fma.f64 -1/2 (*.f64 b b) 1)) (*.f64 (/.f64 (sin.f64 b) (/.f64 (fma.f64 -1/2 (*.f64 b b) 1) r)) (-.f64 -1/2 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2))))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (/.f64 (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))) r))
(*.f64 (/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a)))) r)
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a)
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) a)
(+.f64 (*.f64 -1/6 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 3))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a))
(fma.f64 -1/6 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 a 3)) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) a))
(fma.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (pow.f64 a 3) -1/6)))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (+.f64 a (*.f64 -1/6 (pow.f64 a 3))))
(+.f64 (*.f64 1/120 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 5))) (+.f64 (*.f64 -1/6 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 3))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a)))
(fma.f64 1/120 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 a 5)) (fma.f64 -1/6 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 a 3)) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) a)))
(fma.f64 1/120 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 5)) (fma.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (pow.f64 a 3) -1/6))))
(fma.f64 1/120 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 a 5)) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (+.f64 a (*.f64 -1/6 (pow.f64 a 3)))))
(+.f64 (*.f64 1/120 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 5))) (+.f64 (*.f64 -1/6 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 3))) (+.f64 (*.f64 -1/5040 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 7))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a))))
(fma.f64 1/120 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 a 5)) (fma.f64 -1/6 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 a 3)) (fma.f64 -1/5040 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 a 7)) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) a))))
(fma.f64 1/120 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 5)) (fma.f64 -1/6 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 a 3)) (fma.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) a (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (pow.f64 a 7) -1/5040)))))
(+.f64 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (+.f64 a (*.f64 -1/5040 (pow.f64 a 7)))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (+.f64 (*.f64 -1/6 (pow.f64 a 3)) (*.f64 1/120 (pow.f64 a 5)))))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(*.f64 (sin.f64 a) (-.f64 (*.f64 1/6 (pow.f64 b 3)) b))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(*.f64 -1 (*.f64 (sin.f64 a) b))
(neg.f64 (*.f64 b (sin.f64 a)))
(*.f64 b (neg.f64 (sin.f64 a)))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)))
(*.f64 (*.f64 1/6 (sin.f64 a)) (pow.f64 b 3))
(*.f64 1/6 (*.f64 (pow.f64 b 3) (sin.f64 a)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)))
(*.f64 (*.f64 1/6 (sin.f64 a)) (pow.f64 b 3))
(*.f64 1/6 (*.f64 (pow.f64 b 3) (sin.f64 a)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))
(*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (/.f64 1/6 (cos.f64 a))) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (fma.f64 (/.f64 1 (cos.f64 a)) 1/3 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (/.f64 1/6 (cos.f64 a))) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (pow.f64 b 3) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (fma.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (neg.f64 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (/.f64 1/6 (cos.f64 a))) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))))))) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))))
(+.f64 (/.f64 b (cos.f64 a)) (-.f64 (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (fma.f64 (/.f64 1 (cos.f64 a)) 1/3 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 1 (cos.f64 a)) 1/3 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))
(*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 6 (/.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (pow.f64 b 3)))
(*.f64 6 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) 6) (*.f64 (pow.f64 b 3) (sin.f64 a)))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (cos.f64 a) (pow.f64 b 4))) (*.f64 6 (/.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (pow.f64 b 3))))
(fma.f64 6 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) (/.f64 (/.f64 (*.f64 (*.f64 18 (cos.f64 a)) (sin.f64 b)) (pow.f64 (sin.f64 a) 2)) (pow.f64 b 4)))
(fma.f64 18 (/.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (pow.f64 b 4)) (/.f64 (*.f64 (sin.f64 b) 6) (*.f64 (pow.f64 b 3) (sin.f64 a))))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (*.f64 -1 (/.f64 (+.f64 (*.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a))) (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (pow.f64 (sin.f64 a) 3)))) (pow.f64 b 5)))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (cos.f64 a) (pow.f64 b 4))) (fma.f64 6 (/.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (pow.f64 b 3)) (neg.f64 (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a)) (*.f64 -54 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 5)))))
(-.f64 (fma.f64 6 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) (/.f64 (/.f64 (*.f64 (*.f64 18 (cos.f64 a)) (sin.f64 b)) (pow.f64 (sin.f64 a) 2)) (pow.f64 b 4))) (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 -54 (/.f64 (pow.f64 (sin.f64 a) 3) (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 5)))
(-.f64 (fma.f64 18 (/.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (pow.f64 b 4)) (/.f64 (*.f64 (sin.f64 b) 6) (*.f64 (pow.f64 b 3) (sin.f64 a)))) (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 -54 (/.f64 (pow.f64 (sin.f64 a) 3) (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 5)))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (pow.f64 (sin.f64 a) 2))) (+.f64 (*.f64 3 (/.f64 (*.f64 (cos.f64 a) (+.f64 (*.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a))) (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (pow.f64 (sin.f64 a) 3))))) (sin.f64 a))) (*.f64 -108 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (pow.f64 (sin.f64 a) 2))))) (pow.f64 b 6))) (*.f64 -1 (/.f64 (+.f64 (*.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a))) (*.f64 -54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (pow.f64 (sin.f64 a) 3)))) (pow.f64 b 5))))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (cos.f64 a) (pow.f64 b 4))) (fma.f64 6 (/.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (pow.f64 b 3)) (fma.f64 -1 (/.f64 (fma.f64 36 (/.f64 (*.f64 (cos.f64 a) (sin.f64 b)) (pow.f64 (sin.f64 a) 2)) (fma.f64 3 (/.f64 (cos.f64 a) (/.f64 (sin.f64 a) (fma.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a)) (*.f64 -54 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 (cos.f64 a) 2))))))) (*.f64 -108 (/.f64 (*.f64 (cos.f64 a) (sin.f64 b)) (pow.f64 (sin.f64 a) 2))))) (pow.f64 b 6)) (neg.f64 (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a)) (*.f64 -54 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 5))))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (cos.f64 a) (pow.f64 b 4))) (-.f64 (-.f64 (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a)))) (/.f64 (+.f64 (*.f64 3 (*.f64 (/.f64 (cos.f64 a) (sin.f64 a)) (fma.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 -54 (/.f64 (pow.f64 (sin.f64 a) 3) (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2))))))) (*.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (cos.f64 a)) -72)) (pow.f64 b 6))) (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 -54 (/.f64 (pow.f64 (sin.f64 a) 3) (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 5))))
(-.f64 (-.f64 (fma.f64 18 (/.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (pow.f64 b 4)) (/.f64 (*.f64 (sin.f64 b) 6) (*.f64 (pow.f64 b 3) (sin.f64 a)))) (/.f64 (fma.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 -54 (/.f64 (pow.f64 (sin.f64 a) 3) (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 5))) (/.f64 (+.f64 (*.f64 3 (*.f64 (/.f64 (cos.f64 a) (sin.f64 a)) (fma.f64 -36 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 -54 (/.f64 (pow.f64 (sin.f64 a) 3) (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2))))))) (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) -72)) (pow.f64 b 6)))
(*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3))))
(*.f64 6 (/.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (pow.f64 b 3)))
(*.f64 6 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) 6) (*.f64 (pow.f64 b 3) (sin.f64 a)))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (cos.f64 a) (pow.f64 b 4))) (*.f64 6 (/.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (pow.f64 b 3))))
(fma.f64 6 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) (/.f64 (/.f64 (*.f64 (*.f64 18 (cos.f64 a)) (sin.f64 b)) (pow.f64 (sin.f64 a) 2)) (pow.f64 b 4)))
(fma.f64 18 (/.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (pow.f64 b 4)) (/.f64 (*.f64 (sin.f64 b) 6) (*.f64 (pow.f64 b 3) (sin.f64 a))))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 5)))) (*.f64 36 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 5)))))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (cos.f64 a) (pow.f64 b 4))) (fma.f64 6 (/.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (pow.f64 b 3)) (fma.f64 54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 5))) (*.f64 36 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 5)))))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (cos.f64 a) (pow.f64 b 4))) (fma.f64 6 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) (fma.f64 54 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 b 5))) (*.f64 36 (/.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (pow.f64 b 5))))))
(fma.f64 18 (/.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (pow.f64 b 4)) (+.f64 (*.f64 54 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 b 5)))) (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (+.f64 (/.f64 36 (pow.f64 b 5)) (/.f64 6 (pow.f64 b 3))))))
(+.f64 (*.f64 18 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 4)))) (+.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -3 (/.f64 (*.f64 (cos.f64 a) (+.f64 (*.f64 36 (/.f64 (sin.f64 b) (sin.f64 a))) (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (pow.f64 (sin.f64 a) 3))))) (sin.f64 a))) (+.f64 (*.f64 36 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (pow.f64 (sin.f64 a) 2))) (*.f64 -108 (/.f64 (*.f64 (sin.f64 b) (cos.f64 a)) (pow.f64 (sin.f64 a) 2))))) (pow.f64 b 6))) (+.f64 (*.f64 6 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 3)))) (+.f64 (*.f64 54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 5)))) (*.f64 36 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 5))))))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (cos.f64 a) (pow.f64 b 4))) (fma.f64 -1 (/.f64 (fma.f64 -3 (/.f64 (cos.f64 a) (/.f64 (sin.f64 a) (fma.f64 36 (/.f64 (sin.f64 b) (sin.f64 a)) (*.f64 54 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 (cos.f64 a) 2))))))) (*.f64 (/.f64 (*.f64 (cos.f64 a) (sin.f64 b)) (pow.f64 (sin.f64 a) 2)) -72)) (pow.f64 b 6)) (fma.f64 6 (/.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (pow.f64 b 3)) (fma.f64 54 (/.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 5))) (*.f64 36 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) (pow.f64 b 5))))))))
(fma.f64 18 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (cos.f64 a) (pow.f64 b 4))) (-.f64 (fma.f64 6 (/.f64 (sin.f64 b) (*.f64 (pow.f64 b 3) (sin.f64 a))) (fma.f64 54 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 b 5))) (*.f64 36 (/.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (pow.f64 b 5))))) (/.f64 (fma.f64 -3 (*.f64 (/.f64 (cos.f64 a) (sin.f64 a)) (fma.f64 36 (/.f64 (sin.f64 b) (sin.f64 a)) (*.f64 54 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (pow.f64 (cos.f64 a) 2))))) (*.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (cos.f64 a)) -72)) (pow.f64 b 6))))
(-.f64 (fma.f64 18 (/.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) (pow.f64 b 4)) (+.f64 (*.f64 54 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 b 5)))) (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (+.f64 (/.f64 36 (pow.f64 b 5)) (/.f64 6 (pow.f64 b 3)))))) (/.f64 (fma.f64 -3 (*.f64 (/.f64 (cos.f64 a) (sin.f64 a)) (fma.f64 36 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 54 (/.f64 (pow.f64 (sin.f64 a) 3) (*.f64 (sin.f64 b) (pow.f64 (cos.f64 a) 2)))))) (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (sin.f64 a) 2) (cos.f64 a))) -72)) (pow.f64 b 6)))
(/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))
(/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (*.f64 b b))))
(/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) a)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))))
(fma.f64 -1 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 2) (*.f64 a (sin.f64 b)))) (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (*.f64 b b)))))
(-.f64 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1)) (*.f64 (/.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (sin.f64 b))))
(-.f64 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1)) (*.f64 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (sin.f64 b))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3)))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) a)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))))
(fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (*.f64 b b)))) (neg.f64 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 3) (sin.f64 b)))))) (fma.f64 -1 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 2) (*.f64 a (sin.f64 b)))) (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (*.f64 b b))))))
(-.f64 (-.f64 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1)) (*.f64 (/.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (sin.f64 b)))) (*.f64 a (*.f64 a (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1))) (/.f64 (*.f64 (sin.f64 b) (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2)) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 3))))))
(-.f64 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1)) (+.f64 (*.f64 a (*.f64 a (*.f64 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1)) (-.f64 -1/2 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)))))) (*.f64 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (sin.f64 b)))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3))))) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (+.f64 (*.f64 1/2 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (*.f64 -1/6 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 3)))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (*.f64 (sin.f64 b) a)) (pow.f64 (+.f64 1 (*.f64 -1/2 (pow.f64 b 2))) 2))) (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))))))
(fma.f64 -1 (*.f64 (pow.f64 a 3) (fma.f64 -1 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (/.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (fma.f64 -1/2 (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (*.f64 b b)))) (neg.f64 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 3) (sin.f64 b))))))) (*.f64 (/.f64 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 b)) (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 2)) 1/3))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (*.f64 b b)))) (neg.f64 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 3) (sin.f64 b)))))) (fma.f64 -1 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (/.f64 (pow.f64 (+.f64 1 (*.f64 -1/2 (*.f64 b b))) 2) (*.f64 a (sin.f64 b)))) (/.f64 (sin.f64 b) (+.f64 1 (*.f64 -1/2 (*.f64 b b)))))))
(-.f64 (-.f64 (-.f64 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1)) (*.f64 (/.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (sin.f64 b)))) (*.f64 a (*.f64 a (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1))) (/.f64 (*.f64 (sin.f64 b) (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2)) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 3)))))) (*.f64 (pow.f64 a 3) (-.f64 (*.f64 (*.f64 (/.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (sin.f64 b)) 1/3) (*.f64 (/.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (fma.f64 -1/2 (*.f64 b b) 1)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1))) (/.f64 (*.f64 (sin.f64 b) (pow.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) 2)) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 3)))))))
(-.f64 (-.f64 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1)) (*.f64 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)) (*.f64 a (sin.f64 b)))) (*.f64 (*.f64 a a) (+.f64 (*.f64 a (-.f64 (/.f64 (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 1/3) (/.f64 (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2) (sin.f64 b))) (*.f64 (/.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (fma.f64 -1/2 (*.f64 b b) 1)) (*.f64 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1)) (-.f64 -1/2 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2))))))) (*.f64 (/.f64 (sin.f64 b) (fma.f64 -1/2 (*.f64 b b) 1)) (-.f64 -1/2 (/.f64 (pow.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) 2) (pow.f64 (fma.f64 -1/2 (*.f64 b b) 1) 2)))))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (pow.f64 b 2)))) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (cos.f64 a) (+.f64 1 (*.f64 -1/2 (*.f64 b b))) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (-.f64 (*.f64 1/6 (pow.f64 b 3)) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (fma.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a) (*.f64 (fma.f64 1/6 (pow.f64 b 3) (neg.f64 b)) (sin.f64 a))))

eval753.0ms (3.5%)

Compiler

Compiled 25393 to 10928 computations (57% saved)

prune625.0ms (2.9%)

Pruning

78 alts after pruning (72 fresh and 6 done)

PrunedKeptTotal
New86530895
Fresh174259
Picked011
Done257
Total88478962
Error
0.0b
Counts
962 → 78
Alt Table
Click to see full alt table
StatusErrorProgram
55.1b
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
41.5b
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
53.8b
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
31.6b
(/.f64 b (/.f64 (cos.f64 a) r))
31.5b
(/.f64 (*.f64 r b) (cos.f64 a))
35.8b
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
0.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 3) (*.f64 (sin.f64 b) (sin.f64 a)))))
56.9b
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
27.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
53.8b
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
37.4b
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
30.0b
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
29.6b
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
17.7b
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
30.0b
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
54.5b
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
0.4b
(*.f64 r (pow.f64 (-.f64 (/.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (sin.f64 b)) (/.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (sin.f64 b))) -1))
17.5b
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
41.0b
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
53.8b
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
52.8b
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
54.3b
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
23.7b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
32.0b
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
30.9b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
54.8b
(*.f64 r (log.f64 1))
17.7b
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
0.4b
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
55.6b
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
28.7b
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
17.7b
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
0.4b
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
53.8b
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
28.8b
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
31.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
17.7b
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
25.0b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
55.6b
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
53.5b
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
18.3b
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
1.8b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))) (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))))) (*.f64 (sin.f64 b) (sin.f64 a)))))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
53.5b
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
28.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
17.7b
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
40.2b
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
44.0b
(*.f64 r b)
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (expm1.f64 (log1p.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
30.0b
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
31.5b
(*.f64 (/.f64 r (cos.f64 a)) b)
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3)))))
30.0b
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
26.6b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
53.6b
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
18.2b
(*.f64 r (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 3) -1))
33.2b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))))
17.8b
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
31.7b
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
44.1b
(pow.f64 (sqrt.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)))) 2)
18.3b
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
52.6b
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
31.5b
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
0.4b
(*.f64 r (pow.f64 (/.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))) (sin.f64 b)) -1))
54.6b
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
53.8b
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
52.6b
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
31.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
17.8b
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
17.6b
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
31.6b
(/.f64 r (/.f64 (cos.f64 a) b))
0.3b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))))
18.0b
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
30.5b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
31.5b
(*.f64 r (/.f64 b (cos.f64 a)))
0.6b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (log.f64 (+.f64 1 (expm1.f64 (*.f64 (cos.f64 b) (cos.f64 a))))) (*.f64 (sin.f64 b) (sin.f64 a)))))
30.6b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
Compiler

Compiled 2395 to 1651 computations (31.1% saved)

localize28.0ms (0.1%)

Local error

Found 4 expressions with local error:

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

Compiled 63 to 12 computations (81% saved)

series16.0ms (0.1%)

Counts
4 → 92
Calls

27 calls:

TimeVariablePointExpression
2.0ms
b
@-inf
(*.f64 (cos.f64 a) (cos.f64 b))
1.0ms
b
@inf
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
1.0ms
b
@-inf
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
1.0ms
b
@inf
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))))
1.0ms
a
@inf
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))

rewrite125.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
669×prod-diff_binary64
666×log-prod_binary64
240×expm1-udef_binary64
240×log1p-udef_binary64
224×pow3_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01375
127139
2365439
Stop Event
node limit
Counts
4 → 247
Calls
Call 1
Inputs
(/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))))
(fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(*.f64 (cos.f64 a) (cos.f64 b))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 0 (neg.f64 (cos.f64 (+.f64 b a)))) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (sin.f64 b) r)) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) 1) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (*.f64 (cos.f64 a) (cos.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (sin.f64 b) (sin.f64 a) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sqrt.f64 (sin.f64 b)))) (*.f64 (sqrt.f64 (sin.f64 a)) (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1) (*.f64 (cos.f64 a) (cos.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 1 (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 a) (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 a)) 2) (*.f64 (cbrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 a)) (*.f64 (sqrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a))) 1/2 (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (pow.f64 (cbrt.f64 (cos.f64 b)) 2)) (cbrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (sqrt.f64 (cos.f64 b))) (sqrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 1 (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 a) (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 a)) 2) (*.f64 (cbrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 a)) (*.f64 (sqrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a))) 1/2 (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (pow.f64 (cbrt.f64 (cos.f64 b)) 2)) (cbrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (sqrt.f64 (cos.f64 b))) (sqrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b))) (pow.f64 (cbrt.f64 (sin.f64 a)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 a)) (sin.f64 b)) (pow.f64 (cbrt.f64 (sin.f64 a)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 1 (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 a) (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 a)) 2) (*.f64 (cbrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 a)) (*.f64 (sqrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a))) 1/2 (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (pow.f64 (cbrt.f64 (cos.f64 b)) 2)) (cbrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (sqrt.f64 (cos.f64 b))) (sqrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 1 (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 a) (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 a)) 2) (*.f64 (cbrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 a)) (*.f64 (sqrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a))) 1/2 (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (pow.f64 (cbrt.f64 (cos.f64 b)) 2)) (cbrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (sqrt.f64 (cos.f64 b))) (sqrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 1 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 a) (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 a)) 2) (*.f64 (cbrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 a)) (*.f64 (sqrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a))) 1/2 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (pow.f64 (cbrt.f64 (cos.f64 b)) 2)) (cbrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (sqrt.f64 (cos.f64 b))) (sqrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))) (fma.f64 (neg.f64 (cbrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))) (*.f64 (cbrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 1 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 a) (cos.f64 b)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 a)) 2) (*.f64 (cbrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 a)) (*.f64 (sqrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a))) 1/2 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (pow.f64 (cbrt.f64 (cos.f64 b)) 2)) (cbrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (sqrt.f64 (cos.f64 b))) (sqrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b)))))) (fma.f64 (neg.f64 (sqrt.f64 (sin.f64 b))) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))) (*.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sin.f64 a) (sqrt.f64 (sin.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 1 (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 a) (cos.f64 b)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 b)) 2) (*.f64 (cbrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2) (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (cos.f64 a)) 2) (*.f64 (cbrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 b)) (*.f64 (sqrt.f64 (cos.f64 b)) (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.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 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (cos.f64 a)) (*.f64 (sqrt.f64 (cos.f64 a)) (cos.f64 b)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a))) 1/2 (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (pow.f64 (cbrt.f64 (cos.f64 b)) 2)) (cbrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 a) (sqrt.f64 (cos.f64 b))) (sqrt.f64 (cos.f64 b)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (pow.f64 (cbrt.f64 (cos.f64 a)) 2)) (cbrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (*.f64 (cos.f64 b) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1)))) (fma.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1) (*.f64 (sin.f64 b) (*.f64 (sin.f64 a) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (cos.f64 (+.f64 b a)))) (cbrt.f64 (exp.f64 (cos.f64 (+.f64 b a)))))) (log.f64 (cbrt.f64 (exp.f64 (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (cos.f64 (+.f64 b a))))) (log.f64 (sqrt.f64 (exp.f64 (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (cos.f64 (+.f64 b a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 a) (cos.f64 (neg.f64 b))) (*.f64 (sin.f64 a) (sin.f64 (neg.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 a) (cos.f64 (*.f64 -1 b))) (*.f64 (sin.f64 a) (sin.f64 (*.f64 -1 b))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 a) (cos.f64 (*.f64 (neg.f64 (pow.f64 (cbrt.f64 b) 2)) (cbrt.f64 b)))) (*.f64 (sin.f64 a) (sin.f64 (*.f64 (neg.f64 (pow.f64 (cbrt.f64 b) 2)) (cbrt.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 a) (cos.f64 (*.f64 (neg.f64 (sqrt.f64 b)) (sqrt.f64 b)))) (*.f64 (sin.f64 a) (sin.f64 (*.f64 (neg.f64 (sqrt.f64 b)) (sqrt.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 (+.f64 b a)) (cos.f64 (fma.f64 (neg.f64 b) 1 b))) (*.f64 (sin.f64 (-.f64 a b)) (sin.f64 (fma.f64 (neg.f64 b) 1 b))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 (+.f64 b a)) (cos.f64 (fma.f64 (neg.f64 (cbrt.f64 b)) (pow.f64 (cbrt.f64 b) 2) b))) (*.f64 (sin.f64 (-.f64 a b)) (sin.f64 (fma.f64 (neg.f64 (cbrt.f64 b)) (pow.f64 (cbrt.f64 b) 2) b))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 (+.f64 b a)) (cos.f64 (fma.f64 (neg.f64 (sqrt.f64 b)) (sqrt.f64 b) b))) (*.f64 (sin.f64 (-.f64 a b)) (sin.f64 (fma.f64 (neg.f64 (sqrt.f64 b)) (sqrt.f64 b) b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 2) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cos.f64 (+.f64 b a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3) (pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 3)) (fma.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)) (-.f64 (pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 2) (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (*.f64 (cos.f64 a) (cos.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 2)) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 (+.f64 b a)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cos.f64 (+.f64 b a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (pow.f64 (exp.f64 (cos.f64 b)) (cos.f64 a)) (exp.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (+.f64 1 (expm1.f64 (*.f64 (cos.f64 a) (cos.f64 b)))) (exp.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 (cos.f64 b)) (cos.f64 a)) (exp.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 (cos.f64 a) (cos.f64 b)))) (exp.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (+.f64 1 (expm1.f64 (*.f64 (cos.f64 a) (cos.f64 b))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cos.f64 (+.f64 b a))))) (#(struct:change #<rule egg-rr> (2) ((x cos.f64 (-.f64 a b))))) (#(struct:change #<rule egg-rr> (2) ((x cos.f64 (-.f64 b a))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cos.f64 (+.f64 b a))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (cos.f64 a) (cos.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 b)) (cos.f64 a))) (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 b)) (cos.f64 a))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 b)) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (cos.f64 b)) (cos.f64 a)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (cos.f64 b)) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (cos.f64 a) (cos.f64 b)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 2 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a)))) -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 2 (+.f64 (cos.f64 (+.f64 b a)) (cos.f64 (+.f64 b a)))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (cos.f64 b)) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (cos.f64 a) (cos.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (cos.f64 a) (cos.f64 b)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (cos.f64 b) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (cos.f64 b) 3) (pow.f64 (cos.f64 a) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (cos.f64 a) (cos.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (cos.f64 a) (cos.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (cos.f64 a) (cos.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (cos.f64 a) (cos.f64 b))) 1))))))

simplify81.0ms (0.4%)

Algorithm
egg-herbie
Rules
497×times-frac_binary64
452×associate-/l*_binary64
437×associate-*l/_binary64
359×associate-*r/_binary64
303×distribute-rgt-in_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01902781
16242631
222932561
Stop Event
node limit
Counts
339 → 309
Calls
Call 1
Inputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 b r) (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(cos.f64 b)
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (cos.f64 b))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(cos.f64 b)
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (cos.f64 b))) (cos.f64 b)))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 a 6) (cos.f64 b))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (cos.f64 b))) (cos.f64 b))))
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))
(+.f64 (*.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4))) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (*.f64 -1/720 (*.f64 (cos.f64 a) (pow.f64 b 6))) (+.f64 (*.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4))) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
Outputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (fma.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (neg.f64 (/.f64 (*.f64 (sin.f64 a) (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a)))))) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (-.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3)))))))))
(-.f64 (+.f64 (/.f64 b (cos.f64 a)) (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b)))) (*.f64 (pow.f64 b 4) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3 (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (neg.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)) (*.f64 a (*.f64 a (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)))))
(+.f64 (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)) (*.f64 a (*.f64 a (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (fma.f64 (neg.f64 (pow.f64 a 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))) (fma.f64 (neg.f64 (pow.f64 a 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)))) (/.f64 (sin.f64 b) (cos.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (sin.f64 b) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))))
(+.f64 (*.f64 (/.f64 r (cos.f64 a)) b) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))) (+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 r (cos.f64 a)) b)))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 r (cos.f64 a)) b)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))) (+.f64 (/.f64 r (/.f64 (cos.f64 a) b)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (neg.f64 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))) (*.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) r)) -1/3)))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r))) (-.f64 (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 r (cos.f64 a)) b)) (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (*.f64 (sin.f64 a) -1/3) (/.f64 (pow.f64 (cos.f64 a) 2) r)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))))))))
(-.f64 (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 r (cos.f64 a)) b)) (-.f64 (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (*.f64 (sin.f64 a) -1/3) (/.f64 (pow.f64 (cos.f64 a) 2) r)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b (*.f64 b r)))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))))
(+.f64 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a) r))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (*.f64 a (*.f64 a (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 b) 3)) r) (pow.f64 (cos.f64 b) 3)))))))
(+.f64 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r) (*.f64 a (neg.f64 (*.f64 a (-.f64 (*.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) r)))))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (cos.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) r)) -1/3))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (-.f64 (-.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 a (*.f64 a (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 b) 3)) r) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (pow.f64 a 3) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) r)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 b) 3)) r) (pow.f64 (cos.f64 b) 3))))))))
(+.f64 (*.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a) r) (-.f64 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b)) (*.f64 (*.f64 a a) (+.f64 (*.f64 a (fma.f64 (/.f64 r (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) r))))) (-.f64 (*.f64 -1/2 (*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) r))))))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) r)
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(cos.f64 b)
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (cos.f64 b))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (cos.f64 b))
(-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b)))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b)))
(-.f64 (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b)) (*.f64 a (sin.f64 b)))
(fma.f64 (neg.f64 (sin.f64 b)) a (fma.f64 (*.f64 -1/2 (*.f64 a a)) (cos.f64 b) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b))))
(-.f64 (fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b))) (*.f64 a (sin.f64 b)))
(+.f64 (fma.f64 (*.f64 -1/2 (*.f64 a a)) (cos.f64 b) (cos.f64 b)) (*.f64 (sin.f64 b) (+.f64 (neg.f64 a) (*.f64 1/6 (pow.f64 a 3)))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (cos.f64 a) (neg.f64 (*.f64 b (sin.f64 a))))
(-.f64 (cos.f64 a) (*.f64 b (sin.f64 a)))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (fma.f64 -1 (*.f64 b (sin.f64 a)) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)))))
(+.f64 (cos.f64 a) (-.f64 (*.f64 (*.f64 b b) (*.f64 (cos.f64 a) -1/2)) (*.f64 b (sin.f64 a))))
(+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(+.f64 (cos.f64 a) (fma.f64 -1 (*.f64 b (sin.f64 a)) (fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b))))))
(+.f64 (-.f64 (cos.f64 a) (*.f64 b (sin.f64 a))) (fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (*.f64 (*.f64 b b) (*.f64 (cos.f64 a) -1/2))))
(+.f64 (fma.f64 -1/2 (*.f64 (*.f64 (cos.f64 a) b) b) (cos.f64 a)) (*.f64 (sin.f64 a) (+.f64 (neg.f64 b) (*.f64 1/6 (pow.f64 b 3)))))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b))) (*.f64 (cos.f64 a) (cos.f64 b)))
(fma.f64 -1 (*.f64 (sin.f64 a) (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))
(-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))
(cos.f64 b)
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))
(fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b))
(fma.f64 (*.f64 -1/2 (*.f64 a a)) (cos.f64 b) (cos.f64 b))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (cos.f64 b))) (cos.f64 b)))
(fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (fma.f64 1/24 (*.f64 (cos.f64 b) (pow.f64 a 4)) (cos.f64 b)))
(+.f64 (cos.f64 b) (*.f64 (cos.f64 b) (+.f64 (*.f64 -1/2 (*.f64 a a)) (*.f64 1/24 (pow.f64 a 4)))))
(*.f64 (cos.f64 b) (+.f64 (*.f64 -1/2 (*.f64 a a)) (+.f64 (*.f64 1/24 (pow.f64 a 4)) 1)))
(+.f64 (*.f64 -1/720 (*.f64 (pow.f64 a 6) (cos.f64 b))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (cos.f64 b))) (cos.f64 b))))
(fma.f64 -1/720 (*.f64 (cos.f64 b) (pow.f64 a 6)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (fma.f64 1/24 (*.f64 (cos.f64 b) (pow.f64 a 4)) (cos.f64 b))))
(+.f64 (*.f64 (+.f64 (*.f64 1/24 (pow.f64 a 4)) 1) (cos.f64 b)) (*.f64 (cos.f64 b) (+.f64 (*.f64 -1/720 (pow.f64 a 6)) (*.f64 -1/2 (*.f64 a a)))))
(+.f64 (*.f64 (cos.f64 b) (+.f64 (+.f64 (*.f64 -1/720 (pow.f64 a 6)) (*.f64 -1/2 (*.f64 a a))) (*.f64 1/24 (pow.f64 a 4)))) (cos.f64 b))
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))
(+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b))))
(fma.f64 -1/2 (*.f64 b (*.f64 b (cos.f64 a))) (cos.f64 a))
(fma.f64 -1/2 (*.f64 (*.f64 (cos.f64 a) b) b) (cos.f64 a))
(+.f64 (*.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4))) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(fma.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4)) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)))))
(fma.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4)) (fma.f64 -1/2 (*.f64 b (*.f64 b (cos.f64 a))) (cos.f64 a)))
(+.f64 (cos.f64 a) (*.f64 (cos.f64 a) (+.f64 (*.f64 -1/2 (*.f64 b b)) (*.f64 1/24 (pow.f64 b 4)))))
(+.f64 (*.f64 -1/720 (*.f64 (cos.f64 a) (pow.f64 b 6))) (+.f64 (*.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4))) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(fma.f64 -1/720 (*.f64 (cos.f64 a) (pow.f64 b 6)) (fma.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4)) (+.f64 (cos.f64 a) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b))))))
(fma.f64 -1/720 (*.f64 (cos.f64 a) (pow.f64 b 6)) (fma.f64 1/24 (*.f64 (cos.f64 a) (pow.f64 b 4)) (fma.f64 -1/2 (*.f64 b (*.f64 b (cos.f64 a))) (cos.f64 a))))
(+.f64 (fma.f64 -1/2 (*.f64 (*.f64 (cos.f64 a) b) b) (cos.f64 a)) (*.f64 (cos.f64 a) (+.f64 (*.f64 1/24 (pow.f64 b 4)) (*.f64 -1/720 (pow.f64 b 6)))))

localize5.0ms (0%)

Compiler

Compiled 11 to 9 computations (18.2% saved)

localize30.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
0.2b
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))
2.4b
(cos.f64 (-.f64 b a))
Compiler

Compiled 31 to 8 computations (74.2% saved)

series20.0ms (0.1%)

Counts
3 → 68
Calls

21 calls:

TimeVariablePointExpression
7.0ms
b
@0
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
1.0ms
r
@0
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
1.0ms
b
@0
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))
1.0ms
a
@0
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
1.0ms
a
@0
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))

rewrite82.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
546×log-prod_binary64
504×prod-diff_binary64
348×pow-prod-down_binary64
291×pow2_binary64
216×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0931
120131
2289531
Stop Event
node limit
Counts
3 → 118
Calls
Call 1
Inputs
(cos.f64 (-.f64 b a))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (*.f64 (cos.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (cos.f64 (-.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 1) (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))) (fma.f64 (neg.f64 (neg.f64 (sin.f64 a))) (sin.f64 b) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 (exp.f64 (log1p.f64 (-.f64 b a)))) (cos.f64 1)) (*.f64 (sin.f64 (exp.f64 (log1p.f64 (-.f64 b a)))) (sin.f64 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 (/.f64 (pow.f64 b 3) (fma.f64 a (+.f64 b a) (*.f64 b b)))) (cos.f64 (/.f64 (pow.f64 a 3) (fma.f64 a (+.f64 b a) (*.f64 b b))))) (*.f64 (sin.f64 (/.f64 (pow.f64 b 3) (fma.f64 a (+.f64 b a) (*.f64 b b)))) (sin.f64 (/.f64 (pow.f64 a 3) (fma.f64 a (+.f64 b a) (*.f64 b b))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 (/.f64 (*.f64 b b) (+.f64 b a))) (cos.f64 (/.f64 (*.f64 a a) (+.f64 b a)))) (*.f64 (sin.f64 (/.f64 (*.f64 b b) (+.f64 b a))) (sin.f64 (/.f64 (*.f64 a a) (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (cos.f64 (-.f64 b a)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (cos.f64 (-.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (cos.f64 (-.f64 b a))))) (log.f64 (sqrt.f64 (exp.f64 (cos.f64 (-.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (neg.f64 (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (neg.f64 (sin.f64 a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (cos.f64 (-.f64 b a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 b) (cos.f64 (*.f64 (neg.f64 a) 1))) (*.f64 (sin.f64 b) (sin.f64 (*.f64 (neg.f64 a) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 (-.f64 b a)) (cos.f64 (fma.f64 (neg.f64 a) 1 a))) (*.f64 (sin.f64 (-.f64 b a)) (sin.f64 (fma.f64 (neg.f64 a) 1 a))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 (-.f64 b a)) (cos.f64 (fma.f64 (neg.f64 (cbrt.f64 a)) (pow.f64 (cbrt.f64 a) 2) a))) (*.f64 (sin.f64 (-.f64 b a)) (sin.f64 (fma.f64 (neg.f64 (cbrt.f64 a)) (pow.f64 (cbrt.f64 a) 2) a))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 (-.f64 b a)) (cos.f64 (+.f64 (neg.f64 a) a))) (*.f64 (sin.f64 (-.f64 b a)) (sin.f64 (+.f64 (neg.f64 a) a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cos.f64 (-.f64 b a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cos.f64 (-.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 2) (cbrt.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cos.f64 (-.f64 b a))) (sqrt.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3)) (+.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (-.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2) (*.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2)) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cos.f64 (-.f64 b a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 (-.f64 b a)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 (-.f64 b a)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (cos.f64 (-.f64 b a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cos.f64 (-.f64 b a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (exp.f64 (*.f64 (cos.f64 b) (cos.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (cos.f64 (-.f64 b a)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cos.f64 (-.f64 b a))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sin.f64 b) (sin.f64 a) (*.f64 (cos.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (sin.f64 b) (sin.f64 a)) (*.f64 (cos.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (*.f64 (cos.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (*.f64 (cos.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 b) (neg.f64 (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 a) (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sin.f64 a) (sin.f64 b) (*.f64 (cos.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cos.f64 b) (cos.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (cos.f64 b) (cos.f64 a)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (sin.f64 b)) (/.f64 1 (neg.f64 (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) -2) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cos.f64 (-.f64 b a)) -1/2) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (sqrt.f64 (cos.f64 (-.f64 b a)))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (-.f64 b a)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (neg.f64 (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (-.f64 b a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (sin.f64 b) r)) (neg.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) 1) (cos.f64 (-.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 2)) (cbrt.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (-.f64 b a)))) (sqrt.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (sin.f64 b)) r) (neg.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 (sin.f64 b))) (neg.f64 (cos.f64 (-.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 1))))))

simplify60.0ms (0.3%)

Algorithm
egg-herbie
Rules
567×times-frac_binary64
483×associate-/l*_binary64
455×associate-*l/_binary64
360×associate-*r/_binary64
310×distribute-rgt-in_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01781783
15961643
222781557
Stop Event
node limit
Counts
186 → 173
Calls
Call 1
Inputs
(cos.f64 (neg.f64 a))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 (neg.f64 a)) b)) (cos.f64 (neg.f64 a)))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 b 2) (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 (neg.f64 a)) b)) (cos.f64 (neg.f64 a))))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 b 2) (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 (neg.f64 a)) b)) (+.f64 (cos.f64 (neg.f64 a)) (*.f64 1/6 (*.f64 (sin.f64 (neg.f64 a)) (pow.f64 b 3))))))
(cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b))))
(cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b))))
(cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b))))
(cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b))))
(cos.f64 b)
(+.f64 (cos.f64 b) (*.f64 (sin.f64 b) a))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (cos.f64 b) (*.f64 (sin.f64 b) a)))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (*.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (cos.f64 b) (*.f64 (sin.f64 b) a))))
(cos.f64 (+.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 b (*.f64 -1 a)))
(/.f64 b (cos.f64 (neg.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (pow.f64 b 2)) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 b (cos.f64 (neg.f64 a))))
(+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) (pow.f64 (cos.f64 (neg.f64 a)) 3))))) (pow.f64 b 3)) (+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (pow.f64 b 2)) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 b (cos.f64 (neg.f64 a)))))
(+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) (pow.f64 (cos.f64 (neg.f64 a)) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 (neg.f64 a)) (pow.f64 (cos.f64 (neg.f64 a)) 2))) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 (neg.f64 a)) (pow.f64 (cos.f64 (neg.f64 a)) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) (pow.f64 (cos.f64 (neg.f64 a)) 3)))))) (cos.f64 (neg.f64 a)))))))) (+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (pow.f64 b 2)) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 b (cos.f64 (neg.f64 a))))))
(/.f64 (sin.f64 b) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (sin.f64 b) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (sin.f64 b) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (sin.f64 b) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))) (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b))))) (pow.f64 a 3))))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 b r) (cos.f64 (neg.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 (*.f64 r b) (cos.f64 (neg.f64 a))))
(+.f64 (*.f64 (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) r) (pow.f64 (cos.f64 (neg.f64 a)) 3))))) (pow.f64 b 3)) (+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 (*.f64 r b) (cos.f64 (neg.f64 a)))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) r) (pow.f64 (cos.f64 (neg.f64 a)) 3)))))) (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) r) (pow.f64 (cos.f64 (neg.f64 a)) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) r) (pow.f64 (cos.f64 (neg.f64 a)) 2))))) (pow.f64 b 4))) (+.f64 (*.f64 (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) r) (pow.f64 (cos.f64 (neg.f64 a)) 3))))) (pow.f64 b 3)) (+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 (*.f64 r b) (cos.f64 (neg.f64 a))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b))) (+.f64 (*.f64 -1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b (*.f64 -1 a))))
Outputs
(cos.f64 (neg.f64 a))
(cos.f64 a)
(+.f64 (*.f64 -1 (*.f64 (sin.f64 (neg.f64 a)) b)) (cos.f64 (neg.f64 a)))
(fma.f64 -1 (*.f64 (neg.f64 (sin.f64 a)) b) (cos.f64 a))
(-.f64 (cos.f64 a) (*.f64 (neg.f64 (sin.f64 a)) b))
(fma.f64 (sin.f64 a) b (cos.f64 a))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 b 2) (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 (neg.f64 a)) b)) (cos.f64 (neg.f64 a))))
(fma.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)) (fma.f64 -1 (*.f64 (neg.f64 (sin.f64 a)) b) (cos.f64 a)))
(fma.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)) (-.f64 (cos.f64 a) (*.f64 (neg.f64 (sin.f64 a)) b)))
(fma.f64 -1/2 (*.f64 b (*.f64 b (cos.f64 a))) (fma.f64 (sin.f64 a) b (cos.f64 a)))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 b 2) (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 -1 (*.f64 (sin.f64 (neg.f64 a)) b)) (+.f64 (cos.f64 (neg.f64 a)) (*.f64 1/6 (*.f64 (sin.f64 (neg.f64 a)) (pow.f64 b 3))))))
(fma.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)) (fma.f64 -1 (*.f64 (neg.f64 (sin.f64 a)) b) (+.f64 (cos.f64 a) (*.f64 1/6 (*.f64 (neg.f64 (sin.f64 a)) (pow.f64 b 3))))))
(fma.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)) (-.f64 (fma.f64 1/6 (*.f64 (neg.f64 (sin.f64 a)) (pow.f64 b 3)) (cos.f64 a)) (*.f64 (neg.f64 (sin.f64 a)) b)))
(fma.f64 -1/2 (*.f64 b (*.f64 b (cos.f64 a))) (fma.f64 (sin.f64 a) b (fma.f64 (*.f64 -1/6 (sin.f64 a)) (pow.f64 b 3) (cos.f64 a))))
(cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b))))
(cos.f64 (+.f64 a (neg.f64 b)))
(cos.f64 (-.f64 a b))
(cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b))))
(cos.f64 (+.f64 a (neg.f64 b)))
(cos.f64 (-.f64 a b))
(cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b))))
(cos.f64 (+.f64 a (neg.f64 b)))
(cos.f64 (-.f64 a b))
(cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b))))
(cos.f64 (+.f64 a (neg.f64 b)))
(cos.f64 (-.f64 a b))
(cos.f64 b)
(+.f64 (cos.f64 b) (*.f64 (sin.f64 b) a))
(+.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))
(fma.f64 a (sin.f64 b) (cos.f64 b))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (cos.f64 b) (*.f64 (sin.f64 b) a)))
(fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (+.f64 (cos.f64 b) (*.f64 a (sin.f64 b))))
(fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (fma.f64 a (sin.f64 b) (cos.f64 b)))
(+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (+.f64 (*.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (cos.f64 b) (*.f64 (sin.f64 b) a))))
(fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (fma.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (+.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (fma.f64 -1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 a (sin.f64 b) (cos.f64 b))))
(fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (+.f64 (cos.f64 b) (*.f64 (sin.f64 b) (+.f64 a (*.f64 -1/6 (pow.f64 a 3))))))
(cos.f64 (+.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a (neg.f64 b)))
(cos.f64 (-.f64 a b))
(cos.f64 (+.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a (neg.f64 b)))
(cos.f64 (-.f64 a b))
(cos.f64 (+.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a (neg.f64 b)))
(cos.f64 (-.f64 a b))
(cos.f64 (+.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a (neg.f64 b)))
(cos.f64 (-.f64 a b))
(/.f64 b (cos.f64 (neg.f64 a)))
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (pow.f64 b 2)) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 b (cos.f64 (neg.f64 a))))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (neg.f64 (sin.f64 a)) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (neg.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 b b)))
(-.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) b) b)))
(+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) (pow.f64 (cos.f64 (neg.f64 a)) 3))))) (pow.f64 b 3)) (+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (pow.f64 b 2)) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 b (cos.f64 (neg.f64 a)))))
(fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (neg.f64 (sin.f64 a)) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (+.f64 (/.f64 b (cos.f64 a)) (/.f64 (neg.f64 (sin.f64 a)) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (*.f64 (sin.f64 a) (sin.f64 a))) (pow.f64 (cos.f64 a) 3))) (*.f64 (neg.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 b b))))
(fma.f64 (pow.f64 b 3) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (sin.f64 a)) (pow.f64 (cos.f64 a) 3))) (-.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) b) b))))
(+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) (pow.f64 (cos.f64 (neg.f64 a)) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 (neg.f64 a)) (pow.f64 (cos.f64 (neg.f64 a)) 2))) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 (neg.f64 a)) (pow.f64 (cos.f64 (neg.f64 a)) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) (pow.f64 (cos.f64 (neg.f64 a)) 3)))))) (cos.f64 (neg.f64 a)))))))) (+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (pow.f64 b 2)) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 b (cos.f64 (neg.f64 a))))))
(fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (neg.f64 (sin.f64 a)) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 -1/2 (/.f64 (neg.f64 (sin.f64 a)) (pow.f64 (cos.f64 a) 2)) (fma.f64 1/6 (/.f64 (neg.f64 (sin.f64 a)) (pow.f64 (cos.f64 a) 2)) (neg.f64 (/.f64 (neg.f64 (sin.f64 a)) (/.f64 (cos.f64 a) (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (neg.f64 (sin.f64 a)) 2) (pow.f64 (cos.f64 a) 3))))))))))) (+.f64 (/.f64 b (cos.f64 a)) (/.f64 (neg.f64 (sin.f64 a)) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (*.f64 (sin.f64 a) (sin.f64 a))) (pow.f64 (cos.f64 a) 3))) (+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (neg.f64 (pow.f64 b 4)) (-.f64 (*.f64 (neg.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) -1/3) (*.f64 (/.f64 (neg.f64 (sin.f64 a)) (cos.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (*.f64 (sin.f64 a) (sin.f64 a))) (pow.f64 (cos.f64 a) 3))))) (*.f64 (neg.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 b b)))))
(-.f64 (fma.f64 (pow.f64 b 3) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (sin.f64 a)) (pow.f64 (cos.f64 a) 3))) (-.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) b) b)))) (*.f64 (pow.f64 b 4) (fma.f64 (/.f64 (neg.f64 (sin.f64 a)) (pow.f64 (cos.f64 a) 2)) -1/3 (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (sin.f64 a)) (pow.f64 (cos.f64 a) 3)))))))
(/.f64 (sin.f64 b) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a (neg.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a (neg.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a (neg.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a (neg.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a))))
(-.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))) (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 -1 (+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)) (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))))))
(-.f64 (-.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a)) (*.f64 a (*.f64 a (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))))
(-.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b))))) (pow.f64 a 3))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) a)) (*.f64 -1 (+.f64 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (*.f64 (pow.f64 a 3) (fma.f64 1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (fma.f64 -1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (neg.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))))))))))))
(+.f64 (-.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a)) (neg.f64 (fma.f64 (*.f64 a a) (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))) (*.f64 (pow.f64 a 3) (-.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) 1/3) (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))))))
(-.f64 (-.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a)) (*.f64 (*.f64 a a) (+.f64 (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) (*.f64 a (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) 1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)))))))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a (neg.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a (neg.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a (neg.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a (neg.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 b r) (cos.f64 (neg.f64 a)))
(/.f64 b (/.f64 (cos.f64 a) r))
(*.f64 (/.f64 b (cos.f64 a)) r)
(+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 (*.f64 r b) (cos.f64 (neg.f64 a))))
(+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (/.f64 (neg.f64 (sin.f64 a)) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))))
(+.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (*.f64 (neg.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 b (*.f64 b r))))
(-.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (*.f64 (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) b) b)) r))
(+.f64 (*.f64 (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) r) (pow.f64 (cos.f64 (neg.f64 a)) 3))))) (pow.f64 b 3)) (+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 (*.f64 r b) (cos.f64 (neg.f64 a)))))
(fma.f64 (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (neg.f64 (sin.f64 a)) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (pow.f64 b 3) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (/.f64 (neg.f64 (sin.f64 a)) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r)))))
(+.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (*.f64 (sin.f64 a) (sin.f64 a))) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (neg.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 b (*.f64 b r)))))
(fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (*.f64 (sin.f64 a) (sin.f64 a)) (pow.f64 (cos.f64 a) 3)) r)) (-.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (*.f64 (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) b) b)) r)))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) r) (pow.f64 (cos.f64 (neg.f64 a)) 3)))))) (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) r) (pow.f64 (cos.f64 (neg.f64 a)) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) r) (pow.f64 (cos.f64 (neg.f64 a)) 2))))) (pow.f64 b 4))) (+.f64 (*.f64 (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 (neg.f64 a)))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 (neg.f64 a)))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 (neg.f64 a)) 2) r) (pow.f64 (cos.f64 (neg.f64 a)) 3))))) (pow.f64 b 3)) (+.f64 (/.f64 (*.f64 (sin.f64 (neg.f64 a)) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 (neg.f64 a)) 2)) (/.f64 (*.f64 r b) (cos.f64 (neg.f64 a))))))
(fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (*.f64 (neg.f64 (sin.f64 a)) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (neg.f64 (sin.f64 a)) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))) (cos.f64 a)) (*.f64 (/.f64 (neg.f64 (sin.f64 a)) (/.f64 (pow.f64 (cos.f64 a) 2) r)) -1/3))) (fma.f64 (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (neg.f64 (sin.f64 a)) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (pow.f64 b 3) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (/.f64 (neg.f64 (sin.f64 a)) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))))))
(-.f64 (+.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (*.f64 (sin.f64 a) (sin.f64 a))) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (neg.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 b (*.f64 b r))))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (*.f64 (neg.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) r) -1/3) (*.f64 (/.f64 (neg.f64 (sin.f64 a)) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (*.f64 (sin.f64 a) (sin.f64 a))) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))))
(-.f64 (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (*.f64 (sin.f64 a) (sin.f64 a)) (pow.f64 (cos.f64 a) 3)) r)) (-.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (*.f64 (/.f64 (sin.f64 a) (/.f64 (/.f64 (pow.f64 (cos.f64 a) 2) b) b)) r))) (*.f64 (pow.f64 b 4) (fma.f64 (*.f64 (/.f64 r (pow.f64 (cos.f64 a) 2)) (neg.f64 (sin.f64 a))) -1/3 (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (*.f64 (sin.f64 a) (sin.f64 a)) (pow.f64 (cos.f64 a) 3)) r))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (neg.f64 (+.f64 a (*.f64 -1 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))
(-.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))))
(-.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a) r))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))
(-.f64 (-.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r)))) (*.f64 (*.f64 a a) (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (/.f64 (cos.f64 b) r)) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)))))
(-.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (+.f64 (*.f64 (*.f64 a a) (fma.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))) (*.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a) r)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b))) (+.f64 (*.f64 -1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (pow.f64 a 3) (fma.f64 -1 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) r)) 1/3))) (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))))
(-.f64 (-.f64 (-.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (pow.f64 a 3) (-.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) 1/3) (/.f64 (pow.f64 (cos.f64 b) 2) r)) (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (/.f64 (cos.f64 b) r)) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r))))))) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r)))) (*.f64 (*.f64 a a) (-.f64 (/.f64 (*.f64 -1/2 (sin.f64 b)) (/.f64 (cos.f64 b) r)) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)))))
(-.f64 (-.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (+.f64 (*.f64 (*.f64 a a) (fma.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))) (*.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a) r))) (*.f64 (pow.f64 a 3) (-.f64 (*.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) 1/3) r) (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (-.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 a b))) r)

localize43.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
0.2b
(/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a)))))
0.5b
(log.f64 (exp.f64 (cos.f64 (+.f64 b a))))
2.9b
(cos.f64 (+.f64 b a))
Compiler

Compiled 46 to 10 computations (78.3% saved)

series7.0ms (0%)

Counts
3 → 84
Calls

21 calls:

TimeVariablePointExpression
1.0ms
b
@0
(log.f64 (exp.f64 (cos.f64 (+.f64 b a))))
0.0ms
a
@0
(/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a)))))
0.0ms
a
@0
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
0.0ms
b
@0
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
0.0ms
b
@0
(/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a)))))

rewrite202.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
583×prod-diff_binary64
576×log-prod_binary64
308×pow2_binary64
219×fma-def_binary64
215×pow1/3_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01131
122331
2306131
Stop Event
node limit
Counts
3 → 141
Calls
Call 1
Inputs
(log.f64 (exp.f64 (cos.f64 (+.f64 b a))))
(/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a)))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sin.f64 b)) (sin.f64 a) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (sqrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 2 (*.f64 1/3 (cos.f64 (+.f64 b a)))) (*.f64 1/3 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 1/2 (cos.f64 (+.f64 b a))) (*.f64 1/2 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 1/3 (cos.f64 (+.f64 b a))) (*.f64 2 (*.f64 1/3 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1))) (fma.f64 (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 1 (*.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2))))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (cbrt.f64 (pow.f64 (sin.f64 b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 (exp.f64 (log1p.f64 (+.f64 b a)))) (cos.f64 1)) (*.f64 (sin.f64 (exp.f64 (log1p.f64 (+.f64 b a)))) (sin.f64 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (cos.f64 (/.f64 (*.f64 b b) (-.f64 b a))) (cos.f64 (/.f64 (*.f64 a a) (-.f64 b a)))) (*.f64 (sin.f64 (/.f64 (*.f64 b b) (-.f64 b a))) (sin.f64 (/.f64 (*.f64 a a) (-.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (cos.f64 (+.f64 b a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cos.f64 (+.f64 b a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 2 (*.f64 1/2 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3)) (+.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (+.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2) (*.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2)) (cos.f64 (-.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cos.f64 (+.f64 b a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cos.f64 (+.f64 b a)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cos.f64 (+.f64 b a))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cos.f64 (+.f64 b a))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 (+.f64 b a)) 1 (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (cos.f64 (+.f64 b a)) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) (cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2)) (cbrt.f64 (cos.f64 (+.f64 b a))) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) (sqrt.f64 (cos.f64 (+.f64 b a))) (fma.f64 (neg.f64 (sin.f64 a)) (sin.f64 b) (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 a) (cos.f64 b) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 a) (cos.f64 b) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (sin.f64 b) (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (sin.f64 b)) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) -2) (/.f64 (sin.f64 b) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))) (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cos.f64 (+.f64 b a)) -1/2) (/.f64 (sin.f64 b) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (sqrt.f64 (cos.f64 (+.f64 b a)))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (neg.f64 (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 (+.f64 b a)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) r)) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) r))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (sin.f64 b) r)) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) 1) (cos.f64 (+.f64 b a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (cbrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))) (cbrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (sin.f64 b)) r) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 (sin.f64 b))) (neg.f64 (cos.f64 (+.f64 b a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) r))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 1))))))

simplify62.0ms (0.3%)

Algorithm
egg-herbie
Rules
904×fma-def_binary64
521×times-frac_binary64
471×associate-/l*_binary64
437×associate-*l/_binary64
359×associate-*r/_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01781827
15851745
221051658
Stop Event
node limit
Counts
225 → 195
Calls
Call 1
Inputs
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 b)
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (cos.f64 b))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 b r) (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
Outputs
(cos.f64 a)
(+.f64 (cos.f64 a) (*.f64 -1 (*.f64 (sin.f64 a) b)))
(+.f64 (cos.f64 a) (neg.f64 (*.f64 (sin.f64 a) b)))
(-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2)))))
(+.f64 (cos.f64 a) (fma.f64 -1 (*.f64 (sin.f64 a) b) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)))))
(+.f64 (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b)) (*.f64 (cos.f64 a) (*.f64 (*.f64 b b) -1/2)))
(+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))
(+.f64 (cos.f64 a) (+.f64 (*.f64 -1 (*.f64 (sin.f64 a) b)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3))) (*.f64 -1/2 (*.f64 (cos.f64 a) (pow.f64 b 2))))))
(+.f64 (cos.f64 a) (fma.f64 -1 (*.f64 (sin.f64 a) b) (fma.f64 1/6 (*.f64 (sin.f64 a) (pow.f64 b 3)) (*.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b))))))
(+.f64 (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b)) (fma.f64 -1/2 (*.f64 (cos.f64 a) (*.f64 b b)) (*.f64 (pow.f64 b 3) (*.f64 (sin.f64 a) 1/6))))
(+.f64 (*.f64 (sin.f64 a) (+.f64 (neg.f64 b) (*.f64 1/6 (pow.f64 b 3)))) (fma.f64 (cos.f64 a) (*.f64 (*.f64 b b) -1/2) (cos.f64 a)))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 a (*.f64 -1 b)))
(cos.f64 (+.f64 a b))
(cos.f64 b)
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (cos.f64 b))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (cos.f64 b))
(-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b)))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b)))
(-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))
(-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (sin.f64 b) a)) (+.f64 (*.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (*.f64 (pow.f64 a 2) (cos.f64 b))) (cos.f64 b))))
(fma.f64 -1 (*.f64 a (sin.f64 b)) (fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (fma.f64 -1/2 (*.f64 (cos.f64 b) (*.f64 a a)) (cos.f64 b))))
(-.f64 (fma.f64 1/6 (*.f64 (sin.f64 b) (pow.f64 a 3)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b))) (*.f64 a (sin.f64 b)))
(fma.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b) (*.f64 (sin.f64 b) (+.f64 (neg.f64 a) (*.f64 1/6 (pow.f64 a 3)))))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a b))
(cos.f64 (-.f64 b (*.f64 -1 a)))
(cos.f64 (+.f64 a b))
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)))
(fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b))))
(fma.f64 (pow.f64 b 3) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 b 4) (+.f64 (*.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))))))) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (fma.f64 -1 (*.f64 (pow.f64 b 4) (fma.f64 1/6 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (fma.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (neg.f64 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))))))) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3)))))))))
(-.f64 (fma.f64 (pow.f64 b 3) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b) (/.f64 b (cos.f64 a)))) (*.f64 (pow.f64 b 4) (fma.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3 (*.f64 (/.f64 (neg.f64 (sin.f64 a)) (cos.f64 a)) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) a (/.f64 (sin.f64 b) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))) (*.f64 (*.f64 a a) (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) a) (pow.f64 (cos.f64 b) 2)))))
(fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3)))))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (*.f64 a (pow.f64 (sin.f64 b) 2)) (pow.f64 (cos.f64 b) 2)))))
(+.f64 (-.f64 (/.f64 a (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 (sin.f64 b) 2))) (*.f64 (*.f64 a a) (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (fma.f64 (neg.f64 (pow.f64 a 3)) (fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (/.f64 -1/2 (/.f64 (cos.f64 b) (sin.f64 b))) (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (cos.f64 b) 3))))) (/.f64 (sin.f64 b) (cos.f64 b))))
(+.f64 (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a))) (fma.f64 (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) -1/3))) (neg.f64 (pow.f64 a 3)) (/.f64 (sin.f64 b) (cos.f64 b))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 b r) (cos.f64 a))
(/.f64 b (/.f64 (cos.f64 a) r))
(*.f64 (/.f64 b (cos.f64 a)) r)
(*.f64 (/.f64 r (cos.f64 a)) b)
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))))
(+.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (*.f64 b b) r)))
(fma.f64 (/.f64 b (cos.f64 a)) r (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (*.f64 (pow.f64 b 3) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (*.f64 b b) r)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 b (cos.f64 a)) r)))
(fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (fma.f64 (/.f64 b (cos.f64 a)) r (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2))))) (pow.f64 b 4))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))) (+.f64 (/.f64 b (/.f64 (cos.f64 a) r)) (fma.f64 (pow.f64 b 3) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (neg.f64 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (/.f64 (*.f64 -1/6 r) (cos.f64 a)) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r)))))) (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) r)) -1/3)))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (*.f64 b b) r)) (-.f64 (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))) (*.f64 (/.f64 b (cos.f64 a)) r)) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) r) -1/3) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(-.f64 (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (fma.f64 (/.f64 b (cos.f64 a)) r (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r))) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) -1/3) r) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 a (*.f64 -1 b))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)))
(fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (*.f64 (/.f64 a (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2)) r))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (-.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r))))))
(fma.f64 (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r))) (*.f64 a (neg.f64 a)) (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r (*.f64 (*.f64 (/.f64 a (pow.f64 (cos.f64 b) 2)) (pow.f64 (sin.f64 b) 2)) r)))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (*.f64 (sin.f64 b) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (cos.f64 b)) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))) (*.f64 1/6 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2))))))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 3) r) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 a r))) (fma.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))) (*.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) r) (pow.f64 (cos.f64 b) 2)) -1/3))) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r)) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))))
(+.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r)) (-.f64 (-.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r))))) (*.f64 (pow.f64 a 3) (fma.f64 (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) r) -1/3 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))) (/.f64 (pow.f64 (sin.f64 b) 3) (/.f64 (pow.f64 (cos.f64 b) 3) r))))))))
(fma.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 a r) (-.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (*.f64 a a) (+.f64 (*.f64 (fma.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r))) (*.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (/.f64 (pow.f64 (cos.f64 b) 2) -1/3)) r)) a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (*.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3) (neg.f64 r)))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 a b)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b (*.f64 -1 a))))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 (+.f64 a b)) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))) r)

localize97.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (cos.f64 b) (cos.f64 a))
0.1b
(*.f64 (sin.f64 a) b)
0.2b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
0.2b
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b)))
Compiler

Compiled 61 to 12 computations (80.3% saved)

series27.0ms (0.1%)

Counts
3 → 64
Calls

21 calls:

TimeVariablePointExpression
11.0ms
a
@0
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b)))
1.0ms
b
@inf
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b)))
1.0ms
b
@inf
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
1.0ms
a
@inf
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b)))
1.0ms
a
@0
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))

rewrite120.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
803×log-prod_binary64
530×fma-def_binary64
277×expm1-udef_binary64
277×log1p-udef_binary64
276×fma-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01351
129151
2415251
Stop Event
node limit
Counts
3 → 81
Calls
Call 1
Inputs
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 (sin.f64 a) b)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))) (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sin.f64 b) (/.f64 1 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))) (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (*.f64 (cbrt.f64 (sin.f64 b)) (/.f64 1 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))) (sqrt.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (sin.f64 b)) (*.f64 (sqrt.f64 (sin.f64 b)) (/.f64 1 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (sin.f64 b)) (/.f64 1 (neg.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) (sin.f64 b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) 1) (/.f64 (cbrt.f64 (sin.f64 b)) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) 1) (/.f64 (sqrt.f64 (sin.f64 b)) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 2)) (/.f64 (sin.f64 b) (cbrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (pow.f64 (cbrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 2)) (cbrt.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (sin.f64 b)) (pow.f64 (cbrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 2)) (/.f64 (sqrt.f64 (sin.f64 b)) (cbrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))) (/.f64 (sin.f64 b) (sqrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (sin.f64 b) 2)) (sqrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))) (/.f64 (cbrt.f64 (sin.f64 b)) (sqrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3) (pow.f64 (*.f64 b (sin.f64 a)) 3))) (fma.f64 (*.f64 b (sin.f64 a)) (fma.f64 b (sin.f64 a) (*.f64 (cos.f64 b) (cos.f64 a))) (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sin.f64 b) (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (pow.f64 (*.f64 b (sin.f64 a)) 2))) (fma.f64 b (sin.f64 a) (*.f64 (cos.f64 b) (cos.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))) (sin.f64 b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (sin.f64 b) (neg.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (sin.f64 b) 3) (pow.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))) (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 r (/.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))) (sin.f64 b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))) (*.f64 (sin.f64 b) r)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 (sin.f64 b) r)) (neg.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) 1) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (pow.f64 (cbrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 2)) (cbrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))) (sqrt.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (neg.f64 (sin.f64 b)) r) (neg.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 r (neg.f64 (sin.f64 b))) (neg.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 r) (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 3) (pow.f64 r 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 r 3) (pow.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a)))) r)) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 b (sin.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) b)) (cbrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) b)))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) b))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) b))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (sin.f64 a)) b))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 b (sin.f64 a)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 b (sin.f64 a)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 b (sin.f64 a))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 b (sin.f64 a))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 b (sin.f64 a)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 b (sin.f64 a)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (sin.f64 a)) b))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 b (sin.f64 a)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 b (sin.f64 a)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 b (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 b (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 b (sin.f64 a))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 b (sin.f64 a))) 1))))))

simplify98.0ms (0.5%)

Algorithm
egg-herbie
Rules
720×associate-*l/_binary64
592×associate-*r/_binary64
307×cancel-sign-sub-inv_binary64
288×distribute-rgt-neg-in_binary64
253×associate-/r/_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02132826
17292682
230562569
Stop Event
node limit
Counts
145 → 139
Calls
Call 1
Inputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)))) (pow.f64 b 4))) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b)))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b)))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (cos.f64 b) 3))) (*.f64 (pow.f64 (sin.f64 a) 4) (pow.f64 b 4)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b))))))
(*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b)))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b)))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (cos.f64 b) 3))) (*.f64 (pow.f64 (sin.f64 a) 4) (pow.f64 b 4)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b))))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (sin.f64 b) (*.f64 a b)) (pow.f64 (cos.f64 b) 2)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (pow.f64 b 2)) (pow.f64 (cos.f64 b) 3)))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (sin.f64 b) (*.f64 a b)) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (pow.f64 b 2)) (pow.f64 (cos.f64 b) 3)))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 b) b) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) b) (pow.f64 (cos.f64 b) 2))) (/.f64 (*.f64 b (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (pow.f64 b 2)) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)))) (pow.f64 a 3))) (/.f64 (*.f64 (sin.f64 b) (*.f64 a b)) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 b r) (cos.f64 a))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2)))) (pow.f64 b 4))))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b)))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3))))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (*.f64 (pow.f64 (cos.f64 b) 3) r))) (*.f64 (pow.f64 (sin.f64 a) 4) (pow.f64 b 4)))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b)))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3))))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (*.f64 (pow.f64 (cos.f64 b) 3) r))) (*.f64 (pow.f64 (sin.f64 a) 4) (pow.f64 b 4)))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(+.f64 (/.f64 (*.f64 (sin.f64 b) (*.f64 a (*.f64 b r))) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))) (pow.f64 a 2))) (/.f64 (*.f64 (sin.f64 b) (*.f64 a (*.f64 r b))) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))) (pow.f64 a 2))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 b) (*.f64 b r)) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) (*.f64 r b)) (pow.f64 (cos.f64 b) 2))) (/.f64 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))) b) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) (*.f64 a (*.f64 r b))) (pow.f64 (cos.f64 b) 2)))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(*.f64 a b)
(+.f64 (*.f64 a b) (*.f64 -1/6 (*.f64 (pow.f64 a 3) b)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 1/120 (*.f64 (pow.f64 a 5) b)) (*.f64 -1/6 (*.f64 (pow.f64 a 3) b))))
(+.f64 (*.f64 a b) (+.f64 (*.f64 1/120 (*.f64 (pow.f64 a 5) b)) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 a 3) b)) (*.f64 -1/5040 (*.f64 (pow.f64 a 7) b)))))
Outputs
(/.f64 b (cos.f64 a))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))
(+.f64 (/.f64 b (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b))))
(+.f64 (/.f64 b (cos.f64 a)) (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b))))
(+.f64 (/.f64 b (cos.f64 a)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)))) (pow.f64 b 4))) (+.f64 (*.f64 (-.f64 (*.f64 1/2 (/.f64 1 (cos.f64 a))) (+.f64 (*.f64 1/6 (/.f64 1 (cos.f64 a))) (*.f64 -1 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3)) (/.f64 (*.f64 (sin.f64 a) (pow.f64 b 2)) (pow.f64 (cos.f64 a) 2)))))
(+.f64 (/.f64 b (cos.f64 a)) (fma.f64 -1 (*.f64 (fma.f64 -1 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))))) (*.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)))) (pow.f64 b 4)) (fma.f64 (-.f64 (/.f64 1/2 (cos.f64 a)) (+.f64 (/.f64 1/6 (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 3) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b b))))))
(+.f64 (/.f64 b (cos.f64 a)) (-.f64 (fma.f64 (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3))) (pow.f64 b 3) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b))) (*.f64 (fma.f64 -1/2 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 (neg.f64 (sin.f64 a)) (-.f64 (*.f64 (/.f64 1 (cos.f64 a)) 1/3) (/.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) (pow.f64 (cos.f64 a) 3)))) (cos.f64 a))) (pow.f64 b 4))))
(+.f64 (/.f64 b (cos.f64 a)) (-.f64 (*.f64 (*.f64 b b) (+.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))) b))) (*.f64 (-.f64 (/.f64 (*.f64 (sin.f64 a) -1/2) (pow.f64 (cos.f64 a) 2)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (+.f64 (/.f64 1/3 (cos.f64 a)) (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3))))) (pow.f64 b 4))))
(*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b)))
(neg.f64 (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a))))
(/.f64 (neg.f64 (sin.f64 b)) (*.f64 b (sin.f64 a)))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b))))
(*.f64 -1 (+.f64 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (cos.f64 b)))) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a)))))
(neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (cos.f64 b) b)) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a)))))
(neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (cos.f64 b) b)) (/.f64 (/.f64 (sin.f64 b) b) (sin.f64 a))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b)))))
(fma.f64 -1 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (cos.f64 b)))) (*.f64 -1 (+.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2)) (pow.f64 b 3))) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a))))))
(-.f64 (neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (pow.f64 (cos.f64 a) 2) (/.f64 (pow.f64 b 3) (pow.f64 (cos.f64 b) 2))) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a))))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (cos.f64 b) b))))
(-.f64 (*.f64 (/.f64 (neg.f64 (sin.f64 b)) (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2))) (*.f64 (cos.f64 a) (cos.f64 b))) (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 b 3)) (pow.f64 (cos.f64 a) 2)) (/.f64 (/.f64 (sin.f64 b) b) (sin.f64 a))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (cos.f64 b) 3))) (*.f64 (pow.f64 (sin.f64 a) 4) (pow.f64 b 4)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b))))))
(fma.f64 -1 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (cos.f64 b)))) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (cos.f64 b) 3))) (*.f64 (pow.f64 b 4) (pow.f64 (sin.f64 a) 4))) (*.f64 -1 (+.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2)) (pow.f64 b 3))) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a)))))))
(-.f64 (-.f64 (neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (pow.f64 (cos.f64 a) 2) (/.f64 (pow.f64 b 3) (pow.f64 (cos.f64 b) 2))) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a))))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 4)) (/.f64 (pow.f64 (cos.f64 b) 3) (/.f64 (pow.f64 b 4) (pow.f64 (cos.f64 a) 3))))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (cos.f64 b) b))))
(-.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (neg.f64 (/.f64 (cos.f64 b) b))) (/.f64 (*.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 b) 3)) (neg.f64 (pow.f64 (cos.f64 a) 3))) (*.f64 (pow.f64 b 4) (pow.f64 (sin.f64 a) 4)))) (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 b 3)) (pow.f64 (cos.f64 a) 2)) (/.f64 (/.f64 (sin.f64 b) b) (sin.f64 a))))
(*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b)))
(neg.f64 (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a))))
(/.f64 (neg.f64 (sin.f64 b)) (*.f64 b (sin.f64 a)))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b))))
(*.f64 -1 (+.f64 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (cos.f64 b)))) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a)))))
(neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (cos.f64 b) b)) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a)))))
(neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (cos.f64 b) b)) (/.f64 (/.f64 (sin.f64 b) b) (sin.f64 a))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b)))))
(fma.f64 -1 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (cos.f64 b)))) (*.f64 -1 (+.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2)) (pow.f64 b 3))) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a))))))
(-.f64 (neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (pow.f64 (cos.f64 a) 2) (/.f64 (pow.f64 b 3) (pow.f64 (cos.f64 b) 2))) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a))))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (cos.f64 b) b))))
(-.f64 (*.f64 (/.f64 (neg.f64 (sin.f64 b)) (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2))) (*.f64 (cos.f64 a) (cos.f64 b))) (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 b 3)) (pow.f64 (cos.f64 a) 2)) (/.f64 (/.f64 (sin.f64 b) b) (sin.f64 a))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (cos.f64 b))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (cos.f64 b) 3))) (*.f64 (pow.f64 (sin.f64 a) 4) (pow.f64 b 4)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))) (*.f64 -1 (/.f64 (sin.f64 b) (*.f64 (sin.f64 a) b))))))
(fma.f64 -1 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (cos.f64 b)))) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (cos.f64 b) 3))) (*.f64 (pow.f64 b 4) (pow.f64 (sin.f64 a) 4))) (*.f64 -1 (+.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (pow.f64 (cos.f64 b) 2)) (pow.f64 b 3))) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a)))))))
(-.f64 (-.f64 (neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (pow.f64 (cos.f64 a) 2) (/.f64 (pow.f64 b 3) (pow.f64 (cos.f64 b) 2))) (/.f64 (sin.f64 b) (*.f64 b (sin.f64 a))))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 4)) (/.f64 (pow.f64 (cos.f64 b) 3) (/.f64 (pow.f64 b 4) (pow.f64 (cos.f64 a) 3))))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (cos.f64 b) b))))
(-.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (neg.f64 (/.f64 (cos.f64 b) b))) (/.f64 (*.f64 (*.f64 (sin.f64 b) (pow.f64 (cos.f64 b) 3)) (neg.f64 (pow.f64 (cos.f64 a) 3))) (*.f64 (pow.f64 b 4) (pow.f64 (sin.f64 a) 4)))) (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 b 3)) (pow.f64 (cos.f64 a) 2)) (/.f64 (/.f64 (sin.f64 b) b) (sin.f64 a))))
(/.f64 (sin.f64 b) (cos.f64 b))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (sin.f64 b) (*.f64 a b)) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (sin.f64 b) (*.f64 b a)) (pow.f64 (cos.f64 b) 2)))
(+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (sin.f64 b) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 b a))))
(*.f64 (+.f64 (/.f64 (*.f64 b a) (cos.f64 b)) 1) (/.f64 (sin.f64 b) (cos.f64 b)))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (pow.f64 b 2)) (pow.f64 (cos.f64 b) 3)))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (sin.f64 b) (*.f64 a b)) (pow.f64 (cos.f64 b) 2))))
(fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (*.f64 (*.f64 b b) (sin.f64 b)) (pow.f64 (cos.f64 b) 3))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (/.f64 (*.f64 (sin.f64 b) (*.f64 b a)) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 b a))) (fma.f64 (neg.f64 (*.f64 a a)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (*.f64 b b) (/.f64 (pow.f64 (cos.f64 b) 3) (sin.f64 b)))) (/.f64 (sin.f64 b) (cos.f64 b))))
(-.f64 (*.f64 (+.f64 (/.f64 (*.f64 b a) (cos.f64 b)) 1) (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 a (*.f64 a (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 -1/2 (/.f64 (*.f64 b b) (pow.f64 (cos.f64 b) 2)))))))
(+.f64 (*.f64 -1 (*.f64 (pow.f64 a 2) (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (pow.f64 b 2)) (pow.f64 (cos.f64 b) 3)))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 b) b) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) b) (pow.f64 (cos.f64 b) 2))) (/.f64 (*.f64 b (+.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (pow.f64 b 2)) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)))) (pow.f64 a 3))) (/.f64 (*.f64 (sin.f64 b) (*.f64 a b)) (pow.f64 (cos.f64 b) 2)))))
(fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (*.f64 (*.f64 b b) (sin.f64 b)) (pow.f64 (cos.f64 b) 3))))) (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (fma.f64 -1 (*.f64 (fma.f64 1/6 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (cos.f64 b) 2) b)) (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (cos.f64 b) 2) b)) (/.f64 (*.f64 b (fma.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b)) (neg.f64 (/.f64 (*.f64 (*.f64 b b) (sin.f64 b)) (pow.f64 (cos.f64 b) 3))))) (cos.f64 b)))) (pow.f64 a 3)) (/.f64 (*.f64 (sin.f64 b) (*.f64 b a)) (pow.f64 (cos.f64 b) 2)))))
(+.f64 (-.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 b a))) (*.f64 (+.f64 (*.f64 (/.f64 b (cos.f64 b)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (*.f64 b b) (/.f64 (pow.f64 (cos.f64 b) 3) (sin.f64 b))))) (*.f64 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (cos.f64 b) 2) b)) -1/3)) (pow.f64 a 3))) (fma.f64 (neg.f64 (*.f64 a a)) (-.f64 (*.f64 -1/2 (/.f64 (sin.f64 b) (cos.f64 b))) (/.f64 (*.f64 b b) (/.f64 (pow.f64 (cos.f64 b) 3) (sin.f64 b)))) (/.f64 (sin.f64 b) (cos.f64 b))))
(-.f64 (-.f64 (*.f64 (+.f64 (/.f64 (*.f64 b a) (cos.f64 b)) 1) (/.f64 (sin.f64 b) (cos.f64 b))) (*.f64 a (*.f64 a (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 -1/2 (/.f64 (*.f64 b b) (pow.f64 (cos.f64 b) 2))))))) (*.f64 (+.f64 (*.f64 (/.f64 b (cos.f64 b)) (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (-.f64 -1/2 (/.f64 (*.f64 b b) (pow.f64 (cos.f64 b) 2))))) (/.f64 (*.f64 (*.f64 b (sin.f64 b)) -1/3) (pow.f64 (cos.f64 b) 2))) (pow.f64 a 3)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 (/.f64 b (cos.f64 a)) r)
(*.f64 (/.f64 r (cos.f64 a)) b)
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 (pow.f64 b 2) r)) (pow.f64 (cos.f64 a) 2)) (/.f64 (*.f64 r b) (cos.f64 a)))
(+.f64 (/.f64 (*.f64 b r) (cos.f64 a)) (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))))
(+.f64 (*.f64 (/.f64 b (cos.f64 a)) r) (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (*.f64 b b) r)))
(+.f64 (*.f64 (/.f64 r (cos.f64 a)) b) (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))) (+.f64 (/.f64 (*.f64 b r) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (*.f64 b b) r)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 b (cos.f64 a)) r)))
(+.f64 (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (*.f64 (/.f64 r (cos.f64 a)) b)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (+.f64 (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3)))))) (cos.f64 a))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 a) r) (pow.f64 (cos.f64 a) 2)))) (pow.f64 b 4))))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (*.f64 b b) r))) (+.f64 (/.f64 (*.f64 b r) (cos.f64 a)) (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))) (neg.f64 (*.f64 (pow.f64 b 4) (fma.f64 -1 (/.f64 (sin.f64 a) (/.f64 (cos.f64 a) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (fma.f64 -1/2 (/.f64 r (cos.f64 a)) (neg.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (/.f64 (pow.f64 (cos.f64 a) 3) r))))))) (*.f64 -1/2 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) r)))))))))
(+.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 (*.f64 b b) r)) (-.f64 (fma.f64 (pow.f64 b 3) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))) (*.f64 (/.f64 b (cos.f64 a)) r)) (*.f64 (pow.f64 b 4) (-.f64 (*.f64 -1/2 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) r)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (-.f64 (*.f64 (/.f64 r (cos.f64 a)) 1/3) (/.f64 (*.f64 (neg.f64 (pow.f64 (sin.f64 a) 2)) r) (pow.f64 (cos.f64 a) 3))))))))
(-.f64 (+.f64 (*.f64 (*.f64 (/.f64 (sin.f64 a) (pow.f64 (cos.f64 a) 2)) (*.f64 b b)) r) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (*.f64 (/.f64 r (cos.f64 a)) b))) (*.f64 (pow.f64 b 4) (-.f64 (/.f64 (*.f64 -1/2 (*.f64 (sin.f64 a) r)) (pow.f64 (cos.f64 a) 2)) (*.f64 (/.f64 (sin.f64 a) (cos.f64 a)) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r))))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b)))
(neg.f64 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b)))
(*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (neg.f64 (/.f64 r b)))
(*.f64 (/.f64 (/.f64 (sin.f64 b) b) (sin.f64 a)) (neg.f64 r))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))))
(*.f64 -1 (+.f64 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r)))) (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b))))
(neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (*.f64 (cos.f64 b) r) b)) (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b))))
(neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 b) (*.f64 r (cos.f64 a))) (*.f64 b b)) (/.f64 (*.f64 (/.f64 r b) (sin.f64 b)) (sin.f64 a))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3))))))
(fma.f64 -1 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r)))) (*.f64 -1 (+.f64 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b)) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r)) (pow.f64 b 3))))))
(-.f64 (neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (*.f64 (cos.f64 b) r) b)) (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b)))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 b 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r)) (pow.f64 (sin.f64 a) 3))))
(-.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (neg.f64 (*.f64 (pow.f64 (cos.f64 b) 2) r)) (/.f64 (pow.f64 b 3) (pow.f64 (cos.f64 a) 2)))) (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 b) (*.f64 r (cos.f64 a))) (*.f64 b b)) (/.f64 (*.f64 (/.f64 r b) (sin.f64 b)) (sin.f64 a))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (*.f64 (pow.f64 (cos.f64 b) 3) r))) (*.f64 (pow.f64 (sin.f64 a) 4) (pow.f64 b 4)))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))))))
(fma.f64 -1 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r)))) (fma.f64 -1 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b)) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (*.f64 (pow.f64 (cos.f64 b) 3) r))) (*.f64 (pow.f64 b 4) (pow.f64 (sin.f64 a) 4))) (neg.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r)) (pow.f64 b 3)))))))
(*.f64 -1 (+.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (*.f64 (cos.f64 b) r) b)) (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b))) (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 4)) (/.f64 (pow.f64 (cos.f64 a) 3) (/.f64 (pow.f64 b 4) (*.f64 (pow.f64 (cos.f64 b) 3) r))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 b 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r)) (pow.f64 (sin.f64 a) 3))))))
(-.f64 (neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 b) (*.f64 r (cos.f64 a))) (*.f64 b b)) (/.f64 (*.f64 (/.f64 r b) (sin.f64 b)) (sin.f64 a)))) (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 4)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (cos.f64 b) 3)) (/.f64 (pow.f64 b 4) r)) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 (*.f64 (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 b 3)) (pow.f64 (cos.f64 a) 2)) r))))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b)))
(neg.f64 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b)))
(*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (neg.f64 (/.f64 r b)))
(*.f64 (/.f64 (/.f64 (sin.f64 b) b) (sin.f64 a)) (neg.f64 r))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))))
(*.f64 -1 (+.f64 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r)))) (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b))))
(neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (*.f64 (cos.f64 b) r) b)) (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b))))
(neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 b) (*.f64 r (cos.f64 a))) (*.f64 b b)) (/.f64 (*.f64 (/.f64 r b) (sin.f64 b)) (sin.f64 a))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3))))))
(fma.f64 -1 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r)))) (*.f64 -1 (+.f64 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b)) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r)) (pow.f64 b 3))))))
(-.f64 (neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (*.f64 (cos.f64 b) r) b)) (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b)))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 b 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r)) (pow.f64 (sin.f64 a) 3))))
(-.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (neg.f64 (*.f64 (pow.f64 (cos.f64 b) 2) r)) (/.f64 (pow.f64 b 3) (pow.f64 (cos.f64 a) 2)))) (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 b) (*.f64 r (cos.f64 a))) (*.f64 b b)) (/.f64 (*.f64 (/.f64 r b) (sin.f64 b)) (sin.f64 a))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r))) (*.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 b 2)))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (*.f64 (sin.f64 a) b))) (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (*.f64 (pow.f64 (cos.f64 b) 3) r))) (*.f64 (pow.f64 (sin.f64 a) 4) (pow.f64 b 4)))) (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r))) (*.f64 (pow.f64 (sin.f64 a) 3) (pow.f64 b 3)))))))
(fma.f64 -1 (/.f64 (sin.f64 b) (/.f64 (*.f64 (*.f64 b b) (pow.f64 (sin.f64 a) 2)) (*.f64 (cos.f64 a) (*.f64 (cos.f64 b) r)))) (fma.f64 -1 (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b)) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (pow.f64 (cos.f64 a) 3) (*.f64 (pow.f64 (cos.f64 b) 3) r))) (*.f64 (pow.f64 b 4) (pow.f64 (sin.f64 a) 4))) (neg.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r)) (pow.f64 b 3)))))))
(*.f64 -1 (+.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (*.f64 (/.f64 (cos.f64 a) b) (/.f64 (*.f64 (cos.f64 b) r) b)) (*.f64 (/.f64 (sin.f64 b) (sin.f64 a)) (/.f64 r b))) (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 4)) (/.f64 (pow.f64 (cos.f64 a) 3) (/.f64 (pow.f64 b 4) (*.f64 (pow.f64 (cos.f64 b) 3) r))) (*.f64 (/.f64 (sin.f64 b) (pow.f64 b 3)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 2) (*.f64 (pow.f64 (cos.f64 b) 2) r)) (pow.f64 (sin.f64 a) 3))))))
(-.f64 (neg.f64 (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 2)) (/.f64 (*.f64 (cos.f64 b) (*.f64 r (cos.f64 a))) (*.f64 b b)) (/.f64 (*.f64 (/.f64 r b) (sin.f64 b)) (sin.f64 a)))) (fma.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 4)) (/.f64 (*.f64 (pow.f64 (cos.f64 a) 3) (pow.f64 (cos.f64 b) 3)) (/.f64 (pow.f64 b 4) r)) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (sin.f64 a) 3)) (*.f64 (*.f64 (/.f64 (pow.f64 (cos.f64 b) 2) (pow.f64 b 3)) (pow.f64 (cos.f64 a) 2)) r))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(+.f64 (/.f64 (*.f64 (sin.f64 b) (*.f64 a (*.f64 b r))) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (/.f64 (*.f64 (sin.f64 b) (*.f64 (*.f64 a r) b)) (pow.f64 (cos.f64 b) 2)))
(+.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (/.f64 (*.f64 (*.f64 b a) (*.f64 (sin.f64 b) r)) (pow.f64 (cos.f64 b) 2)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 r (/.f64 (*.f64 b (*.f64 a r)) (cos.f64 b))))
(+.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))) (pow.f64 a 2))) (/.f64 (*.f64 (sin.f64 b) (*.f64 a (*.f64 r b))) (pow.f64 (cos.f64 b) 2))))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 b) 3)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (/.f64 (*.f64 (sin.f64 b) (*.f64 (*.f64 a r) b)) (pow.f64 (cos.f64 b) 2))))
(+.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (-.f64 (/.f64 (*.f64 (*.f64 b a) (*.f64 (sin.f64 b) r)) (pow.f64 (cos.f64 b) 2)) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (cos.f64 b) 3)) (*.f64 (*.f64 b b) r))))))
(-.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 r (/.f64 (*.f64 b (*.f64 a r)) (cos.f64 b)))) (*.f64 (*.f64 a a) (*.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (-.f64 -1/2 (/.f64 (*.f64 b b) (pow.f64 (cos.f64 b) 2))))))
(+.f64 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (+.f64 (*.f64 -1 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))) (pow.f64 a 2))) (+.f64 (*.f64 -1 (*.f64 (pow.f64 a 3) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (sin.f64 b) (*.f64 b r)) (pow.f64 (cos.f64 b) 2))) (+.f64 (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) (*.f64 r b)) (pow.f64 (cos.f64 b) 2))) (/.f64 (*.f64 (+.f64 (*.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 b) 3))) (*.f64 -1/2 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))) b) (cos.f64 b)))))) (/.f64 (*.f64 (sin.f64 b) (*.f64 a (*.f64 r b))) (pow.f64 (cos.f64 b) 2)))))
(+.f64 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)) (fma.f64 -1 (*.f64 (*.f64 a a) (fma.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 b) 3)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))))) (fma.f64 -1 (*.f64 (pow.f64 a 3) (fma.f64 1/6 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 b r))) (fma.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 b r))) (/.f64 (fma.f64 -1 (/.f64 (*.f64 (sin.f64 b) (*.f64 (*.f64 b b) r)) (pow.f64 (cos.f64 b) 3)) (*.f64 -1/2 (/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r)))) (/.f64 (cos.f64 b) b))))) (/.f64 (*.f64 (sin.f64 b) (*.f64 (*.f64 a r) b)) (pow.f64 (cos.f64 b) 2)))))
(+.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (-.f64 (-.f64 (/.f64 (*.f64 (*.f64 b a) (*.f64 (sin.f64 b) r)) (pow.f64 (cos.f64 b) 2)) (*.f64 (pow.f64 a 3) (+.f64 (*.f64 (/.f64 (-.f64 (*.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (cos.f64 b) 3)) (*.f64 (*.f64 b b) r))) (cos.f64 b)) b) (*.f64 (*.f64 (/.f64 (sin.f64 b) (pow.f64 (cos.f64 b) 2)) (*.f64 b r)) -1/3)))) (*.f64 (*.f64 a a) (-.f64 (*.f64 -1/2 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)) (*.f64 (/.f64 (sin.f64 b) (pow.f64 (cos.f64 b) 3)) (*.f64 (*.f64 b b) r))))))
(+.f64 (*.f64 (*.f64 a a) (-.f64 (neg.f64 (*.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (-.f64 -1/2 (/.f64 (*.f64 b b) (pow.f64 (cos.f64 b) 2))))) (*.f64 (+.f64 (*.f64 (/.f64 b (cos.f64 b)) (*.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r) (-.f64 -1/2 (/.f64 (*.f64 b b) (pow.f64 (cos.f64 b) 2))))) (/.f64 (*.f64 (sin.f64 b) -1/3) (/.f64 (pow.f64 (cos.f64 b) 2) (*.f64 b r)))) a))) (*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (+.f64 r (/.f64 (*.f64 b (*.f64 a r)) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) b)))
(/.f64 (sin.f64 b) (/.f64 (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 b (sin.f64 a))) r))
(*.f64 a b)
(*.f64 b a)
(+.f64 (*.f64 a b) (*.f64 -1/6 (*.f64 (pow.f64 a 3) b)))
(fma.f64 a b (*.f64 -1/6 (*.f64 b (pow.f64 a 3))))
(*.f64 b (+.f64 a (*.f64 (pow.f64 a 3) -1/6)))
(+.f64 (*.f64 a b) (+.f64 (*.f64 1/120 (*.f64 (pow.f64 a 5) b)) (*.f64 -1/6 (*.f64 (pow.f64 a 3) b))))
(fma.f64 a b (fma.f64 1/120 (*.f64 b (pow.f64 a 5)) (*.f64 -1/6 (*.f64 b (pow.f64 a 3)))))
(fma.f64 b a (*.f64 b (+.f64 (*.f64 (pow.f64 a 3) -1/6) (*.f64 1/120 (pow.f64 a 5)))))
(*.f64 b (+.f64 (*.f64 (pow.f64 a 3) -1/6) (+.f64 a (*.f64 1/120 (pow.f64 a 5)))))
(+.f64 (*.f64 a b) (+.f64 (*.f64 1/120 (*.f64 (pow.f64 a 5) b)) (+.f64 (*.f64 -1/6 (*.f64 (pow.f64 a 3) b)) (*.f64 -1/5040 (*.f64 (pow.f64 a 7) b)))))
(fma.f64 a b (fma.f64 1/120 (*.f64 b (pow.f64 a 5)) (fma.f64 -1/6 (*.f64 b (pow.f64 a 3)) (*.f64 -1/5040 (*.f64 b (pow.f64 a 7))))))
(fma.f64 b a (fma.f64 1/120 (*.f64 b (pow.f64 a 5)) (*.f64 b (+.f64 (*.f64 (pow.f64 a 3) -1/6) (*.f64 -1/5040 (pow.f64 a 7))))))
(*.f64 b (+.f64 (+.f64 (*.f64 (pow.f64 a 3) -1/6) (*.f64 -1/5040 (pow.f64 a 7))) (+.f64 a (*.f64 1/120 (pow.f64 a 5)))))

eval867.0ms (4%)

Compiler

Compiled 25461 to 7997 computations (68.6% saved)

prune389.0ms (1.8%)

Pruning

84 alts after pruning (75 fresh and 9 done)

PrunedKeptTotal
New90826934
Fresh184967
Picked011
Done2810
Total928841012
Error
0.0b
Counts
1012 → 84
Alt Table
Click to see full alt table
StatusErrorProgram
55.1b
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
41.5b
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
53.8b
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
31.6b
(/.f64 b (/.f64 (cos.f64 a) r))
53.5b
(*.f64 r (log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
31.5b
(/.f64 (*.f64 r b) (cos.f64 a))
30.0b
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
56.9b
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
27.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
53.8b
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
0.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 3) (*.f64 (sin.f64 b) (sin.f64 a)))))
44.4b
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1))
17.7b
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
28.8b
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
54.5b
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
29.6b
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
30.0b
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
30.0b
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
0.4b
(*.f64 r (pow.f64 (-.f64 (/.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (sin.f64 b)) (/.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (sin.f64 b))) -1))
41.0b
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
30.0b
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
53.8b
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
52.8b
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
54.3b
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
23.7b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
32.0b
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
17.7b
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
23.7b
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))
30.9b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
54.8b
(*.f64 r (log.f64 1))
0.4b
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
37.3b
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
40.7b
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))
55.6b
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
17.6b
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))
28.7b
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
0.4b
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
53.8b
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
31.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
17.7b
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
23.8b
(expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
17.6b
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
25.0b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
55.6b
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
53.5b
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
0.5b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (cbrt.f64 (*.f64 (pow.f64 (cos.f64 b) 3) (pow.f64 (cos.f64 a) 3))))))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
17.6b
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
28.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
40.2b
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
30.1b
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 b)))))
44.0b
(*.f64 r b)
0.4b
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (expm1.f64 (log1p.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
17.6b
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
31.5b
(*.f64 (/.f64 r (cos.f64 a)) b)
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3)))))
26.6b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
53.6b
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
18.2b
(*.f64 r (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 3) -1))
33.2b
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))))
31.7b
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
0.4b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
30.6b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
0.6b
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))))
18.2b
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3))
52.6b
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
31.5b
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
0.4b
(*.f64 r (pow.f64 (/.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))) (sin.f64 b)) -1))
54.6b
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
52.6b
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
31.9b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
17.8b
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
35.6b
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)
0.4b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
17.9b
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))
31.6b
(/.f64 r (/.f64 (cos.f64 a) b))
0.3b
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))))
18.2b
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)
30.5b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
53.8b
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
17.5b
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
31.5b
(*.f64 r (/.f64 b (cos.f64 a)))
0.6b
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (log.f64 (+.f64 1 (expm1.f64 (*.f64 (cos.f64 b) (cos.f64 a))))) (*.f64 (sin.f64 b) (sin.f64 a)))))
Compiler

Compiled 1321 to 919 computations (30.4% saved)

regimes1.4s (6.3%)

Counts
165 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 b)))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 a) 2))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 b) 2))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))
(expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))
(cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))
(sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(*.f64 r (log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
(pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))))
(*.f64 r (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 3) -1))
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (cos.f64 b) (cos.f64 a) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
(*.f64 r (pow.f64 (/.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))) (sin.f64 b)) -1))
(+.f64 (/.f64 (*.f64 (pow.f64 (sin.f64 b) 2) (*.f64 a r)) (pow.f64 (cos.f64 b) 2)) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (log1p.f64 (expm1.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (expm1.f64 (log1p.f64 (*.f64 (sin.f64 b) (sin.f64 a)))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 3) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (cbrt.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cbrt.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (log.f64 (+.f64 1 (expm1.f64 (*.f64 (cos.f64 b) (cos.f64 a))))) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (pow.f64 (-.f64 (/.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (sin.f64 b)) (/.f64 (*.f64 (sin.f64 b) (sin.f64 a)) (sin.f64 b))) -1))
(pow.f64 (sqrt.f64 (/.f64 r (/.f64 (fma.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b) (*.f64 (fma.f64 -1/2 (*.f64 b b) 1) (cos.f64 a))) (sin.f64 b)))) 2)
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (cbrt.f64 (*.f64 (pow.f64 (cos.f64 b) 3) (pow.f64 (cos.f64 a) 3))))))
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (*.f64 (neg.f64 (sin.f64 b)) (sin.f64 a)))))
(*.f64 r (+.f64 (/.f64 (sin.f64 b) (cos.f64 b)) (*.f64 a (-.f64 (/.f64 (pow.f64 (sin.f64 b) 2) (pow.f64 (cos.f64 b) 2)) (*.f64 (-.f64 (*.f64 (/.f64 -1/2 (cos.f64 b)) (sin.f64 b)) (pow.f64 (/.f64 (sin.f64 b) (cos.f64 b)) 3)) a)))))
(+.f64 (/.f64 (sin.f64 a) (/.f64 (pow.f64 (cos.f64 a) 2) (*.f64 b (*.f64 b r)))) (fma.f64 (pow.f64 b 3) (fma.f64 (/.f64 r (cos.f64 a)) 1/3 (*.f64 (/.f64 (pow.f64 (sin.f64 a) 2) (pow.f64 (cos.f64 a) 3)) r)) (*.f64 (/.f64 b (cos.f64 a)) r)))
(+.f64 (/.f64 (*.f64 (sin.f64 a) (*.f64 r (pow.f64 b 2))) (pow.f64 (cos.f64 a) 2)) (+.f64 (/.f64 (*.f64 r b) (cos.f64 a)) (*.f64 (pow.f64 b 3) (-.f64 (*.f64 -1/6 (/.f64 r (cos.f64 a))) (+.f64 (*.f64 -1/2 (/.f64 r (cos.f64 a))) (*.f64 -1 (/.f64 (*.f64 (pow.f64 (sin.f64 a) 2) r) (pow.f64 (cos.f64 a) 3))))))))
(*.f64 r (/.f64 (sin.f64 b) (/.f64 (-.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 3) (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 3)) (+.f64 (pow.f64 (*.f64 (cos.f64 b) (cos.f64 a)) 2) (+.f64 (pow.f64 (*.f64 (sin.f64 b) (sin.f64 a)) 2) (*.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))) (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (cos.f64 a)) (cos.f64 b))))) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b))) (sqrt.f64 (sin.f64 a)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 a)) (sin.f64 b)) (sqrt.f64 (sin.f64 a)))))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b))))) (fma.f64 (neg.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a))) (sqrt.f64 (sin.f64 b)) (*.f64 (*.f64 (sqrt.f64 (sin.f64 b)) (sin.f64 a)) (sqrt.f64 (sin.f64 b)))))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2))))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (cos.f64 b) (cos.f64 a) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (sqrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2)))) (fma.f64 (neg.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a))) (pow.f64 (cbrt.f64 (sin.f64 b)) 2) (*.f64 (*.f64 (cbrt.f64 (sin.f64 b)) (sin.f64 a)) (pow.f64 (cbrt.f64 (sin.f64 b)) 2))))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (fma.f64 (pow.f64 (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) 2) (cbrt.f64 (*.f64 (cos.f64 b) (cos.f64 a))) (neg.f64 (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2)))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a)))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2) (*.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) (pow.f64 (cbrt.f64 (*.f64 (sin.f64 b) (sin.f64 a))) 2))))))
Outputs
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))))
Calls

6 calls:

295.0ms
a
262.0ms
b
202.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
188.0ms
r
158.0ms
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
Results
ErrorSegmentsBranch
0.3b1r
0.3b1a
0.3b1b
0.3b1(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
0.3b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
0.3b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Compiler

Compiled 2467 to 772 computations (68.7% saved)

regimes1.5s (7%)

Counts
138 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 b)))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 a) 2))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 b) 2))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))
(expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))
(cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))
(sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(*.f64 r (log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
(pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))))
(*.f64 r (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 3) -1))
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
Outputs
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
Calls

6 calls:

752.0ms
r
206.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
158.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
115.0ms
b
114.0ms
a
Results
ErrorSegmentsBranch
0.4b1r
0.4b1a
0.4b1b
0.4b1(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
0.4b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
0.4b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Compiler

Compiled 1614 to 509 computations (68.5% saved)

regimes711.0ms (3.3%)

Counts
137 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 b)))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 a) 2))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 b) 2))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))
(expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))
(cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))
(sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(*.f64 r (log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
(pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))))
(*.f64 r (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 3) -1))
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
Outputs
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
Calls

6 calls:

147.0ms
b
136.0ms
a
98.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
91.0ms
r
87.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Results
ErrorSegmentsBranch
0.4b1r
0.4b1a
0.4b1b
0.4b1(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
0.4b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
0.4b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Compiler

Compiled 1598 to 506 computations (68.3% saved)

regimes791.0ms (3.7%)

Counts
136 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 b)))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 a) 2))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 b) 2))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))
(expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))
(cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))
(sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(*.f64 r (log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
(pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))))
(*.f64 r (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 3) -1))
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (/.f64 (*.f64 (sin.f64 b) r) (sqrt.f64 (cos.f64 (+.f64 b a)))) (sqrt.f64 (cos.f64 (+.f64 b a))))
Outputs
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
Calls

6 calls:

154.0ms
r
153.0ms
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
121.0ms
a
105.0ms
b
91.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Results
ErrorSegmentsBranch
0.4b1r
0.4b1a
0.4b1b
0.4b1(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
0.4b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
0.4b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Compiler

Compiled 1582 to 503 computations (68.2% saved)

regimes837.0ms (3.9%)

Counts
133 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 b)))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 a) 2))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 b) 2))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))
(expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))
(cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))
(sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(*.f64 r (log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
(pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))))
(*.f64 r (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 3) -1))
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
Outputs
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
Calls

6 calls:

156.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
151.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
115.0ms
a
114.0ms
b
112.0ms
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
Results
ErrorSegmentsBranch
0.4b1r
0.4b1a
0.4b1b
0.4b1(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
0.4b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
0.4b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Compiler

Compiled 1534 to 500 computations (67.4% saved)

regimes723.0ms (3.4%)

Counts
132 → 3
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 b)))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 a) 2))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 b) 2))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))
(expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))
(cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))
(sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(*.f64 r (log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
(pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))))
(*.f64 r (pow.f64 (pow.f64 (cbrt.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b))) 3) -1))
Outputs
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)))))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
Calls

6 calls:

247.0ms
a
85.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
83.0ms
b
80.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
76.0ms
r
Results
ErrorSegmentsBranch
17.5b1r
15.9b3a
17.5b1b
17.5b1(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
17.5b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
17.5b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Compiler

Compiled 1518 to 495 computations (67.4% saved)

bsearch139.0ms (0.6%)

Algorithm
binary-search
Steps
TimeLeftRight
70.0ms
0.002714775271232511
30.794776646147486
68.0ms
-120634.49979016042
-8.596803228628322e-10
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes1.0s (4.8%)

Counts
130 → 3
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 b)))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 a) 2))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 b) 2))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))
(expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))
(cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))
(sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(*.f64 r (log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
(pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 a) (-.f64 (*.f64 (pow.f64 b 3) 1/6) b)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
Outputs
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
Calls

6 calls:

439.0ms
a
117.0ms
b
117.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
115.0ms
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
89.0ms
r
Results
ErrorSegmentsBranch
17.5b1r
15.9b3a
17.5b1b
17.5b1(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
17.5b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
17.5b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Compiler

Compiled 1478 to 475 computations (67.9% saved)

bsearch247.0ms (1.1%)

Algorithm
binary-search
Steps
TimeLeftRight
109.0ms
0.002714775271232511
30.794776646147486
135.0ms
-120634.49979016042
-8.596803228628322e-10
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes711.0ms (3.3%)

Counts
127 → 3
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 b)))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 a) 2))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 b) 2))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))
(expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))
(cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))
(sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(*.f64 r (log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
(pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (fma.f64 -1/2 (*.f64 a a) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (cos.f64 a) (*.f64 b (-.f64 (*.f64 (*.f64 (cos.f64 a) -1/2) b) (sin.f64 a))))))
Outputs
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a))))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
Calls

6 calls:

211.0ms
a
103.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
95.0ms
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
85.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
77.0ms
b
Results
ErrorSegmentsBranch
17.5b1r
15.9b3a
17.5b1b
17.5b1(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
17.5b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
17.5b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Compiler

Compiled 1410 to 445 computations (68.4% saved)

bsearch132.0ms (0.6%)

Algorithm
binary-search
Steps
TimeLeftRight
63.0ms
0.002714775271232511
30.794776646147486
68.0ms
-120634.49979016042
-8.596803228628322e-10
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes765.0ms (3.5%)

Counts
124 → 3
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 b (neg.f64 (sin.f64 a))) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 b)))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 a) 2))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 b) 2))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (-.f64 b a))))))
(expm1.f64 (log1p.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(/.f64 (/.f64 (*.f64 b r) (sqrt.f64 (cos.f64 a))) (sqrt.f64 (cos.f64 a)))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (log.f64 (exp.f64 (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a)))) 3))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 2)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (-.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (log1p.f64 (expm1.f64 (cos.f64 (+.f64 b a)))))))
(*.f64 r (neg.f64 (log.f64 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (neg.f64 (expm1.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -2)))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 3)
(*.f64 r (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3)))
(*.f64 r (sqrt.f64 (pow.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) 2)))
(cbrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3))
(sqrt.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 2))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (pow.f64 (cos.f64 (+.f64 b a)) 2))))
(pow.f64 (sqrt.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r)) 2)
(*.f64 r (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3))
(*.f64 r (log.f64 (/.f64 1 (exp.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))))
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))) 1))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (cbrt.f64 (cos.f64 (+.f64 b a))) 3))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (pow.f64 (sqrt.f64 (cos.f64 (+.f64 b a))) 2))))
(*.f64 r (neg.f64 (pow.f64 (cbrt.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))) 3)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 (sin.f64 b) (sin.f64 a)))))
(pow.f64 (pow.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r) 3) 1/3)
(*.f64 r (-.f64 (exp.f64 (log1p.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))) 1))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))) r))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 b (sin.f64 a))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
(*.f64 r (log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))))
Outputs
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b)))))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
Calls

6 calls:

306.0ms
a
118.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
81.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
74.0ms
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
74.0ms
r
Results
ErrorSegmentsBranch
17.5b1r
15.9b3a
17.5b1b
17.5b1(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
17.5b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
17.5b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Compiler

Compiled 1357 to 426 computations (68.6% saved)

bsearch141.0ms (0.7%)

Algorithm
binary-search
Steps
TimeLeftRight
71.0ms
0.002714775271232511
30.794776646147486
69.0ms
-120634.49979016042
-8.596803228628322e-10
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes317.0ms (1.5%)

Counts
68 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(*.f64 r (log.f64 (+.f64 (/.f64 b (cos.f64 a)) 1)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 -1 (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (-.f64 b a))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (+.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a)))))
(/.f64 (*.f64 (sin.f64 b) r) (neg.f64 (cos.f64 (+.f64 b a))))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (-.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (-.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (/.f64 1 (cos.f64 (+.f64 b a))) (sin.f64 b)))
(/.f64 1 (/.f64 (cos.f64 (+.f64 b a)) (*.f64 (sin.f64 b) r)))
(*.f64 r (*.f64 (sin.f64 b) (/.f64 1 (neg.f64 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 1/3 (*.f64 3 (cos.f64 (+.f64 b a))))))
(*.f64 r (/.f64 (sin.f64 b) (*.f64 3 (*.f64 1/3 (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 3 (*.f64 1/3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(*.f64 r (*.f64 1/3 (*.f64 3 (/.f64 (sin.f64 b) (cos.f64 (+.f64 b a))))))
(exp.f64 (log.f64 (*.f64 (/.f64 b (cos.f64 a)) r)))
(pow.f64 (cbrt.f64 (*.f64 (/.f64 b (cos.f64 a)) r)) 3)
(pow.f64 (pow.f64 (*.f64 (/.f64 b (cos.f64 a)) r) 3) 1/3)
(*.f64 r (pow.f64 (pow.f64 (/.f64 b (cos.f64 a)) 3) 1/3))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 b) (sin.f64 b)) a) -1))
(*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))
(*.f64 r (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1))
(*.f64 r (neg.f64 (pow.f64 (/.f64 (cos.f64 (+.f64 b a)) (sin.f64 b)) -1)))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 b) (*.f64 a (sin.f64 b)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (cos.f64 a) (*.f64 (sin.f64 a) b))))
(*.f64 r (/.f64 (sin.f64 b) (sqrt.f64 (+.f64 1/2 (*.f64 1/2 (cos.f64 (*.f64 2 (+.f64 b a))))))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 b b)) 1) (cos.f64 a)) (*.f64 (sin.f64 a) b))))
Outputs
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
Calls

6 calls:

61.0ms
b
57.0ms
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
48.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
46.0ms
a
45.0ms
(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Results
ErrorSegmentsBranch
17.5b1r
17.5b1a
17.5b1b
17.5b1(*.f64 r (/.f64 (sin.f64 b) (cos.f64 (+.f64 a b))))
17.5b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
17.5b1(/.f64 (sin.f64 b) (cos.f64 (+.f64 a b)))
Compiler

Compiled 670 to 224 computations (66.6% saved)

regimes58.0ms (0.3%)

Counts
29 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
Outputs
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
Calls

3 calls:

17.0ms
a
17.0ms
r
17.0ms
b
Results
ErrorSegmentsBranch
17.6b1r
17.6b1a
17.6b1b
Compiler

Compiled 215 to 68 computations (68.4% saved)

regimes145.0ms (0.7%)

Counts
28 → 3
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 b)) (sin.f64 b))
(*.f64 (/.f64 (sin.f64 b) (cos.f64 b)) r)
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (sin.f64 b) (/.f64 (cos.f64 b) r))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 b)))
(*.f64 r (neg.f64 (/.f64 (sin.f64 b) (cos.f64 a))))
(*.f64 (/.f64 (sin.f64 (neg.f64 b)) (cos.f64 b)) r)
Outputs
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))
Calls

3 calls:

53.0ms
r
44.0ms
a
41.0ms
b
Results
ErrorSegmentsBranch
25.1b3r
17.5b3a
17.7b3b
Compiler

Compiled 206 to 64 computations (68.9% saved)

bsearch126.0ms (0.6%)

Algorithm
binary-search
Steps
TimeLeftRight
63.0ms
30.794776646147486
3707.5009248211663
63.0ms
-120634.49979016042
-8.596803228628322e-10
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes112.0ms (0.5%)

Counts
15 → 3
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
Outputs
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))
Calls

3 calls:

52.0ms
r
31.0ms
a
24.0ms
b
Results
ErrorSegmentsBranch
25.5b4r
18.9b3a
17.7b3b
Compiler

Compiled 113 to 50 computations (55.8% saved)

bsearch211.0ms (1%)

Algorithm
binary-search
Steps
TimeLeftRight
86.0ms
4.0839894579162385e-6
7.754747772611917e-5
125.0ms
-7.443575294864509e-6
-1.5945069754996967e-21
Compiler

Compiled 18 to 13 computations (27.8% saved)

regimes31.0ms (0.1%)

Counts
14 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
(*.f64 r (/.f64 b (cos.f64 a)))
(/.f64 (*.f64 r (neg.f64 b)) (cos.f64 a))
(*.f64 r (neg.f64 (/.f64 b (cos.f64 a))))
(/.f64 1 (/.f64 (cos.f64 a) (*.f64 b r)))
(*.f64 r (-.f64 (+.f64 1 (/.f64 b (cos.f64 a))) 1))
(-.f64 (+.f64 1 (*.f64 (/.f64 b (cos.f64 a)) r)) 1)
Outputs
(*.f64 r (/.f64 b (cos.f64 a)))
Calls

3 calls:

9.0ms
a
9.0ms
b
8.0ms
r
Results
ErrorSegmentsBranch
31.5b1r
31.5b1a
31.5b1b
Compiler

Compiled 106 to 46 computations (56.6% saved)

regimes21.0ms (0.1%)

Counts
8 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 r (/.f64 (cos.f64 a) b))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 b r) (cos.f64 a))
Outputs
(*.f64 (/.f64 r (cos.f64 a)) b)
Calls

3 calls:

7.0ms
r
6.0ms
b
5.0ms
a
Results
ErrorSegmentsBranch
31.5b1r
31.5b1a
31.5b1b
Compiler

Compiled 58 to 26 computations (55.2% saved)

regimes14.0ms (0.1%)

Counts
4 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
(/.f64 (*.f64 r b) (cos.f64 a))
Outputs
(/.f64 (*.f64 r b) (cos.f64 a))
Calls

3 calls:

4.0ms
r
4.0ms
a
4.0ms
b
Results
ErrorSegmentsBranch
31.5b1r
31.5b1a
31.5b1b
Compiler

Compiled 34 to 20 computations (41.2% saved)

regimes14.0ms (0.1%)

Counts
3 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
(/.f64 b (/.f64 (cos.f64 a) r))
Outputs
(/.f64 b (/.f64 (cos.f64 a) r))
Calls

3 calls:

4.0ms
a
4.0ms
b
4.0ms
r
Results
ErrorSegmentsBranch
31.6b1r
31.6b1a
31.6b1b
Compiler

Compiled 28 to 19 computations (32.1% saved)

regimes12.0ms (0.1%)

Accuracy

Total -11.5b remaining (-26.2%)

Threshold costs -11.5b (-26.2%)

Counts
2 → 1
Calls
Call 1
Inputs
(*.f64 r b)
(*.f64 r (log.f64 1))
Outputs
(*.f64 r b)
Calls

3 calls:

4.0ms
b
3.0ms
a
3.0ms
r
Results
ErrorSegmentsBranch
44.0b1r
44.0b1a
44.0b1b
Compiler

Compiled 22 to 16 computations (27.3% saved)

simplify28.0ms (0.1%)

Algorithm
egg-herbie
Rules
25×*-commutative_binary64
14×+-commutative_binary64
13×sub-neg_binary64
cancel-sign-sub-inv_binary64
neg-sub0_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
095598
1147598
2171598
3180598
4184598
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 50078764646061560/18446744073709551616) (*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b))))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 50078764646061560/18446744073709551616) (*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a))))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 50078764646061560/18446744073709551616) (*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a)))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 50078764646061560/18446744073709551616) (*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b))))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (/.f64 (sin.f64 b) (cos.f64 a))) (if (<=.f64 a 8667959039284217/281474976710656) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))))
(if (<=.f64 b -8787822621296173/1180591620717411303424) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (if (<=.f64 b 2410761866557077/590295810358705651712) (*.f64 r (/.f64 b (cos.f64 a))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(*.f64 r (/.f64 b (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 a)) b)
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 b (/.f64 (cos.f64 a) r))
(*.f64 r b)
Outputs
(*.f64 r (/.f64 (sin.f64 b) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b)))))
(/.f64 (*.f64 (sin.f64 b) r) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(/.f64 (*.f64 r (sin.f64 b)) (fma.f64 (sin.f64 a) (neg.f64 (sin.f64 b)) (*.f64 (cos.f64 a) (cos.f64 b))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(/.f64 (*.f64 (sin.f64 b) r) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b))))
(/.f64 (*.f64 r (sin.f64 b)) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a))))
(*.f64 (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 a) (sin.f64 b)))) (sin.f64 b))
(*.f64 (sin.f64 b) (/.f64 r (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a)))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 50078764646061560/18446744073709551616) (*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b))))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 6259845580757695/2305843009213693952) (*.f64 r (/.f64 (sin.f64 b) (+.f64 (*.f64 (sin.f64 b) (-.f64 (*.f64 1/6 (pow.f64 a 3)) a)) (*.f64 (cos.f64 b) (+.f64 (*.f64 -1/2 (*.f64 a a)) 1))))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 50078764646061560/18446744073709551616) (*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 (sin.f64 b) (sin.f64 a))))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 6259845580757695/2305843009213693952) (*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (+.f64 (*.f64 -1/2 (*.f64 a a)) 1)) (*.f64 (sin.f64 b) (sin.f64 a))))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 50078764646061560/18446744073709551616) (*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (cos.f64 a)) (*.f64 (sin.f64 b) a)))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 6259845580757695/2305843009213693952) (*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 a) (cos.f64 b)) (*.f64 (sin.f64 b) a)))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 50078764646061560/18446744073709551616) (*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (+.f64 (*.f64 -1/2 (*.f64 a a)) 1) (cos.f64 b)) (*.f64 a (sin.f64 b))))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1)) (if (<=.f64 a 6259845580757695/2305843009213693952) (*.f64 r (/.f64 (sin.f64 b) (-.f64 (*.f64 (cos.f64 b) (+.f64 (*.f64 -1/2 (*.f64 a a)) 1)) (*.f64 (sin.f64 b) a)))) (*.f64 r (pow.f64 (-.f64 (/.f64 (cos.f64 a) b) (sin.f64 a)) -1))))
(/.f64 (*.f64 (sin.f64 b) r) (cos.f64 (-.f64 b a)))
(/.f64 (*.f64 r (sin.f64 b)) (cos.f64 (-.f64 b a)))
(/.f64 r (/.f64 (cos.f64 (-.f64 b a)) (sin.f64 b)))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (/.f64 (sin.f64 b) (cos.f64 a))) (if (<=.f64 a 8667959039284217/281474976710656) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))))
(if (<=.f64 a -4144969850944463/34359738368) (*.f64 r (/.f64 (sin.f64 b) (cos.f64 a))) (if (<=.f64 a 8667959039284217/281474976710656) (/.f64 (*.f64 r (sin.f64 b)) (cos.f64 b)) (*.f64 r (/.f64 (sin.f64 b) (cos.f64 a)))))
(if (<=.f64 b -8787822621296173/1180591620717411303424) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b)) (if (<=.f64 b 2410761866557077/590295810358705651712) (*.f64 r (/.f64 b (cos.f64 a))) (/.f64 (*.f64 (sin.f64 b) r) (cos.f64 b))))
(if (<=.f64 b -8787822621296173/1180591620717411303424) (/.f64 (*.f64 r (sin.f64 b)) (cos.f64 b)) (if (<=.f64 b 2410761866557077/590295810358705651712) (*.f64 r (/.f64 b (cos.f64 a))) (/.f64 (*.f64 r (sin.f64 b)) (cos.f64 b))))
(*.f64 r (/.f64 b (cos.f64 a)))
(*.f64 (/.f64 r (cos.f64 a)) b)
(*.f64 b (/.f64 r (cos.f64 a)))
(/.f64 (*.f64 r b) (cos.f64 a))
(/.f64 b (/.f64 (cos.f64 a) r))
(*.f64 r b)
Compiler

Compiled 438 to 260 computations (40.6% saved)

soundness70.0ms (0.3%)

Algorithm
egg-herbie
Rules
680×fma-def_binary64
497×times-frac_binary64
450×associate-*l/_binary64
443×associate-/l*_binary64
371×associate-*r/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0914
11314
21714
32114
42214
01462104
14882029
218391955
Stop Event
node limit
saturated
Compiler

Compiled 130 to 86 computations (33.8% saved)

end212.0ms (1%)

Compiler

Compiled 387 to 134 computations (65.4% saved)

Profiling

Loading profile data...