Details

Time bar (total: 9.0s)

analyze53.0ms (0.6%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
25%25%74.9%0.1%0%0%0%5
33.3%25%50%0.1%25%0%0%6
44.4%25%31.2%0.1%43.7%0%0%7
53.3%25%21.9%0.1%53.1%0%0%8
64%25%14%0.1%60.9%0%0%9
72%28.1%10.9%0.1%60.9%0%0%10
81%31.6%7.4%0.1%60.9%0%0%11
85.5%33.4%5.7%0.1%60.9%0%0%12
Compiler

Compiled 20 to 13 computations (35% saved)

sample1.4s (15.3%)

Results
1.4s8256×body256valid
0.0msbody256infinite
Bogosity

preprocess78.0ms (0.9%)

Algorithm
egg-herbie
Rules
905×fma-def_binary64
626×associate-*l*_binary64
495×fma-neg_binary64
426×sub-neg_binary64
420×associate-+l+_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01846
14842
29942
329242
4112034
5375934
6749234
022
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 b b) (*.f64 a a)) 2) (*.f64 4 (*.f64 a a))) 1)
Outputs
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
(+.f64 (pow.f64 (fma.f64 a a (*.f64 b b)) 2) (-.f64 (*.f64 (*.f64 b b) 4) 1))
(+.f64 (pow.f64 (fma.f64 a a (*.f64 b b)) 2) (fma.f64 (*.f64 b b) 4 -1))
(+.f64 (pow.f64 (fma.f64 a a (*.f64 b b)) 2) (fma.f64 b (*.f64 b 4) -1))
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 b b) (*.f64 a a)) 2) (*.f64 4 (*.f64 a a))) 1)
(+.f64 (pow.f64 (fma.f64 a a (*.f64 b b)) 2) (-.f64 (*.f64 (*.f64 4 a) a) 1))
(+.f64 (pow.f64 (fma.f64 a a (*.f64 b b)) 2) (fma.f64 (*.f64 a a) 4 -1))
(+.f64 (pow.f64 (fma.f64 a a (*.f64 b b)) 2) (fma.f64 a (*.f64 a 4) -1))
(fma.f64 (hypot.f64 a b) (pow.f64 (hypot.f64 a b) 3) (fma.f64 a (*.f64 a 4) -1))
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 a (*.f64 a 4) -1))
Compiler

Compiled 21 to 14 computations (33.3% saved)

simplify56.0ms (0.6%)

Algorithm
egg-herbie
Rules
776×distribute-rgt-neg-in_binary64
770×unswap-sqr_binary64
617×associate-*l*_binary64
587×fma-def_binary64
311×fma-neg_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01323
13021
26421
319721
477117
5264617
6582617
Stop Event
node limit
Counts
1 → 2
Calls
Call 1
Inputs
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
Outputs
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
(+.f64 (pow.f64 (fma.f64 a a (*.f64 b b)) 2) (-.f64 (*.f64 (*.f64 b b) 4) 1))
(+.f64 (pow.f64 (fma.f64 a a (*.f64 b b)) 2) (fma.f64 (*.f64 b 4) b -1))
(+.f64 (pow.f64 (fma.f64 a a (*.f64 b b)) 2) (fma.f64 b (*.f64 b 4) -1))
(fma.f64 (hypot.f64 a b) (pow.f64 (hypot.f64 a b) 3) (fma.f64 b (*.f64 b 4) -1))
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))

eval2.0ms (0%)

Compiler

Compiled 31 to 20 computations (35.5% saved)

prune3.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.0b
Counts
3 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
0.2b
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
Compiler

Compiled 33 to 22 computations (33.3% saved)

localize74.0ms (0.8%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(hypot.f64 a b)
0.0b
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
0.0b
(pow.f64 (hypot.f64 a b) 4)
Compiler

Compiled 35 to 20 computations (42.9% saved)

series31.0ms (0.3%)

Counts
3 → 72
Calls

18 calls:

TimeVariablePointExpression
8.0ms
b
@0
(pow.f64 (hypot.f64 a b) 4)
4.0ms
a
@0
(pow.f64 (hypot.f64 a b) 4)
2.0ms
b
@inf
(pow.f64 (hypot.f64 a b) 4)
2.0ms
a
@inf
(pow.f64 (hypot.f64 a b) 4)
2.0ms
b
@-inf
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))

rewrite124.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
626×prod-diff_binary64
447×log-prod_binary64
271×pow-prod-down_binary64
266×pow2_binary64
243×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01028
121228
2262928
Stop Event
node limit
Counts
3 → 117
Calls
Call 1
Inputs
(pow.f64 (hypot.f64 a b) 4)
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
(hypot.f64 a b)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (pow.f64 (hypot.f64 a b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (pow.f64 (hypot.f64 a b) 4))) 2)) (log.f64 (cbrt.f64 (exp.f64 (pow.f64 (hypot.f64 a b) 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (hypot.f64 a b) 4)))) (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (hypot.f64 a b) 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (pow.f64 (hypot.f64 a b) 4))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (hypot.f64 a b) 4) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (hypot.f64 a b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 4) (cbrt.f64 (pow.f64 (hypot.f64 a b) 8)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (hypot.f64 a b) 8)) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (hypot.f64 a b) 2) (pow.f64 (hypot.f64 a b) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 8) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (hypot.f64 a b) 8))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 (hypot.f64 a b) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (hypot.f64 a b) 12))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 4 (log.f64 (hypot.f64 a b))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 4 (log.f64 (hypot.f64 a b))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 4)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (log.f64 (hypot.f64 a b))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 12 (log.f64 (hypot.f64 a b))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (hypot.f64 a b)) 1) 4))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (*.f64 4 (log.f64 (hypot.f64 a b))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (hypot.f64 a b)) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (*.f64 4 (log.f64 (hypot.f64 a b))) 3) 1/3))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (hypot.f64 a b) 8) (-.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))) (/.f64 (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2) (-.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))) (pow.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))) 2) (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))) (sqrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (hypot.f64 a b) 12) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 3)) (/.f64 1 (fma.f64 (fma.f64 b (*.f64 b 4) -1) (-.f64 (fma.f64 b (*.f64 b 4) -1) (pow.f64 (hypot.f64 a b) 4)) (pow.f64 (hypot.f64 a b) 8))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (hypot.f64 a b) 8) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2)) (/.f64 1 (-.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (fma.f64 b (*.f64 b 4) -1) (-.f64 (fma.f64 b (*.f64 b 4) -1) (pow.f64 (hypot.f64 a b) 4)) (pow.f64 (hypot.f64 a b) 8)) (+.f64 (pow.f64 (hypot.f64 a b) 12) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)) (-.f64 (pow.f64 (hypot.f64 a b) 8) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (hypot.f64 a b) 12) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 3)) (fma.f64 (fma.f64 b (*.f64 b 4) -1) (-.f64 (fma.f64 b (*.f64 b 4) -1) (pow.f64 (hypot.f64 a b) 4)) (pow.f64 (hypot.f64 a b) 8)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (hypot.f64 a b) 12) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 3)) (+.f64 (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2) (-.f64 (pow.f64 (hypot.f64 a b) 8) (*.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (hypot.f64 a b) 8) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2)) (-.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (hypot.f64 a b) 12) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 3))) (neg.f64 (fma.f64 (fma.f64 b (*.f64 b 4) -1) (-.f64 (fma.f64 b (*.f64 b 4) -1) (pow.f64 (hypot.f64 a b) 4)) (pow.f64 (hypot.f64 a b) 8))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (hypot.f64 a b) 8) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2))) (neg.f64 (-.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2) (pow.f64 (hypot.f64 a b) 8)) (-.f64 (fma.f64 b (*.f64 b 4) -1) (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 (fma.f64 b (*.f64 b 4) -1) (-.f64 (fma.f64 b (*.f64 b 4) -1) (pow.f64 (hypot.f64 a b) 4)) (pow.f64 (hypot.f64 a b) 8)) (+.f64 (pow.f64 (hypot.f64 a b) 12) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 3))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (-.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)) (-.f64 (pow.f64 (hypot.f64 a b) 8) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (pow.f64 (hypot.f64 a b) 4))) (exp.f64 (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (pow.f64 (hypot.f64 a b) 4)) (+.f64 1 (expm1.f64 (fma.f64 b (*.f64 b 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (pow.f64 (hypot.f64 a b) 4))) (+.f64 1 (expm1.f64 (fma.f64 b (*.f64 b 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (fma.f64 b (*.f64 b 4) -1))) (exp.f64 (pow.f64 (hypot.f64 a b) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (fma.f64 b (*.f64 b 4) -1)) (+.f64 1 (expm1.f64 (pow.f64 (hypot.f64 a b) 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (fma.f64 b (*.f64 b 4) -1))) (+.f64 1 (expm1.f64 (pow.f64 (hypot.f64 a b) 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 b (*.f64 b 4) (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 a b) 4) 1 (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b 4) b (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 b (*.f64 b 4) -1) 1 (pow.f64 (hypot.f64 a b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 b (*.f64 b 4) -1) (pow.f64 (hypot.f64 a b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (*.f64 b b) 4) (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b b) 4 (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (fma.f64 b (*.f64 b 4) -1)) (cbrt.f64 (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2)) (pow.f64 (hypot.f64 a b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2)) (cbrt.f64 (fma.f64 b (*.f64 b 4) -1)) (pow.f64 (hypot.f64 a b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 4) (cbrt.f64 (pow.f64 (hypot.f64 a b) 8)) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (hypot.f64 a b) 8)) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 4) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 b b)) (*.f64 (cbrt.f64 b) (*.f64 b 4)) (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (fma.f64 b (*.f64 b 4) -1)) (sqrt.f64 (fma.f64 b (*.f64 b 4) -1)) (pow.f64 (hypot.f64 a b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 b) (*.f64 (sqrt.f64 b) (*.f64 b 4)) (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 a b) 2) (pow.f64 (hypot.f64 a b) 2) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 (*.f64 b b) 4)) 2) (cbrt.f64 (*.f64 (*.f64 b b) 4)) (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 8) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 4) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (*.f64 b b) 4)) (sqrt.f64 (*.f64 (*.f64 b b) 4)) (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b (pow.f64 (cbrt.f64 (*.f64 b 4)) 2)) (cbrt.f64 (*.f64 b 4)) (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b (*.f64 2 (sqrt.f64 b))) (*.f64 2 (sqrt.f64 b)) (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (hypot.f64 a b))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (hypot.f64 a b))) 2)) (log.f64 (cbrt.f64 (exp.f64 (hypot.f64 a b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (hypot.f64 a b)))) (log.f64 (sqrt.f64 (exp.f64 (hypot.f64 a b)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (hypot.f64 a b))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 a b) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (hypot.f64 a b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (hypot.f64 a b)) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) (cbrt.f64 (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (hypot.f64 a b)) (sqrt.f64 (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (hypot.f64 a b) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (hypot.f64 a b) 4) 1/4)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (hypot.f64 a b) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (hypot.f64 a b)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (hypot.f64 a b)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (hypot.f64 a b) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (hypot.f64 a b) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (hypot.f64 a b))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (hypot.f64 a b) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (hypot.f64 a b)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (hypot.f64 a b))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (hypot.f64 a b))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (hypot.f64 a b))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (log.f64 (hypot.f64 a b))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (hypot.f64 a b)) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (hypot.f64 a b)) 2) 1/2))))))

simplify102.0ms (1.1%)

Algorithm
egg-herbie
Rules
709×associate-*l*_binary64
700×associate-*r*_binary64
404×times-frac_binary64
343×associate-/r*_binary64
333×fma-def_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02232109
17711912
227691723
Stop Event
node limit
Counts
189 → 191
Calls
Call 1
Inputs
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1 (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2) (*.f64 1/16 (/.f64 1 (pow.f64 b 6))))) (*.f64 5/64 (/.f64 1 (pow.f64 b 6)))) (*.f64 (pow.f64 a 8) (pow.f64 b 2)))) (+.f64 (pow.f64 a 4) (pow.f64 b 4))))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))))
(+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2)) (pow.f64 a 2))))))))))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))))
(+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2)) (pow.f64 a 2))))))))))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (*.f64 (pow.f64 b 8) (+.f64 (*.f64 -1 (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 a 6))) (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2))) (*.f64 5/64 (/.f64 1 (pow.f64 a 6))))))) (+.f64 (pow.f64 b 4) (pow.f64 a 4))))
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))))
(+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2)) (pow.f64 b 2))))))))))
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))))
(+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2)) (pow.f64 b 2))))))))))
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 8) (*.f64 (pow.f64 b 2) (+.f64 (*.f64 -1 (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 b 6))) (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2))) (*.f64 5/64 (/.f64 1 (pow.f64 b 6))))))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))))) 1)
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 a 4)))))) 1)
(-.f64 (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2)) (pow.f64 a 2))))))))))) 1)
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))))) 1)
(-.f64 (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2)) (pow.f64 a 2))))))))))) 1)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(-.f64 (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (*.f64 (+.f64 (*.f64 5/64 (/.f64 1 (pow.f64 a 6))) (*.f64 -1 (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2) (*.f64 1/16 (/.f64 1 (pow.f64 a 6)))))) (pow.f64 b 8)))) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))) 1)
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))))) 1)
(-.f64 (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2)) (pow.f64 b 2))) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))))))) 1)
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))))) 1)
(-.f64 (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2)) (pow.f64 b 2))) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))))))) 1)
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/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) b))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5))) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) b)))
a
(+.f64 a (*.f64 1/2 (/.f64 (pow.f64 b 2) a)))
(+.f64 a (+.f64 (*.f64 1/2 (/.f64 (pow.f64 b 2) a)) (*.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)))))
(+.f64 a (+.f64 (*.f64 1/2 (/.f64 (pow.f64 b 2) a)) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3))) (*.f64 1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5))))))
(*.f64 -1 a)
(+.f64 (*.f64 -1/2 (/.f64 (pow.f64 b 2) a)) (*.f64 -1 a))
(+.f64 (*.f64 1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 b 2) a)) (*.f64 -1 a)))
(+.f64 (*.f64 1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 b 2) a)) (+.f64 (*.f64 -1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5))) (*.f64 -1 a))))
a
(+.f64 a (*.f64 1/2 (/.f64 (pow.f64 b 2) a)))
(+.f64 a (+.f64 (*.f64 1/2 (/.f64 (pow.f64 b 2) a)) (*.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)))))
(+.f64 a (+.f64 (*.f64 1/2 (/.f64 (pow.f64 b 2) a)) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3))) (*.f64 1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5))))))
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/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) b))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5))) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) b)))
(*.f64 -1 b)
(+.f64 (*.f64 -1/2 (/.f64 (pow.f64 a 2) b)) (*.f64 -1 b))
(+.f64 (*.f64 1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 a 2) b)) (*.f64 -1 b)))
(+.f64 (*.f64 1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 -1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5))) (*.f64 -1 b))))
Outputs
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1 (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2) (*.f64 1/16 (/.f64 1 (pow.f64 b 6))))) (*.f64 5/64 (/.f64 1 (pow.f64 b 6)))) (*.f64 (pow.f64 a 8) (pow.f64 b 2)))) (+.f64 (pow.f64 a 4) (pow.f64 b 4))))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 2 (*.f64 (fma.f64 -1 (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2) (/.f64 1/16 (pow.f64 b 6))) (/.f64 5/64 (pow.f64 b 6))) (*.f64 (*.f64 b b) (pow.f64 a 8))) (+.f64 (pow.f64 b 4) (pow.f64 a 4))))
(+.f64 (fma.f64 2 (*.f64 (-.f64 (/.f64 5/64 (pow.f64 b 6)) (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2) (/.f64 1/16 (pow.f64 b 6)))) (*.f64 b (*.f64 b (pow.f64 a 8)))) (pow.f64 a 4)) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)))
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (*.f64 2 (*.f64 (*.f64 b b) (+.f64 (*.f64 a a) (*.f64 (-.f64 (*.f64 (/.f64 1 (pow.f64 b 6)) 1/64) (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2)) (pow.f64 a 8))))))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2)) (pow.f64 a 2))))))))))
(fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (+.f64 (pow.f64 a 4) (fma.f64 1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (*.f64 2 (/.f64 (*.f64 (pow.f64 b 4) 0) (/.f64 (*.f64 a a) (*.f64 b b))))))))))
(+.f64 (fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)) (+.f64 (pow.f64 a 4) (fma.f64 (/.f64 (pow.f64 b 6) (*.f64 a a)) 1/4 (*.f64 (/.f64 b (/.f64 a b)) (/.f64 0 a)))))) 0)
(fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)) (+.f64 (pow.f64 a 4) (*.f64 (/.f64 (pow.f64 b 6) a) (/.f64 1/4 a)))))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2)) (pow.f64 a 2))))))))))
(fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (+.f64 (pow.f64 a 4) (fma.f64 1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (*.f64 2 (/.f64 (*.f64 (pow.f64 b 4) 0) (/.f64 (*.f64 a a) (*.f64 b b))))))))))
(+.f64 (fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)) (+.f64 (pow.f64 a 4) (fma.f64 (/.f64 (pow.f64 b 6) (*.f64 a a)) 1/4 (*.f64 (/.f64 b (/.f64 a b)) (/.f64 0 a)))))) 0)
(fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)) (+.f64 (pow.f64 a 4) (*.f64 (/.f64 (pow.f64 b 6) a) (/.f64 1/4 a)))))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (*.f64 (pow.f64 b 8) (+.f64 (*.f64 -1 (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 a 6))) (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2))) (*.f64 5/64 (/.f64 1 (pow.f64 a 6))))))) (+.f64 (pow.f64 b 4) (pow.f64 a 4))))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 (pow.f64 b 8) (fma.f64 -1 (+.f64 (/.f64 1/16 (pow.f64 a 6)) (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2)) (/.f64 5/64 (pow.f64 a 6))))) (+.f64 (pow.f64 b 4) (pow.f64 a 4))))
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (*.f64 (*.f64 2 (*.f64 a a)) (+.f64 (*.f64 b b) (*.f64 (pow.f64 b 8) (-.f64 (/.f64 5/64 (pow.f64 a 6)) (+.f64 (/.f64 1/16 (pow.f64 a 6)) (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2)))))))
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (*.f64 2 (*.f64 (*.f64 a a) (+.f64 (*.f64 b b) (*.f64 (pow.f64 b 8) (-.f64 (*.f64 (/.f64 1 (pow.f64 a 6)) 1/64) (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2)))))))
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4))
(+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2)) (pow.f64 b 2))))))))))
(fma.f64 1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (fma.f64 1/2 (pow.f64 a 4) (fma.f64 -1/2 (pow.f64 a 4) (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 2 (/.f64 (*.f64 (pow.f64 a 4) 0) (/.f64 (*.f64 b b) (*.f64 a a)))))))))))
(fma.f64 1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (+.f64 (+.f64 (pow.f64 b 4) (*.f64 (/.f64 a (/.f64 b a)) (/.f64 0 b))) (fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (pow.f64 a 4)))) 0))
(fma.f64 1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (+.f64 (fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (pow.f64 a 4)) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4))))
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4))
(+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2)) (pow.f64 b 2))))))))))
(fma.f64 1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (fma.f64 1/2 (pow.f64 a 4) (fma.f64 -1/2 (pow.f64 a 4) (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 2 (/.f64 (*.f64 (pow.f64 a 4) 0) (/.f64 (*.f64 b b) (*.f64 a a)))))))))))
(fma.f64 1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (+.f64 (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (+.f64 (+.f64 (pow.f64 b 4) (*.f64 (/.f64 a (/.f64 b a)) (/.f64 0 b))) (fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (pow.f64 a 4)))) 0))
(fma.f64 1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (+.f64 (fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (pow.f64 a 4)) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4))))
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) -1)
(+.f64 -1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))
(+.f64 (pow.f64 b 4) (fma.f64 b (*.f64 b 4) -1))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))) 1)
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) -1)
(+.f64 -1 (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) b) b -1))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1))
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) b) b -1))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 8) (*.f64 (pow.f64 b 2) (+.f64 (*.f64 -1 (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 b 6))) (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2))) (*.f64 5/64 (/.f64 1 (pow.f64 b 6))))))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))))) 1)
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 2 (*.f64 (fma.f64 -1 (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2) (/.f64 1/16 (pow.f64 b 6))) (/.f64 5/64 (pow.f64 b 6))) (*.f64 (*.f64 b b) (pow.f64 a 8))) (+.f64 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))))) -1)
(+.f64 -1 (+.f64 (fma.f64 2 (*.f64 (-.f64 (/.f64 5/64 (pow.f64 b 6)) (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2) (/.f64 1/16 (pow.f64 b 6)))) (*.f64 b (*.f64 b (pow.f64 a 8)))) (pow.f64 a 4)) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 4))))
(+.f64 (+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4))) (fma.f64 (-.f64 (*.f64 (/.f64 1 (pow.f64 b 6)) 1/64) (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2)) (*.f64 (*.f64 b b) (*.f64 2 (pow.f64 a 8))) -1))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 a 4)))))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1))
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) b) b -1))
(-.f64 (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2)) (pow.f64 a 2))))))))))) 1)
(+.f64 (fma.f64 1/2 (pow.f64 b 4) (fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (fma.f64 -1/2 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (*.f64 2 (/.f64 (*.f64 (pow.f64 b 4) 0) (/.f64 (*.f64 a a) (*.f64 b b))))))))))) -1)
(+.f64 -1 (fma.f64 (pow.f64 b 4) 1/2 (fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (fma.f64 (/.f64 (pow.f64 b 6) (*.f64 a a)) 1/4 (+.f64 (+.f64 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (*.f64 (/.f64 b (/.f64 a b)) (/.f64 0 a)))) (fma.f64 (pow.f64 b 4) -1/2 (pow.f64 a 4))))))))
(+.f64 (fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (+.f64 (fma.f64 (/.f64 (pow.f64 b 6) (*.f64 a a)) 1/4 (*.f64 (pow.f64 b 4) -1/2)) (+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4))))) (fma.f64 (pow.f64 b 4) 1/2 -1))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1))
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) b) b -1))
(-.f64 (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2)) (pow.f64 a 2))))))))))) 1)
(+.f64 (fma.f64 1/2 (pow.f64 b 4) (fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (fma.f64 -1/2 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (*.f64 2 (/.f64 (*.f64 (pow.f64 b 4) 0) (/.f64 (*.f64 a a) (*.f64 b b))))))))))) -1)
(+.f64 -1 (fma.f64 (pow.f64 b 4) 1/2 (fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (fma.f64 (/.f64 (pow.f64 b 6) (*.f64 a a)) 1/4 (+.f64 (+.f64 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (*.f64 (/.f64 b (/.f64 a b)) (/.f64 0 a)))) (fma.f64 (pow.f64 b 4) -1/2 (pow.f64 a 4))))))))
(+.f64 (fma.f64 -1/4 (/.f64 (pow.f64 b 6) (*.f64 a a)) (+.f64 (fma.f64 (/.f64 (pow.f64 b 6) (*.f64 a a)) 1/4 (*.f64 (pow.f64 b 4) -1/2)) (+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4))))) (fma.f64 (pow.f64 b 4) 1/2 -1))
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
(-.f64 (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(+.f64 (+.f64 (pow.f64 a 4) (*.f64 (*.f64 b b) (+.f64 4 (*.f64 2 (*.f64 a a))))) -1)
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) b) b -1))
(-.f64 (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1))
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) b) b -1))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (*.f64 (+.f64 (*.f64 5/64 (/.f64 1 (pow.f64 a 6))) (*.f64 -1 (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2) (*.f64 1/16 (/.f64 1 (pow.f64 a 6)))))) (pow.f64 b 8)))) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))) 1)
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 (pow.f64 b 8) (fma.f64 -1 (+.f64 (/.f64 1/16 (pow.f64 a 6)) (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2)) (/.f64 5/64 (pow.f64 a 6))))) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (*.f64 b b) (+.f64 4 (*.f64 2 (*.f64 a a))))))) -1)
(fma.f64 (*.f64 2 (*.f64 a a)) (*.f64 (pow.f64 b 8) (-.f64 (/.f64 5/64 (pow.f64 a 6)) (+.f64 (/.f64 1/16 (pow.f64 a 6)) (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2)))) (+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 -1 (fma.f64 2 (*.f64 (-.f64 (*.f64 (/.f64 1 (pow.f64 a 6)) 1/64) (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2)) (*.f64 (*.f64 a a) (pow.f64 b 8))) (+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))))
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (*.f64 (*.f64 b b) (+.f64 4 (*.f64 2 (*.f64 a a)))))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 4))
(-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1))
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) b) b -1))
(-.f64 (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2)) (pow.f64 b 2))) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))))))) 1)
(+.f64 (fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (fma.f64 1/2 (pow.f64 a 4) (fma.f64 1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (fma.f64 -1/2 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 2 (/.f64 (*.f64 (pow.f64 a 4) 0) (/.f64 (*.f64 b b) (*.f64 a a))) (*.f64 (*.f64 b b) (+.f64 4 (*.f64 2 (*.f64 a a))))))))))) -1)
(+.f64 -1 (fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (fma.f64 (pow.f64 a 4) 1/2 (fma.f64 1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (+.f64 (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (*.f64 (/.f64 a (/.f64 b a)) (/.f64 0 b)))) (fma.f64 (pow.f64 a 4) -1/2 (pow.f64 b 4)))))))
(fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (+.f64 (/.f64 (*.f64 (/.f64 1/4 b) (pow.f64 a 6)) b) (+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) b) b -1))))
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (*.f64 (*.f64 b b) (+.f64 4 (*.f64 2 (*.f64 a a)))))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 4))
(-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1))
(+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) b) b -1))
(-.f64 (+.f64 (*.f64 -1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 6) (pow.f64 b 2))) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 2 (/.f64 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2)) (pow.f64 b 2))) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))))))) 1)
(+.f64 (fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (fma.f64 1/2 (pow.f64 a 4) (fma.f64 1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (fma.f64 -1/2 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 2 (/.f64 (*.f64 (pow.f64 a 4) 0) (/.f64 (*.f64 b b) (*.f64 a a))) (*.f64 (*.f64 b b) (+.f64 4 (*.f64 2 (*.f64 a a))))))))))) -1)
(+.f64 -1 (fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (fma.f64 (pow.f64 a 4) 1/2 (fma.f64 1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (+.f64 (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (*.f64 (/.f64 a (/.f64 b a)) (/.f64 0 b)))) (fma.f64 (pow.f64 a 4) -1/2 (pow.f64 b 4)))))))
(fma.f64 -1/4 (/.f64 (pow.f64 a 6) (*.f64 b b)) (+.f64 (/.f64 (*.f64 (/.f64 1/4 b) (pow.f64 a 6)) b) (+.f64 (+.f64 (pow.f64 b 4) (pow.f64 a 4)) (fma.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) b) b -1))))
b
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) b)) b)
(fma.f64 1/2 (/.f64 (*.f64 a a) b) b)
(fma.f64 1/2 (/.f64 a (/.f64 b a)) b)
(fma.f64 1/2 (*.f64 (/.f64 a b) a) b)
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) b))
(fma.f64 1/2 (/.f64 (*.f64 a a) b) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b))
(fma.f64 1/2 (/.f64 a (/.f64 b a)) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b))
(fma.f64 1/2 (*.f64 (/.f64 a b) a) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5))) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) b)))
(fma.f64 1/2 (/.f64 (*.f64 a a) b) (fma.f64 1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5)) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b)))
(fma.f64 1/2 (/.f64 a (/.f64 b a)) (fma.f64 1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5)) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b)))
(fma.f64 1/2 (*.f64 (/.f64 a b) a) (fma.f64 1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5)) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b)))
a
(+.f64 a (*.f64 1/2 (/.f64 (pow.f64 b 2) a)))
(+.f64 a (*.f64 1/2 (/.f64 (*.f64 b b) a)))
(fma.f64 1/2 (/.f64 b (/.f64 a b)) a)
(fma.f64 1/2 (*.f64 (/.f64 b a) b) a)
(+.f64 a (+.f64 (*.f64 1/2 (/.f64 (pow.f64 b 2) a)) (*.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)))))
(+.f64 a (fma.f64 1/2 (/.f64 (*.f64 b b) a) (*.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)))))
(+.f64 a (fma.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (*.f64 1/2 (/.f64 b (/.f64 a b)))))
(+.f64 a (fma.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (/.f64 (*.f64 (*.f64 1/2 b) b) a)))
(+.f64 a (+.f64 (*.f64 1/2 (/.f64 (pow.f64 b 2) a)) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3))) (*.f64 1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5))))))
(+.f64 a (fma.f64 1/2 (/.f64 (*.f64 b b) a) (fma.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (*.f64 1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5))))))
(+.f64 a (fma.f64 1/2 (/.f64 b (/.f64 a b)) (fma.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (*.f64 1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5))))))
(+.f64 (fma.f64 1/2 (*.f64 (/.f64 b a) b) a) (fma.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (*.f64 (/.f64 1/16 (pow.f64 a 5)) (pow.f64 b 6))))
(*.f64 -1 a)
(neg.f64 a)
(+.f64 (*.f64 -1/2 (/.f64 (pow.f64 b 2) a)) (*.f64 -1 a))
(fma.f64 -1/2 (/.f64 (*.f64 b b) a) (neg.f64 a))
(-.f64 (*.f64 -1/2 (/.f64 b (/.f64 a b))) a)
(-.f64 (*.f64 -1/2 (*.f64 (/.f64 b a) b)) a)
(+.f64 (*.f64 1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 b 2) a)) (*.f64 -1 a)))
(fma.f64 1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (fma.f64 -1/2 (/.f64 (*.f64 b b) a) (neg.f64 a)))
(-.f64 (fma.f64 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) 1/8 (*.f64 -1/2 (/.f64 b (/.f64 a b)))) a)
(-.f64 (fma.f64 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) 1/8 (*.f64 -1/2 (*.f64 (/.f64 b a) b))) a)
(+.f64 (*.f64 1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 b 2) a)) (+.f64 (*.f64 -1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5))) (*.f64 -1 a))))
(fma.f64 1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (fma.f64 -1/2 (/.f64 (*.f64 b b) a) (fma.f64 -1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5)) (neg.f64 a))))
(fma.f64 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) 1/8 (fma.f64 -1/2 (/.f64 b (/.f64 a b)) (-.f64 (/.f64 (*.f64 (pow.f64 b 6) -1/16) (pow.f64 a 5)) a)))
(fma.f64 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) 1/8 (-.f64 (fma.f64 -1/2 (*.f64 (/.f64 b a) b) (*.f64 (/.f64 -1/16 (pow.f64 a 5)) (pow.f64 b 6))) a))
a
(+.f64 a (*.f64 1/2 (/.f64 (pow.f64 b 2) a)))
(+.f64 a (*.f64 1/2 (/.f64 (*.f64 b b) a)))
(fma.f64 1/2 (/.f64 b (/.f64 a b)) a)
(fma.f64 1/2 (*.f64 (/.f64 b a) b) a)
(+.f64 a (+.f64 (*.f64 1/2 (/.f64 (pow.f64 b 2) a)) (*.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)))))
(+.f64 a (fma.f64 1/2 (/.f64 (*.f64 b b) a) (*.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)))))
(+.f64 a (fma.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (*.f64 1/2 (/.f64 b (/.f64 a b)))))
(+.f64 a (fma.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (/.f64 (*.f64 (*.f64 1/2 b) b) a)))
(+.f64 a (+.f64 (*.f64 1/2 (/.f64 (pow.f64 b 2) a)) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3))) (*.f64 1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5))))))
(+.f64 a (fma.f64 1/2 (/.f64 (*.f64 b b) a) (fma.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (*.f64 1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5))))))
(+.f64 a (fma.f64 1/2 (/.f64 b (/.f64 a b)) (fma.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (*.f64 1/16 (/.f64 (pow.f64 b 6) (pow.f64 a 5))))))
(+.f64 (fma.f64 1/2 (*.f64 (/.f64 b a) b) a) (fma.f64 -1/8 (/.f64 (pow.f64 b 4) (pow.f64 a 3)) (*.f64 (/.f64 1/16 (pow.f64 a 5)) (pow.f64 b 6))))
b
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) b)) b)
(fma.f64 1/2 (/.f64 (*.f64 a a) b) b)
(fma.f64 1/2 (/.f64 a (/.f64 b a)) b)
(fma.f64 1/2 (*.f64 (/.f64 a b) a) b)
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) b))
(fma.f64 1/2 (/.f64 (*.f64 a a) b) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b))
(fma.f64 1/2 (/.f64 a (/.f64 b a)) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b))
(fma.f64 1/2 (*.f64 (/.f64 a b) a) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b))
(+.f64 (*.f64 1/2 (/.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5))) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) b)))
(fma.f64 1/2 (/.f64 (*.f64 a a) b) (fma.f64 1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5)) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b)))
(fma.f64 1/2 (/.f64 a (/.f64 b a)) (fma.f64 1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5)) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b)))
(fma.f64 1/2 (*.f64 (/.f64 a b) a) (fma.f64 1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5)) (fma.f64 -1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) b)))
(*.f64 -1 b)
(neg.f64 b)
(+.f64 (*.f64 -1/2 (/.f64 (pow.f64 a 2) b)) (*.f64 -1 b))
(fma.f64 -1/2 (/.f64 (*.f64 a a) b) (neg.f64 b))
(-.f64 (*.f64 -1/2 (/.f64 a (/.f64 b a))) b)
(-.f64 (*.f64 -1/2 (*.f64 (/.f64 a b) a)) b)
(+.f64 (*.f64 1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 a 2) b)) (*.f64 -1 b)))
(fma.f64 1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) (fma.f64 -1/2 (/.f64 (*.f64 a a) b) (neg.f64 b)))
(-.f64 (fma.f64 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) 1/8 (*.f64 -1/2 (/.f64 a (/.f64 b a)))) b)
(-.f64 (fma.f64 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) 1/8 (*.f64 -1/2 (*.f64 (/.f64 a b) a))) b)
(+.f64 (*.f64 1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3))) (+.f64 (*.f64 -1/2 (/.f64 (pow.f64 a 2) b)) (+.f64 (*.f64 -1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5))) (*.f64 -1 b))))
(fma.f64 1/8 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) (fma.f64 -1/2 (/.f64 (*.f64 a a) b) (fma.f64 -1/16 (/.f64 (pow.f64 a 6) (pow.f64 b 5)) (neg.f64 b))))
(fma.f64 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) 1/8 (fma.f64 -1/2 (/.f64 a (/.f64 b a)) (-.f64 (/.f64 -1/16 (/.f64 (pow.f64 b 5) (pow.f64 a 6))) b)))
(fma.f64 (/.f64 (pow.f64 a 4) (pow.f64 b 3)) 1/8 (-.f64 (fma.f64 -1/2 (*.f64 (/.f64 a b) a) (/.f64 (*.f64 (pow.f64 a 6) -1/16) (pow.f64 b 5))) b))

localize62.0ms (0.7%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
0.0b
(+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b)))
0.0b
(*.f64 4 (*.f64 b b))
0.3b
(pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2)
Compiler

Compiled 66 to 24 computations (63.6% saved)

series14.0ms (0.2%)

Counts
4 → 84
Calls

21 calls:

TimeVariablePointExpression
1.0ms
a
@0
(pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2)
1.0ms
a
@inf
(pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2)
1.0ms
b
@inf
(pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2)
1.0ms
b
@0
(*.f64 4 (*.f64 b b))
1.0ms
b
@inf
(*.f64 4 (*.f64 b b))

rewrite123.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
661×fma-def_binary64
584×log-prod_binary64
362×fma-neg_binary64
337×pow2_binary64
227×pow1/3_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01361
129052
2386852
Stop Event
node limit
Counts
4 → 213
Calls
Call 1
Inputs
(pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2)
(*.f64 4 (*.f64 b b))
(+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b)))
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 a a) (pow.f64 (hypot.f64 a b) 2)) (*.f64 (*.f64 b b) (pow.f64 (hypot.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 b b) (pow.f64 (hypot.f64 a b) 2)) (*.f64 (*.f64 a a) (pow.f64 (hypot.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 a a)) (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b b)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b b)) (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 a a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))) 2)) (log.f64 (cbrt.f64 (exp.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)))) (log.f64 (sqrt.f64 (exp.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (hypot.f64 a b) 2) (pow.f64 (hypot.f64 a b) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (*.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) (pow.f64 (hypot.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4)) (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 a b) (*.f64 (hypot.f64 a b) (pow.f64 (hypot.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (hypot.f64 a b) 3) (hypot.f64 a b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2)) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 (-.f64 (pow.f64 a 4) (pow.f64 b 4)) 2) (pow.f64 (-.f64 (*.f64 a a) (*.f64 b b)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 (+.f64 (pow.f64 a 6) (pow.f64 b 6)) 2) (pow.f64 (-.f64 (+.f64 (pow.f64 a 4) (pow.f64 b 4)) (pow.f64 (*.f64 a b) 2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (pow.f64 a 4) (pow.f64 b 4)) (+.f64 (pow.f64 a 6) (pow.f64 b 6))) (*.f64 (-.f64 (*.f64 a a) (*.f64 b b)) (-.f64 (+.f64 (pow.f64 a 4) (pow.f64 b 4)) (pow.f64 (*.f64 a b) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 6) (pow.f64 b 6)) (-.f64 (pow.f64 a 4) (pow.f64 b 4))) (*.f64 (-.f64 (+.f64 (pow.f64 a 4) (pow.f64 b 4)) (pow.f64 (*.f64 a b) 2)) (-.f64 (*.f64 a a) (*.f64 b b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 6) (pow.f64 b 6)) (pow.f64 (hypot.f64 a b) 2)) (-.f64 (+.f64 (pow.f64 a 4) (pow.f64 b 4)) (pow.f64 (*.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (pow.f64 a 4) (pow.f64 b 4)) (pow.f64 (hypot.f64 a b) 2)) (-.f64 (*.f64 a a) (*.f64 b b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (+.f64 (pow.f64 a 6) (pow.f64 b 6))) (-.f64 (+.f64 (pow.f64 a 4) (pow.f64 b 4)) (pow.f64 (*.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (-.f64 (pow.f64 a 4) (pow.f64 b 4))) (-.f64 (*.f64 a a) (*.f64 b b)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 6))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 2 (*.f64 2 (log.f64 (hypot.f64 a b)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (*.f64 2 (log.f64 (hypot.f64 a b)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 a a) (pow.f64 (hypot.f64 a b) 2) (*.f64 (*.f64 b b) (pow.f64 (hypot.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b b) (pow.f64 (hypot.f64 a b) 2) (*.f64 (*.f64 a a) (pow.f64 (hypot.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 a a) (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b b)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b b) (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 a a)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (pow.f64 (exp.f64 b) b) 4)) 2)) (log.f64 (cbrt.f64 (pow.f64 (pow.f64 (exp.f64 b) b) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (pow.f64 (exp.f64 b) b) 4))) (log.f64 (sqrt.f64 (pow.f64 (pow.f64 (exp.f64 b) b) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 b (*.f64 b 4)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 b (*.f64 b 4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 b 4) 16) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cbrt.f64 (*.f64 b 2)) 2) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 b 2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 64 (pow.f64 b 6)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 b 4) 16))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (exp.f64 b) b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 b (*.f64 b 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 64 (pow.f64 b 6)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 b (*.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 b (*.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (fma.f64 2 (log.f64 b) (log.f64 4)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (fma.f64 2 (log.f64 b) (log.f64 4)) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 -4 (*.f64 b b)))) (/.f64 (*.f64 (pow.f64 b 4) 16) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 -4 (*.f64 b b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2))) 2) (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2)) (pow.f64 (cbrt.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2)) (*.f64 (pow.f64 (cbrt.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2))) 2) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) (*.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 64 (pow.f64 b 6) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 6)) (/.f64 1 (-.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) (pow.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) (/.f64 1 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 -4 (*.f64 b b)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) (pow.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2)) (fma.f64 64 (pow.f64 b 6) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 6))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 -4 (*.f64 b b))) (-.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 64 (pow.f64 b 6) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 6)) (-.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) (pow.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 64 (pow.f64 b 6) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 6)) (fma.f64 (pow.f64 b 4) 16 (-.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (pow.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 -4 (*.f64 b b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (fma.f64 64 (pow.f64 b 6) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 6))) (neg.f64 (-.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) (pow.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16))) (neg.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 -4 (*.f64 b b)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (pow.f64 b 4) 16) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4)) (-.f64 (*.f64 b (*.f64 b 4)) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 64 (pow.f64 b 6) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 6)) 1) (-.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) (pow.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) 1) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 -4 (*.f64 b b))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2))) 2) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (-.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) (pow.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2)) (fma.f64 64 (pow.f64 b 6) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 6))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 -4 (*.f64 b b))) (-.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))) (pow.f64 (pow.f64 (exp.f64 b) b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)) (+.f64 1 (expm1.f64 (*.f64 b (*.f64 b 4))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))) (+.f64 1 (expm1.f64 (*.f64 b (*.f64 b 4))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 b (*.f64 b 4)))) (exp.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (pow.f64 (exp.f64 b) b) 4) (+.f64 1 (expm1.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 b (*.f64 b 4)))) (+.f64 1 (expm1.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 b (*.f64 b 4) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b b) 4 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 a b) 2) (pow.f64 (hypot.f64 a b) 2) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) 1 (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 4 (*.f64 b b) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b (*.f64 b 4)) 1 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 b (*.f64 b 4)) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4)) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (*.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) (pow.f64 (hypot.f64 a b) 2)) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4)) (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 b 4)) (*.f64 (pow.f64 (cbrt.f64 b) 2) 4) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 b 2)) 2) (cbrt.f64 (*.f64 (pow.f64 b 4) 16)) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 (pow.f64 b 4) 16)) (pow.f64 (cbrt.f64 (*.f64 b 2)) 2) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 a b) (*.f64 (hypot.f64 a b) (pow.f64 (hypot.f64 a b) 2)) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b 2) (*.f64 b 2) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1) 1 -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b 4) b (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 a b) 3) (hypot.f64 a b) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1)) 2) (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 1 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2))) (hypot.f64 1 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 4 (cbrt.f64 (pow.f64 b 4))) (pow.f64 (cbrt.f64 b) 2) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 b 4) 1) b (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 b 4) (pow.f64 (cbrt.f64 b) 2)) (cbrt.f64 b) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 b 4) (sqrt.f64 b)) (sqrt.f64 b) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2)) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) (*.f64 b (*.f64 b 4)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 (fma.f64 b (*.f64 b 4) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 b (*.f64 b 4)) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 b (*.f64 b 4) -1) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1))) 2)) (log.f64 (cbrt.f64 (exp.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)))) (log.f64 (sqrt.f64 (exp.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)) (pow.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)) 2) (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (sqrt.f64 (fma.f64 b (*.f64 b 4) -1))) (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (sqrt.f64 (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 3) -1) (/.f64 1 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) (hypot.f64 1 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2) -1) (/.f64 1 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 1) (-.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) (hypot.f64 1 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))) 2) (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 3) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1) (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 3) -1) (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) (hypot.f64 1 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 3) -1) (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2) (-.f64 1 (*.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2) -1) (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 3) -1)) (neg.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) (hypot.f64 1 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2) -1)) (neg.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 6) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 3)) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (-.f64 (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2) (*.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (fma.f64 b (*.f64 b 4) -1)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (pow.f64 (fma.f64 b (*.f64 b 4) -1) 2)) (-.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (fma.f64 b (*.f64 b 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (sqrt.f64 (fma.f64 b (*.f64 b 4) -1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) (hypot.f64 1 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))) 2) (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 3) -1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1) (+.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2) -1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))) (exp.f64 (fma.f64 b (*.f64 b 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (fma.f64 b (*.f64 b 4) -1)) (exp.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (fma.f64 b (*.f64 b 4) -1)) (+.f64 1 (expm1.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (*.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (+.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 b (*.f64 b 4) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b b) 4 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 a b) 2) (pow.f64 (hypot.f64 a b) 2) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 a b) 2) (pow.f64 (hypot.f64 a b) 2) (*.f64 (fma.f64 b (*.f64 b 4) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) 1 (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) 1 (*.f64 (fma.f64 b (*.f64 b 4) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 4 (*.f64 b b) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b (*.f64 b 4)) 1 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 1 -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 (fma.f64 b (*.f64 b 4) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 b (*.f64 b 4)) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 b (*.f64 b 4) -1) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2))) 2) (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2)) (pow.f64 (cbrt.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2))) 2) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2) 2)) (*.f64 (pow.f64 (cbrt.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2))) 2) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4)) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4)) (*.f64 (fma.f64 b (*.f64 b 4) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (*.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) (pow.f64 (hypot.f64 a b) 2)) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (*.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) (pow.f64 (hypot.f64 a b) 2)) (*.f64 (fma.f64 b (*.f64 b 4) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4)) (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4)) (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2) (*.f64 (fma.f64 b (*.f64 b 4) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 b 4)) (*.f64 (pow.f64 (cbrt.f64 b) 2) 4) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 b 2)) 2) (cbrt.f64 (*.f64 (pow.f64 b 4) 16)) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 (pow.f64 b 4) 16)) (pow.f64 (cbrt.f64 (*.f64 b 2)) 2) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) (*.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 a b) (*.f64 (hypot.f64 a b) (pow.f64 (hypot.f64 a b) 2)) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 a b) (*.f64 (hypot.f64 a b) (pow.f64 (hypot.f64 a b) 2)) (*.f64 (fma.f64 b (*.f64 b 4) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b 2) (*.f64 b 2) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 64 (pow.f64 b 6) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 6)) (/.f64 1 (-.f64 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) (pow.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)) 2))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 4) (*.f64 (pow.f64 b 4) 16)) (/.f64 1 (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) (*.f64 -4 (*.f64 b b)))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b 4) b (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 a b) 3) (hypot.f64 a b) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (hypot.f64 a b) 3) (hypot.f64 a b) (*.f64 (fma.f64 b (*.f64 b 4) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 b (*.f64 b 4) -1)) 2) (cbrt.f64 (fma.f64 b (*.f64 b 4) -1)) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (fma.f64 b (*.f64 b 4) -1)) (sqrt.f64 (fma.f64 b (*.f64 b 4) -1)) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 b 2 1) (fma.f64 b 2 -1) (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 4 (cbrt.f64 (pow.f64 b 4))) (pow.f64 (cbrt.f64 b) 2) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 b 4) 1) b (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 b 4) (pow.f64 (cbrt.f64 b) 2)) (cbrt.f64 b) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 b 4) (sqrt.f64 b)) (sqrt.f64 b) (+.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 2) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2)) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (pow.f64 (hypot.f64 a b) 2) (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 2)) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) (*.f64 (fma.f64 b (*.f64 b 4) -1) 1))))))

simplify135.0ms (1.5%)

Algorithm
egg-herbie
Rules
903×fma-def_binary64
730×fma-neg_binary64
349×*-commutative_binary64
348×associate-*l*_binary64
348×unswap-sqr_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0471572
11321384
23151308
39731308
431841308
570891308
Stop Event
node limit
Counts
297 → 249
Calls
Call 1
Inputs
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (pow.f64 b 2))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 a 4))))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 a 4))))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 a 4))))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 a 4))))
(pow.f64 a 4)
(+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) 1)
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))) 1)
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))) 1)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(-.f64 (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(-.f64 (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(-.f64 (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
Outputs
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)))
(fma.f64 (*.f64 b a) (*.f64 b (*.f64 2 a)) (pow.f64 b 4))
(fma.f64 a (*.f64 b (*.f64 2 (*.f64 b a))) (pow.f64 b 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(*.f64 a (*.f64 a (fma.f64 b (*.f64 b 2) (*.f64 a a))))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(*.f64 a (*.f64 a (fma.f64 b (*.f64 b 2) (*.f64 a a))))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(*.f64 a (*.f64 a (fma.f64 b (*.f64 b 2) (*.f64 a a))))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)))
(fma.f64 (*.f64 b a) (*.f64 b (*.f64 2 a)) (pow.f64 b 4))
(fma.f64 a (*.f64 b (*.f64 2 (*.f64 b a))) (pow.f64 b 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(pow.f64 b 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 b 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)))
(fma.f64 (*.f64 b a) (*.f64 b (*.f64 2 a)) (pow.f64 b 4))
(fma.f64 a (*.f64 b (*.f64 2 (*.f64 b a))) (pow.f64 b 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (pow.f64 b 4)))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (*.f64 2 (*.f64 a a)) (pow.f64 b 3)) (pow.f64 a 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(*.f64 b (*.f64 b 4))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(fma.f64 b (*.f64 b 4) (pow.f64 b 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 4))
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(*.f64 a (*.f64 a (fma.f64 b (*.f64 b 2) (*.f64 a a))))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 a 4))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 a 4))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(*.f64 a (*.f64 a (fma.f64 b (*.f64 b 2) (*.f64 a a))))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 a 4))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 a 4))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(pow.f64 a 4)
(+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(+.f64 (pow.f64 a 4) (*.f64 (*.f64 b b) (+.f64 4 (*.f64 2 (*.f64 a a)))))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4))
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 4))
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)))
(+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 4))
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)))
(+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4)))
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 4)))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 a 4))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (pow.f64 a 4))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) (pow.f64 a 4))
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) -1)
(fma.f64 4 (*.f64 b b) (+.f64 (pow.f64 b 4) -1))
(fma.f64 (*.f64 b b) (fma.f64 b b 4) -1)
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))) 1)
(+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) -1)
(+.f64 (pow.f64 b 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1))
(fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1)
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) -1)
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(*.f64 a (*.f64 a (fma.f64 b (*.f64 b 2) (*.f64 a a))))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(pow.f64 a 4)
(+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 a 4))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 a 4))
(fma.f64 2 (*.f64 b (*.f64 b (*.f64 a a))) (pow.f64 a 4))
(*.f64 a (*.f64 a (fma.f64 b (*.f64 b 2) (*.f64 a a))))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (pow.f64 b 4) (pow.f64 a 4)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
(-.f64 (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(+.f64 (pow.f64 a 4) (-.f64 (*.f64 (*.f64 b b) (+.f64 4 (*.f64 2 (*.f64 a a)))) 1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) 4)) -1))
(-.f64 (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(-.f64 (+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 4))
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)))
(-.f64 (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(-.f64 (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(pow.f64 b 4)
(+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))
(fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 4))
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) 4)) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)))
(-.f64 (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))
(-.f64 (+.f64 (pow.f64 a 4) (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))) 1)
(+.f64 (+.f64 (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 a 4))) -1)
(+.f64 (pow.f64 b 4) (+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4) -1)))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 b b (fma.f64 2 (*.f64 a a) 4)) -1))
(fma.f64 b (fma.f64 b (fma.f64 2 (*.f64 a a) 4) (pow.f64 b 3)) (+.f64 (pow.f64 a 4) -1))
(+.f64 (pow.f64 a 4) (fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1))

eval321.0ms (3.6%)

Compiler

Compiled 9937 to 6651 computations (33.1% saved)

prune202.0ms (2.2%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New4355440
Fresh000
Picked011
Done101
Total4366442
Error
0b
Counts
442 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
15.0b
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
11.1b
(-.f64 (pow.f64 a 4) 1)
14.9b
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b))) 1)
2.3b
(expm1.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))
14.9b
(-.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 1)
Compiler

Compiled 135 to 100 computations (25.9% saved)

localize74.0ms (0.8%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(hypot.f64 a b)
0.0b
(log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))
0.0b
(pow.f64 (hypot.f64 a b) 2)
2.3b
(expm1.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))
Compiler

Compiled 60 to 36 computations (40% saved)

series69.0ms (0.8%)

Counts
3 → 72
Calls

18 calls:

TimeVariablePointExpression
13.0ms
a
@inf
(expm1.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))
11.0ms
a
@0
(expm1.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))
10.0ms
b
@0
(expm1.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))
9.0ms
b
@inf
(expm1.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))
8.0ms
a
@0
(log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))

rewrite96.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
917×pow1_binary64
837×add-log-exp_binary64
837×log1p-expm1-u_binary64
837×expm1-log1p-u_binary64
817×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01142
121941
2241541
Stop Event
node limit
Counts
3 → 57
Calls
Call 1
Inputs
(expm1.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))
(pow.f64 (hypot.f64 a b) 2)
(log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1)) (cbrt.f64 (pow.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1) 2)) (cbrt.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1)) (sqrt.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) 3) 1) (+.f64 (*.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b)))) (+.f64 1 (*.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b)))) 1) (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (+.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))) -1)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 a a) (*.f64 b b))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 b b) (*.f64 a a))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (pow.f64 (hypot.f64 a b) 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 a b) (hypot.f64 a b))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (hypot.f64 a b) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (hypot.f64 a b) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) (cbrt.f64 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) (*.f64 (cbrt.f64 (hypot.f64 a b)) (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (hypot.f64 a b) 4)) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (hypot.f64 a b)) (*.f64 (sqrt.f64 (hypot.f64 a b)) (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (hypot.f64 a b) (sqrt.f64 (hypot.f64 a b))) (sqrt.f64 (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (hypot.f64 a b) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2)) (cbrt.f64 (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 a a) 3) (pow.f64 (*.f64 b b) 3)) (+.f64 (*.f64 (*.f64 a a) (*.f64 a a)) (-.f64 (*.f64 (*.f64 b b) (*.f64 b b)) (*.f64 (*.f64 a a) (*.f64 b b)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 a a) (*.f64 a a)) (*.f64 (*.f64 b b) (*.f64 b b))) (-.f64 (*.f64 a a) (*.f64 b b)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (hypot.f64 a b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (hypot.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 (hypot.f64 a b) 2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (hypot.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (hypot.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (pow.f64 (hypot.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 a a (*.f64 b b))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (cbrt.f64 (+.f64 (pow.f64 (hypot.f64 a b) 4) (*.f64 4 (*.f64 b b))))) (log.f64 (cbrt.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))) (log.f64 (sqrt.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))) (pow.f64 (cbrt.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))) 2) (cbrt.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))) (sqrt.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 2 b)))))))))

simplify165.0ms (1.8%)

Algorithm
egg-herbie
Rules
589×associate-/l*_binary64
585×fma-def_binary64
323×associate-+r+_binary64
314×+-commutative_binary64
290×associate-+l+_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
04265889
114584940
258264127
Stop Event
node limit
Counts
129 → 167
Calls
Call 1
Inputs
(-.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))) 2) 1)
(-.f64 (+.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))) 2) (*.f64 2 (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))))))) 1)
(-.f64 (+.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))) 2) (+.f64 (*.f64 (+.f64 (*.f64 2 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (*.f64 1/12 (+.f64 (*.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (pow.f64 b 2) (sqrt.f64 (/.f64 1 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) 2))))))) (*.f64 (pow.f64 a 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (*.f64 2 (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))))))) 1)
(-.f64 (+.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))) 2) (+.f64 (*.f64 (+.f64 (*.f64 2 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (*.f64 1/12 (+.f64 (*.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (pow.f64 b 2) (sqrt.f64 (/.f64 1 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) 2))))))) (*.f64 (pow.f64 a 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (+.f64 (*.f64 (pow.f64 a 6) (*.f64 (+.f64 (*.f64 4/3 (*.f64 (pow.f64 b 6) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) 3) (pow.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 3)))))) (+.f64 (*.f64 1/360 (+.f64 (*.f64 -360 (/.f64 (*.f64 (pow.f64 b 2) (-.f64 1 (pow.f64 (*.f64 (pow.f64 b 2) (sqrt.f64 (/.f64 1 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) 2))) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (+.f64 (*.f64 -360 (*.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 (sqrt.f64 (/.f64 1 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (pow.f64 b 2)) 2)) (pow.f64 b 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (pow.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 3)))))) (*.f64 240 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) 3) (pow.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 3)))) (pow.f64 b 6)))))) (*.f64 1/6 (*.f64 (*.f64 (pow.f64 b 2) (+.f64 (*.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (pow.f64 b 2) (sqrt.f64 (/.f64 1 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) 2)))))) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (*.f64 2 (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))))))))) 1)
(-.f64 (pow.f64 (/.f64 1 a) -4) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 (/.f64 1 a) -4)) 1)
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2))))) (+.f64 (*.f64 2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 (/.f64 1 a) -4)))) 1)
(-.f64 (+.f64 (*.f64 4/3 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (pow.f64 b 4)) (+.f64 (*.f64 1/12 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2))))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 b 2)) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 1/360 (/.f64 (+.f64 (*.f64 360 (-.f64 (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2))) (+.f64 (*.f64 -1/4 (pow.f64 b 6)) (*.f64 1/4 (pow.f64 b 6)))) (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2)))) (+.f64 (*.f64 -360 (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2))) (*.f64 240 (pow.f64 b 6)))) (pow.f64 a 2))) (pow.f64 (/.f64 1 a) -4))))))) 1)
(-.f64 (pow.f64 (/.f64 -1 a) -4) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 (/.f64 -1 a) -4)) 1)
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2))))) (+.f64 (*.f64 2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 (/.f64 -1 a) -4)))) 1)
(-.f64 (+.f64 (*.f64 4/3 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (pow.f64 b 4)) (+.f64 (*.f64 1/12 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2))))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 b 2)) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 1/360 (/.f64 (+.f64 (*.f64 360 (-.f64 (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2))) (+.f64 (*.f64 -1/4 (pow.f64 b 6)) (*.f64 1/4 (pow.f64 b 6)))) (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2)))) (+.f64 (*.f64 -360 (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2))) (*.f64 240 (pow.f64 b 6)))) (pow.f64 a 2))) (pow.f64 (/.f64 -1 a) -4))))))) 1)
(-.f64 (pow.f64 (pow.f64 a 2) 2) 1)
(-.f64 (+.f64 (*.f64 (pow.f64 a 4) (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (pow.f64 (pow.f64 a 2) 2)) 1)
(-.f64 (+.f64 (*.f64 (pow.f64 a 4) (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (+.f64 (pow.f64 (pow.f64 a 2) 2) (*.f64 (pow.f64 a 4) (*.f64 (+.f64 (*.f64 1/2 (pow.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) 2)) (*.f64 1/12 (+.f64 (*.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2) (pow.f64 a 8))) (*.f64 12 (/.f64 (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2)) (pow.f64 a 4)))))) (pow.f64 b 4))))) 1)
(-.f64 (+.f64 (*.f64 (pow.f64 a 4) (*.f64 (pow.f64 b 6) (+.f64 (*.f64 1/6 (pow.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) 3)) (+.f64 (*.f64 1/360 (+.f64 (*.f64 30 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3) (pow.f64 a 12))) (*.f64 -360 (/.f64 (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2))) (pow.f64 a 8))))) (*.f64 1/12 (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (+.f64 (*.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2) (pow.f64 a 8))) (*.f64 12 (/.f64 (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2)) (pow.f64 a 4)))))))))) (+.f64 (*.f64 (pow.f64 a 4) (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (+.f64 (pow.f64 (pow.f64 a 2) 2) (*.f64 (pow.f64 a 4) (*.f64 (+.f64 (*.f64 1/2 (pow.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) 2)) (*.f64 1/12 (+.f64 (*.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2) (pow.f64 a 8))) (*.f64 12 (/.f64 (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2)) (pow.f64 a 4)))))) (pow.f64 b 4)))))) 1)
(-.f64 (pow.f64 (/.f64 1 b) -4) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 (/.f64 1 b) -4))) 1)
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2))))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (*.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (pow.f64 (/.f64 1 b) -4))))) 1)
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2))))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 (/.f64 1 b) -4) (+.f64 (*.f64 1/360 (/.f64 (+.f64 (*.f64 -180 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))) (+.f64 (*.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3)) (*.f64 360 (-.f64 (+.f64 (*.f64 1/4 (pow.f64 a 6)) (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2))) (*.f64 -1/4 (pow.f64 a 6)))) (*.f64 1/2 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))))))) (pow.f64 b 2))) (+.f64 (*.f64 1/12 (/.f64 (*.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (+.f64 4 (*.f64 2 (pow.f64 a 2)))) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (+.f64 (*.f64 4 (pow.f64 b 2)) (*.f64 1/6 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3) (pow.f64 b 2)))))))))) 1)
(-.f64 (pow.f64 (/.f64 -1 b) -4) 1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 (/.f64 -1 b) -4) (*.f64 4 (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2))))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 (/.f64 -1 b) -4) (+.f64 (*.f64 4 (pow.f64 b 2)) (*.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)))))) 1)
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2))))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 1/360 (/.f64 (+.f64 (*.f64 -180 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))) (+.f64 (*.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3)) (*.f64 360 (-.f64 (+.f64 (*.f64 1/4 (pow.f64 a 6)) (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2))) (*.f64 -1/4 (pow.f64 a 6)))) (*.f64 1/2 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))))))) (pow.f64 b 2))) (+.f64 (pow.f64 (/.f64 -1 b) -4) (+.f64 (*.f64 1/12 (/.f64 (*.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (+.f64 4 (*.f64 2 (pow.f64 a 2)))) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (+.f64 (*.f64 4 (pow.f64 b 2)) (*.f64 1/6 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3) (pow.f64 b 2)))))))))) 1)
(pow.f64 b 2)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 (+.f64 (*.f64 5/64 (/.f64 1 (pow.f64 b 6))) (*.f64 -1 (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 b 6))) (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2)))) (pow.f64 a 8)) (+.f64 (pow.f64 b 2) (pow.f64 a 2)))
(pow.f64 a 2)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (pow.f64 b 2) (pow.f64 a 2))))
(+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4))) (+.f64 (pow.f64 b 2) (pow.f64 a 2))))))
(pow.f64 a 2)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (pow.f64 b 2) (pow.f64 a 2))))
(+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4))) (+.f64 (pow.f64 b 2) (pow.f64 a 2))))))
(pow.f64 a 2)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 (+.f64 (*.f64 -1 (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2) (*.f64 1/16 (/.f64 1 (pow.f64 a 6))))) (*.f64 5/64 (/.f64 1 (pow.f64 a 6)))) (pow.f64 b 8)) (+.f64 (pow.f64 b 2) (pow.f64 a 2)))
(pow.f64 b 2)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))) (+.f64 (pow.f64 b 2) (+.f64 (pow.f64 a 2) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))))))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4))) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))) (+.f64 (pow.f64 b 2) (+.f64 (pow.f64 a 2) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))))))))
(pow.f64 b 2)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))) (+.f64 (pow.f64 b 2) (+.f64 (pow.f64 a 2) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))))))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4))) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))) (+.f64 (pow.f64 b 2) (+.f64 (pow.f64 a 2) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))))))))
(log.f64 (sqrt.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))))
(+.f64 (log.f64 (sqrt.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))))))
(+.f64 (log.f64 (sqrt.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 12 (*.f64 (-.f64 1 (pow.f64 (*.f64 (sqrt.f64 (/.f64 1 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (pow.f64 b 2)) 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))) (*.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))))))) (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))))
(+.f64 (log.f64 (sqrt.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 12 (*.f64 (-.f64 1 (pow.f64 (*.f64 (sqrt.f64 (/.f64 1 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (pow.f64 b 2)) 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))) (*.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))))))) (+.f64 (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))))) (*.f64 1/720 (*.f64 (pow.f64 a 6) (+.f64 (*.f64 240 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) 3) (pow.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 3)))) (pow.f64 b 6))) (+.f64 (*.f64 -360 (*.f64 (*.f64 (pow.f64 b 2) (-.f64 1 (pow.f64 (*.f64 (pow.f64 b 2) (sqrt.f64 (/.f64 1 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) 2))) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) 3) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))) (*.f64 -360 (/.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 (sqrt.f64 (/.f64 1 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (pow.f64 b 2)) 2)) (pow.f64 b 2)) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))))))))
(*.f64 -2 (log.f64 (/.f64 1 a)))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 a))) (/.f64 (pow.f64 b 2) (pow.f64 a 2)))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 a))) (+.f64 (/.f64 (pow.f64 b 2) (pow.f64 a 2)) (*.f64 1/24 (/.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 a 4)))))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 a))) (+.f64 (/.f64 (pow.f64 b 2) (pow.f64 a 2)) (+.f64 (*.f64 1/720 (/.f64 (+.f64 (*.f64 360 (-.f64 (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2))) (+.f64 (*.f64 1/4 (pow.f64 b 6)) (*.f64 -1/4 (pow.f64 b 6)))) (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2)))) (+.f64 (*.f64 -360 (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2))) (*.f64 240 (pow.f64 b 6)))) (pow.f64 a 6))) (*.f64 1/24 (/.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 a 4))))))
(*.f64 -2 (log.f64 (/.f64 -1 a)))
(+.f64 (/.f64 (pow.f64 b 2) (pow.f64 a 2)) (*.f64 -2 (log.f64 (/.f64 -1 a))))
(+.f64 (/.f64 (pow.f64 b 2) (pow.f64 a 2)) (+.f64 (*.f64 -2 (log.f64 (/.f64 -1 a))) (*.f64 1/24 (/.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 a 4)))))
(+.f64 (/.f64 (pow.f64 b 2) (pow.f64 a 2)) (+.f64 (*.f64 1/720 (/.f64 (+.f64 (*.f64 360 (-.f64 (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2))) (+.f64 (*.f64 1/4 (pow.f64 b 6)) (*.f64 -1/4 (pow.f64 b 6)))) (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2)))) (+.f64 (*.f64 -360 (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2))) (*.f64 240 (pow.f64 b 6)))) (pow.f64 a 6))) (+.f64 (*.f64 -2 (log.f64 (/.f64 -1 a))) (*.f64 1/24 (/.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 a 4))))))
(log.f64 (pow.f64 a 2))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (log.f64 (pow.f64 a 2)))
(+.f64 (*.f64 1/24 (*.f64 (+.f64 (*.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2) (pow.f64 a 8))) (*.f64 12 (/.f64 (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2)) (pow.f64 a 4)))) (pow.f64 b 4))) (+.f64 (*.f64 1/2 (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (log.f64 (pow.f64 a 2))))
(+.f64 (*.f64 1/24 (*.f64 (+.f64 (*.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2) (pow.f64 a 8))) (*.f64 12 (/.f64 (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2)) (pow.f64 a 4)))) (pow.f64 b 4))) (+.f64 (*.f64 1/2 (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (+.f64 (*.f64 1/720 (*.f64 (+.f64 (*.f64 -360 (/.f64 (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2))) (pow.f64 a 8))) (*.f64 30 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3) (pow.f64 a 12)))) (pow.f64 b 6))) (log.f64 (pow.f64 a 2)))))
(*.f64 -2 (log.f64 (/.f64 1 b)))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 b))) (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 b))) (+.f64 (*.f64 1/24 (/.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (pow.f64 b 4))) (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 b))) (+.f64 (*.f64 1/720 (/.f64 (+.f64 (*.f64 -180 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))) (+.f64 (*.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3)) (*.f64 360 (-.f64 (+.f64 (*.f64 1/4 (pow.f64 a 6)) (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2))) (*.f64 -1/4 (pow.f64 a 6)))) (*.f64 1/2 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))))))) (pow.f64 b 6))) (+.f64 (*.f64 1/24 (/.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (pow.f64 b 4))) (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))))
(*.f64 -2 (log.f64 (/.f64 -1 b)))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) (*.f64 -2 (log.f64 (/.f64 -1 b))))
(+.f64 (*.f64 1/24 (/.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (pow.f64 b 4))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) (*.f64 -2 (log.f64 (/.f64 -1 b)))))
(+.f64 (*.f64 1/720 (/.f64 (+.f64 (*.f64 -180 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))) (+.f64 (*.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3)) (*.f64 360 (-.f64 (+.f64 (*.f64 1/4 (pow.f64 a 6)) (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2))) (*.f64 -1/4 (pow.f64 a 6)))) (*.f64 1/2 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))))))) (pow.f64 b 6))) (+.f64 (*.f64 1/24 (/.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (pow.f64 b 4))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) (*.f64 -2 (log.f64 (/.f64 -1 b))))))
Outputs
(-.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))) 2) 1)
(+.f64 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 2) -1)
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) -1)
(fma.f64 (*.f64 b b) (+.f64 4 (*.f64 b b)) -1)
(-.f64 (+.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))) 2) (*.f64 2 (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))))))) 1)
(+.f64 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 2) (-.f64 (*.f64 (*.f64 (*.f64 2 (*.f64 a a)) (*.f64 b b)) (sqrt.f64 (/.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 1))
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 a (*.f64 a (*.f64 b b)))) -1))
(+.f64 -1 (*.f64 (*.f64 b b) (+.f64 (+.f64 4 (*.f64 b b)) (*.f64 a (*.f64 a 2)))))
(-.f64 (+.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))) 2) (+.f64 (*.f64 (+.f64 (*.f64 2 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (*.f64 1/12 (+.f64 (*.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (pow.f64 b 2) (sqrt.f64 (/.f64 1 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) 2))))))) (*.f64 (pow.f64 a 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (*.f64 2 (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))))))) 1)
(+.f64 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 2) (-.f64 (fma.f64 (fma.f64 2 (/.f64 (pow.f64 b 4) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (*.f64 1/12 (fma.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (*.f64 b b) (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 2))))))) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 a 4)) (*.f64 (*.f64 (*.f64 2 (*.f64 a a)) (*.f64 b b)) (sqrt.f64 (/.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) 1))
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (+.f64 (fma.f64 (fma.f64 2 (/.f64 (pow.f64 b 4) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (+.f64 (/.f64 (neg.f64 (pow.f64 b 4)) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (*.f64 1 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) 2)))))) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 a 4)) (*.f64 2 (*.f64 a (*.f64 a (*.f64 b b))))) -1))
(+.f64 (*.f64 (+.f64 (*.f64 (+.f64 (*.f64 (/.f64 (pow.f64 b 4) (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4)) 1) (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4))) (-.f64 1 (*.f64 (pow.f64 b 4) (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) (pow.f64 a 4)) 1) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) -1))
(-.f64 (+.f64 (pow.f64 (sqrt.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))) 2) (+.f64 (*.f64 (+.f64 (*.f64 2 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (*.f64 1/12 (+.f64 (*.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (pow.f64 b 2) (sqrt.f64 (/.f64 1 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) 2))))))) (*.f64 (pow.f64 a 4) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (+.f64 (*.f64 (pow.f64 a 6) (*.f64 (+.f64 (*.f64 4/3 (*.f64 (pow.f64 b 6) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) 3) (pow.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 3)))))) (+.f64 (*.f64 1/360 (+.f64 (*.f64 -360 (/.f64 (*.f64 (pow.f64 b 2) (-.f64 1 (pow.f64 (*.f64 (pow.f64 b 2) (sqrt.f64 (/.f64 1 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) 2))) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (+.f64 (*.f64 -360 (*.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 (sqrt.f64 (/.f64 1 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (pow.f64 b 2)) 2)) (pow.f64 b 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (pow.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 3)))))) (*.f64 240 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) 3) (pow.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 3)))) (pow.f64 b 6)))))) (*.f64 1/6 (*.f64 (*.f64 (pow.f64 b 2) (+.f64 (*.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (pow.f64 b 2) (sqrt.f64 (/.f64 1 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) 2)))))) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (*.f64 2 (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))))))))) 1)
(+.f64 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 2) (-.f64 (fma.f64 (fma.f64 2 (/.f64 (pow.f64 b 4) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (*.f64 1/12 (fma.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (*.f64 b b) (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 2))))))) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 a 4)) (fma.f64 (pow.f64 a 6) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4/3 (*.f64 (pow.f64 b 6) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 3) (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 3))))) (fma.f64 1/360 (fma.f64 240 (*.f64 (pow.f64 b 6) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 3) (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 3))))) (*.f64 -360 (+.f64 (*.f64 (*.f64 b b) (*.f64 (-.f64 1 (pow.f64 (*.f64 (*.f64 b b) (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 2)) (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 3)))))) (*.f64 (/.f64 (-.f64 1 (pow.f64 (*.f64 (*.f64 b b) (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 2)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) (/.f64 (*.f64 b b) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) (*.f64 1/6 (*.f64 (*.f64 b b) (*.f64 (fma.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (*.f64 b b) (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 2))))) (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))))))) (*.f64 (*.f64 (*.f64 2 (*.f64 a a)) (*.f64 b b)) (sqrt.f64 (/.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) 1))
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (+.f64 (+.f64 (*.f64 2 (*.f64 a (*.f64 a (*.f64 b b)))) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (+.f64 (*.f64 (fma.f64 2 (/.f64 (pow.f64 b 4) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (+.f64 (/.f64 (neg.f64 (pow.f64 b 4)) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (*.f64 1 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) 2)))))) (pow.f64 a 4)) (*.f64 (pow.f64 a 6) (fma.f64 4/3 (*.f64 (pow.f64 b 6) (sqrt.f64 (/.f64 1 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 6)))) (fma.f64 1/360 (fma.f64 -360 (fma.f64 (*.f64 b b) (*.f64 (-.f64 1 (pow.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) 2)) (sqrt.f64 (/.f64 1 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 4)))) (*.f64 (/.f64 (-.f64 1 (pow.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) 2)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) (/.f64 (*.f64 b b) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (*.f64 (pow.f64 b 6) (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 6))) 240))) (*.f64 (*.f64 (*.f64 b b) (fma.f64 (*.f64 12 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) (-.f64 1 (pow.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) 2)) (*.f64 (/.f64 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) (/.f64 -12 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 1/6)))))))) -1))
(+.f64 -1 (+.f64 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (+.f64 (*.f64 (+.f64 (*.f64 (/.f64 (pow.f64 b 4) (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4)) 1) (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4))) (-.f64 1 (*.f64 (pow.f64 b 4) (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) (pow.f64 a 4)) (*.f64 (pow.f64 a 6) (fma.f64 4/3 (*.f64 (pow.f64 b 6) (sqrt.f64 (/.f64 1 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 6)))) (fma.f64 1/360 (fma.f64 -360 (*.f64 (-.f64 1 (*.f64 (pow.f64 b 4) (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (+.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 4))))) (/.f64 b (/.f64 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4) b)))) (*.f64 (pow.f64 b 6) (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 6))) 240))) (*.f64 (*.f64 (*.f64 b b) (fma.f64 (/.f64 (pow.f64 b 4) (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4)) -12 (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4))) (-.f64 1 (*.f64 (pow.f64 b 4) (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))))) (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4))) 1/6))))))) (*.f64 (*.f64 b b) (+.f64 (+.f64 4 (*.f64 b b)) (*.f64 a (*.f64 a 2))))))
(-.f64 (pow.f64 (/.f64 1 a) -4) 1)
(+.f64 (pow.f64 (/.f64 1 a) -4) -1)
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 (/.f64 1 a) -4)) 1)
(+.f64 (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (pow.f64 (/.f64 1 a) -4)) -1)
(+.f64 (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (pow.f64 (/.f64 1 a) -4)) -1)
(+.f64 (pow.f64 (/.f64 1 a) -4) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) -1))
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2))))) (+.f64 (*.f64 2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 (/.f64 1 a) -4)))) 1)
(+.f64 (fma.f64 1/12 (fma.f64 -12 (pow.f64 b 4) (*.f64 12 (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (fma.f64 2 (pow.f64 b 4) (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (pow.f64 (/.f64 1 a) -4)))) -1)
(+.f64 (fma.f64 2 (pow.f64 b 4) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (pow.f64 (/.f64 1 a) -4))) (-.f64 (+.f64 (neg.f64 (pow.f64 b 4)) (*.f64 1 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))))) 1))
(+.f64 (+.f64 (pow.f64 b 4) (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (+.f64 (pow.f64 (/.f64 1 a) -4) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) -1)))
(-.f64 (+.f64 (*.f64 4/3 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (pow.f64 b 4)) (+.f64 (*.f64 1/12 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2))))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 b 2)) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 1/360 (/.f64 (+.f64 (*.f64 360 (-.f64 (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2))) (+.f64 (*.f64 -1/4 (pow.f64 b 6)) (*.f64 1/4 (pow.f64 b 6)))) (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2)))) (+.f64 (*.f64 -360 (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2))) (*.f64 240 (pow.f64 b 6)))) (pow.f64 a 2))) (pow.f64 (/.f64 1 a) -4))))))) 1)
(+.f64 (fma.f64 4/3 (/.f64 (pow.f64 b 6) (*.f64 a a)) (fma.f64 2 (pow.f64 b 4) (fma.f64 1/12 (fma.f64 -12 (pow.f64 b 4) (*.f64 12 (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (fma.f64 1/6 (/.f64 (fma.f64 -12 (pow.f64 b 4) (*.f64 12 (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (/.f64 (*.f64 a a) (*.f64 b b))) (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (fma.f64 1/360 (/.f64 (fma.f64 360 (-.f64 (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 (pow.f64 b 4) 0)) (*.f64 (pow.f64 b 6) 0)) (*.f64 (*.f64 b b) (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (fma.f64 -360 (*.f64 (*.f64 b b) (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4))) (*.f64 (pow.f64 b 6) 240))) (*.f64 a a)) (pow.f64 (/.f64 1 a) -4))))))) -1)
(+.f64 (fma.f64 4/3 (/.f64 (pow.f64 b 6) (*.f64 a a)) (+.f64 (fma.f64 1/6 (*.f64 (/.f64 (*.f64 b b) a) (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (*.f64 (pow.f64 b 4) -12)) a)) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (fma.f64 1/360 (/.f64 (fma.f64 360 (*.f64 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (neg.f64 (*.f64 b b))) (fma.f64 (pow.f64 b 6) 240 (*.f64 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (*.f64 (*.f64 b b) -360)))) (*.f64 a a)) (pow.f64 (/.f64 1 a) -4)))) (fma.f64 2 (pow.f64 b 4) (+.f64 (neg.f64 (pow.f64 b 4)) (*.f64 1 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)))))))) -1)
(+.f64 (+.f64 (fma.f64 1/6 (*.f64 (*.f64 (/.f64 b a) (/.f64 b a)) (fma.f64 12 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 (pow.f64 b 4) -12))) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (fma.f64 1/360 (/.f64 (fma.f64 360 (*.f64 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 b (neg.f64 b))) (fma.f64 (pow.f64 b 6) 240 (*.f64 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 (*.f64 b b) -360)))) (*.f64 a a)) (pow.f64 (/.f64 1 a) -4)))) (+.f64 (pow.f64 b 4) (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)))) (fma.f64 4/3 (/.f64 (pow.f64 b 6) (*.f64 a a)) -1))
(-.f64 (pow.f64 (/.f64 -1 a) -4) 1)
(+.f64 (pow.f64 (/.f64 -1 a) -4) -1)
(+.f64 -1 (pow.f64 (/.f64 -1 a) -4))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 (/.f64 -1 a) -4)) 1)
(+.f64 (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (pow.f64 (/.f64 -1 a) -4)) -1)
(+.f64 -1 (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (pow.f64 (/.f64 -1 a) -4)))
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2))))) (+.f64 (*.f64 2 (pow.f64 b 4)) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (pow.f64 (/.f64 -1 a) -4)))) 1)
(+.f64 (fma.f64 1/12 (fma.f64 -12 (pow.f64 b 4) (*.f64 12 (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (fma.f64 2 (pow.f64 b 4) (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (pow.f64 (/.f64 -1 a) -4)))) -1)
(+.f64 (+.f64 (neg.f64 (pow.f64 b 4)) (*.f64 1 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))))) (+.f64 (fma.f64 2 (pow.f64 b 4) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (pow.f64 (/.f64 -1 a) -4))) -1))
(+.f64 -1 (+.f64 (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (pow.f64 (/.f64 -1 a) -4)) (+.f64 (pow.f64 b 4) (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)))))
(-.f64 (+.f64 (*.f64 4/3 (/.f64 (pow.f64 b 6) (pow.f64 a 2))) (+.f64 (*.f64 2 (pow.f64 b 4)) (+.f64 (*.f64 1/12 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2))))) (+.f64 (*.f64 1/6 (/.f64 (*.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 b 2)) (pow.f64 a 2))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 1/360 (/.f64 (+.f64 (*.f64 360 (-.f64 (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2))) (+.f64 (*.f64 -1/4 (pow.f64 b 6)) (*.f64 1/4 (pow.f64 b 6)))) (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2)))) (+.f64 (*.f64 -360 (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2))) (*.f64 240 (pow.f64 b 6)))) (pow.f64 a 2))) (pow.f64 (/.f64 -1 a) -4))))))) 1)
(+.f64 (fma.f64 4/3 (/.f64 (pow.f64 b 6) (*.f64 a a)) (fma.f64 2 (pow.f64 b 4) (fma.f64 1/12 (fma.f64 -12 (pow.f64 b 4) (*.f64 12 (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (fma.f64 1/6 (/.f64 (fma.f64 -12 (pow.f64 b 4) (*.f64 12 (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (/.f64 (*.f64 a a) (*.f64 b b))) (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (fma.f64 1/360 (/.f64 (fma.f64 360 (-.f64 (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 (pow.f64 b 4) 0)) (*.f64 (pow.f64 b 6) 0)) (*.f64 (*.f64 b b) (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (fma.f64 -360 (*.f64 (*.f64 b b) (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4))) (*.f64 (pow.f64 b 6) 240))) (*.f64 a a)) (pow.f64 (/.f64 -1 a) -4))))))) -1)
(+.f64 -1 (fma.f64 4/3 (/.f64 (pow.f64 b 6) (*.f64 a a)) (+.f64 (fma.f64 1/6 (*.f64 (/.f64 (*.f64 b b) a) (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (*.f64 (pow.f64 b 4) -12)) a)) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (fma.f64 1/360 (/.f64 (fma.f64 360 (*.f64 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (neg.f64 (*.f64 b b))) (fma.f64 (pow.f64 b 6) 240 (*.f64 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (*.f64 (*.f64 b b) -360)))) (*.f64 a a)) (pow.f64 (/.f64 -1 a) -4)))) (fma.f64 2 (pow.f64 b 4) (+.f64 (neg.f64 (pow.f64 b 4)) (*.f64 1 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)))))))))
(+.f64 (+.f64 (fma.f64 1/6 (*.f64 (*.f64 (/.f64 b a) (/.f64 b a)) (fma.f64 12 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 (pow.f64 b 4) -12))) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (fma.f64 1/360 (/.f64 (fma.f64 360 (*.f64 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 b (neg.f64 b))) (fma.f64 (pow.f64 b 6) 240 (*.f64 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 (*.f64 b b) -360)))) (*.f64 a a)) (pow.f64 (/.f64 -1 a) -4)))) (+.f64 (pow.f64 b 4) (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)))) (fma.f64 4/3 (/.f64 (pow.f64 b 6) (*.f64 a a)) -1))
(-.f64 (pow.f64 (pow.f64 a 2) 2) 1)
(+.f64 (pow.f64 a 4) -1)
(-.f64 (+.f64 (*.f64 (pow.f64 a 4) (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (pow.f64 (pow.f64 a 2) 2)) 1)
(+.f64 (fma.f64 (pow.f64 a 4) (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (pow.f64 a 4)) -1)
(+.f64 -1 (*.f64 (+.f64 (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) 1) (pow.f64 a 4)))
(fma.f64 (+.f64 (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) 1) (pow.f64 a 4) -1)
(-.f64 (+.f64 (*.f64 (pow.f64 a 4) (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (+.f64 (pow.f64 (pow.f64 a 2) 2) (*.f64 (pow.f64 a 4) (*.f64 (+.f64 (*.f64 1/2 (pow.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) 2)) (*.f64 1/12 (+.f64 (*.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2) (pow.f64 a 8))) (*.f64 12 (/.f64 (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2)) (pow.f64 a 4)))))) (pow.f64 b 4))))) 1)
(+.f64 (+.f64 (fma.f64 (pow.f64 a 4) (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (pow.f64 a 4)) (*.f64 (pow.f64 a 4) (*.f64 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) 2) (*.f64 1/12 (fma.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (pow.f64 a 8)) (/.f64 (*.f64 12 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) (*.f64 a a)) 2))) (pow.f64 a 4)))))))) -1)
(+.f64 -1 (fma.f64 (pow.f64 a 4) (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (*.f64 (+.f64 (*.f64 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) 2) (+.f64 (*.f64 1 (/.f64 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 a a)) 2)) (pow.f64 a 4))) (/.f64 (*.f64 -1/4 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2)) (pow.f64 a 8))))) 1) (pow.f64 a 4))))
(+.f64 -1 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (+.f64 (*.f64 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) 2) (+.f64 (/.f64 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 a a)) 2)) (pow.f64 a 4)) (/.f64 (neg.f64 (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (pow.f64 a 8))))) 1))))
(-.f64 (+.f64 (*.f64 (pow.f64 a 4) (*.f64 (pow.f64 b 6) (+.f64 (*.f64 1/6 (pow.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) 3)) (+.f64 (*.f64 1/360 (+.f64 (*.f64 30 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3) (pow.f64 a 12))) (*.f64 -360 (/.f64 (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2))) (pow.f64 a 8))))) (*.f64 1/12 (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (+.f64 (*.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2) (pow.f64 a 8))) (*.f64 12 (/.f64 (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2)) (pow.f64 a 4)))))))))) (+.f64 (*.f64 (pow.f64 a 4) (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (+.f64 (pow.f64 (pow.f64 a 2) 2) (*.f64 (pow.f64 a 4) (*.f64 (+.f64 (*.f64 1/2 (pow.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) 2)) (*.f64 1/12 (+.f64 (*.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2) (pow.f64 a 8))) (*.f64 12 (/.f64 (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2)) (pow.f64 a 4)))))) (pow.f64 b 4)))))) 1)
(+.f64 (fma.f64 (pow.f64 a 4) (*.f64 (pow.f64 b 6) (fma.f64 1/6 (pow.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) 3) (fma.f64 1/360 (fma.f64 -360 (/.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (/.f64 (pow.f64 a 8) (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) (*.f64 a a)) 2)))) (*.f64 30 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 3) (pow.f64 a 12)))) (*.f64 (*.f64 1/12 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (fma.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (pow.f64 a 8)) (/.f64 (*.f64 12 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) (*.f64 a a)) 2))) (pow.f64 a 4))))))) (+.f64 (fma.f64 (pow.f64 a 4) (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (pow.f64 a 4)) (*.f64 (pow.f64 a 4) (*.f64 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) 2) (*.f64 1/12 (fma.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (pow.f64 a 8)) (/.f64 (*.f64 12 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) (*.f64 a a)) 2))) (pow.f64 a 4))))))))) -1)
(+.f64 -1 (+.f64 (*.f64 (+.f64 (*.f64 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) 2) (+.f64 (*.f64 1 (/.f64 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 a a)) 2)) (pow.f64 a 4))) (/.f64 (*.f64 -1/4 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2)) (pow.f64 a 8))))) 1) (pow.f64 a 4)) (*.f64 (pow.f64 a 4) (+.f64 (*.f64 (pow.f64 b 6) (fma.f64 1/6 (pow.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) 3) (fma.f64 1/12 (*.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) (fma.f64 12 (/.f64 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 a a)) 2)) (pow.f64 a 4)) (/.f64 -3 (/.f64 (pow.f64 a 8) (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))))) (+.f64 (*.f64 -1 (*.f64 (/.f64 (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 8)) (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 a a)) 2)))) (*.f64 1/12 (/.f64 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3) (pow.f64 a 12))))))) (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))))))))
(+.f64 -1 (+.f64 (*.f64 (pow.f64 a 4) (+.f64 (+.f64 (*.f64 (pow.f64 b 6) (+.f64 (*.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) (+.f64 (/.f64 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 a a)) 2)) (pow.f64 a 4)) (/.f64 (neg.f64 (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (pow.f64 a 8)))) (fma.f64 1/6 (pow.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) 3) (+.f64 (neg.f64 (*.f64 (/.f64 (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 8)) (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 a a)) 2)))) (*.f64 1/12 (/.f64 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3) (pow.f64 a 12))))))) (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))))) (*.f64 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) 2) (+.f64 (/.f64 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 a a)) 2)) (pow.f64 a 4)) (/.f64 (neg.f64 (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (pow.f64 a 8))))))) (pow.f64 a 4)))
(-.f64 (pow.f64 (/.f64 1 b) -4) 1)
(+.f64 (pow.f64 (/.f64 1 b) -4) -1)
(+.f64 -1 (pow.f64 (/.f64 1 b) -4))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 (/.f64 1 b) -4))) 1)
(+.f64 (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (fma.f64 4 (*.f64 b b) (pow.f64 (/.f64 1 b) -4))) -1)
(+.f64 -1 (+.f64 (pow.f64 (/.f64 1 b) -4) (*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4))))
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2))))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (+.f64 (*.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (pow.f64 (/.f64 1 b) -4))))) 1)
(+.f64 (fma.f64 1/12 (fma.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (*.f64 12 (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))) (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (fma.f64 4 (*.f64 b b) (fma.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (pow.f64 (/.f64 1 b) -4))))) -1)
(fma.f64 1/12 (fma.f64 12 (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (+.f64 (+.f64 (fma.f64 1/2 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2) (pow.f64 (/.f64 1 b) -4)) (*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4))) -1))
(+.f64 -1 (+.f64 (neg.f64 (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (+.f64 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (+.f64 (*.f64 (fma.f64 2 (*.f64 a a) 4) (+.f64 (*.f64 b b) (+.f64 2 (*.f64 a a)))) (pow.f64 (/.f64 1 b) -4)))))
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2))))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 (/.f64 1 b) -4) (+.f64 (*.f64 1/360 (/.f64 (+.f64 (*.f64 -180 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))) (+.f64 (*.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3)) (*.f64 360 (-.f64 (+.f64 (*.f64 1/4 (pow.f64 a 6)) (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2))) (*.f64 -1/4 (pow.f64 a 6)))) (*.f64 1/2 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))))))) (pow.f64 b 2))) (+.f64 (*.f64 1/12 (/.f64 (*.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (+.f64 4 (*.f64 2 (pow.f64 a 2)))) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (+.f64 (*.f64 4 (pow.f64 b 2)) (*.f64 1/6 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3) (pow.f64 b 2)))))))))) 1)
(+.f64 (fma.f64 1/12 (fma.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (*.f64 12 (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))) (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (+.f64 (pow.f64 (/.f64 1 b) -4) (fma.f64 1/360 (/.f64 (fma.f64 -180 (*.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2))) (fma.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 3) (*.f64 360 (+.f64 (fma.f64 1/4 (pow.f64 a 6) (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 (pow.f64 a 4) 0)) (*.f64 (pow.f64 a 6) -1/4))) (*.f64 -1/2 (*.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))))))) (*.f64 b b)) (fma.f64 1/12 (/.f64 (fma.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (*.f64 12 (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))) (/.f64 (*.f64 b b) (+.f64 4 (*.f64 2 (*.f64 a a))))) (fma.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (fma.f64 4 (*.f64 b b) (/.f64 (*.f64 1/6 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 3)) (*.f64 b b))))))))) -1)
(+.f64 -1 (fma.f64 1/12 (fma.f64 12 (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (+.f64 (fma.f64 1/360 (/.f64 (fma.f64 -180 (*.f64 (fma.f64 2 (*.f64 a a) 4) (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2)))) (fma.f64 360 (-.f64 (fma.f64 (pow.f64 a 6) 1/4 (fma.f64 (pow.f64 a 6) -1/4 (*.f64 a (*.f64 a 0)))) (*.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))))) (*.f64 30 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3)))) (*.f64 b b)) (fma.f64 1/12 (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (/.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4))) (fma.f64 1/2 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2) (fma.f64 1/6 (/.f64 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3) (*.f64 b b)) (*.f64 4 (*.f64 b b)))))) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (pow.f64 (/.f64 1 b) -4)))))
(+.f64 (+.f64 (fma.f64 1/360 (/.f64 (fma.f64 -180 (*.f64 (fma.f64 2 (*.f64 a a) 4) (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2))) (fma.f64 360 (*.f64 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (+.f64 -2 (neg.f64 (*.f64 a a)))) (*.f64 30 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3)))) (*.f64 b b)) (+.f64 (*.f64 (/.f64 (+.f64 (neg.f64 (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2))) b) (/.f64 (fma.f64 2 (*.f64 a a) 4) b)) (fma.f64 1/2 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2) (fma.f64 4 (*.f64 b b) (*.f64 (/.f64 1/6 (*.f64 b b)) (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3)))))) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (pow.f64 (/.f64 1 b) -4))) (+.f64 (+.f64 (neg.f64 (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2))) -1))
(-.f64 (pow.f64 (/.f64 -1 b) -4) 1)
(+.f64 (pow.f64 (/.f64 -1 b) -4) -1)
(+.f64 -1 (pow.f64 (/.f64 -1 b) -4))
(-.f64 (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 (/.f64 -1 b) -4) (*.f64 4 (pow.f64 b 2)))) 1)
(+.f64 (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (+.f64 (*.f64 4 (*.f64 b b)) (pow.f64 (/.f64 -1 b) -4))) -1)
(+.f64 -1 (+.f64 (pow.f64 (/.f64 -1 b) -4) (*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4))))
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2))))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (pow.f64 (/.f64 -1 b) -4) (+.f64 (*.f64 4 (pow.f64 b 2)) (*.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)))))) 1)
(+.f64 (fma.f64 1/12 (fma.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (*.f64 12 (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))) (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (+.f64 (pow.f64 (/.f64 -1 b) -4) (fma.f64 4 (*.f64 b b) (*.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2)))))) -1)
(+.f64 -1 (fma.f64 1/12 (fma.f64 12 (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (+.f64 (+.f64 (pow.f64 (/.f64 -1 b) -4) (*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4))) (*.f64 1/2 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2)))))
(+.f64 -1 (+.f64 (+.f64 (neg.f64 (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2))) (+.f64 (+.f64 (pow.f64 (/.f64 -1 b) -4) (*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4))) (*.f64 1/2 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2)))))
(-.f64 (+.f64 (*.f64 1/12 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2))))) (+.f64 (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2))) (+.f64 (*.f64 1/360 (/.f64 (+.f64 (*.f64 -180 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))) (+.f64 (*.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3)) (*.f64 360 (-.f64 (+.f64 (*.f64 1/4 (pow.f64 a 6)) (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2))) (*.f64 -1/4 (pow.f64 a 6)))) (*.f64 1/2 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))))))) (pow.f64 b 2))) (+.f64 (pow.f64 (/.f64 -1 b) -4) (+.f64 (*.f64 1/12 (/.f64 (*.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (+.f64 4 (*.f64 2 (pow.f64 a 2)))) (pow.f64 b 2))) (+.f64 (*.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (+.f64 (*.f64 4 (pow.f64 b 2)) (*.f64 1/6 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3) (pow.f64 b 2)))))))))) 1)
(+.f64 (fma.f64 1/12 (fma.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (*.f64 12 (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))) (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 a a)) (fma.f64 1/360 (/.f64 (fma.f64 -180 (*.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2))) (fma.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 3) (*.f64 360 (+.f64 (fma.f64 1/4 (pow.f64 a 6) (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 (pow.f64 a 4) 0)) (*.f64 (pow.f64 a 6) -1/4))) (*.f64 -1/2 (*.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))))))) (*.f64 b b)) (+.f64 (fma.f64 1/12 (/.f64 (fma.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (*.f64 12 (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))) (/.f64 (*.f64 b b) (+.f64 4 (*.f64 2 (*.f64 a a))))) (fma.f64 1/2 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (fma.f64 4 (*.f64 b b) (/.f64 (*.f64 1/6 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 3)) (*.f64 b b))))) (pow.f64 (/.f64 -1 b) -4))))) -1)
(+.f64 -1 (fma.f64 1/12 (fma.f64 12 (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) (+.f64 (fma.f64 1/12 (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (/.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) 4))) (fma.f64 1/2 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2) (fma.f64 1/6 (/.f64 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3) (*.f64 b b)) (*.f64 4 (*.f64 b b))))) (fma.f64 1/360 (/.f64 (fma.f64 -180 (*.f64 (fma.f64 2 (*.f64 a a) 4) (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2)))) (fma.f64 360 (-.f64 (fma.f64 (pow.f64 a 6) 1/4 (fma.f64 (pow.f64 a 6) -1/4 (*.f64 a (*.f64 a 0)))) (*.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))))) (*.f64 30 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3)))) (*.f64 b b)) (pow.f64 (/.f64 -1 b) -4))))))
(+.f64 (+.f64 (neg.f64 (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2))) (+.f64 (+.f64 (+.f64 (*.f64 (/.f64 (+.f64 (neg.f64 (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2))) b) (/.f64 (fma.f64 2 (*.f64 a a) 4) b)) (fma.f64 1/2 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2) (fma.f64 4 (*.f64 b b) (*.f64 (/.f64 1/6 (*.f64 b b)) (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3))))) (fma.f64 1/360 (/.f64 (fma.f64 -180 (*.f64 (fma.f64 2 (*.f64 a a) 4) (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2))) (fma.f64 360 (*.f64 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (+.f64 -2 (neg.f64 (*.f64 a a)))) (*.f64 30 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3)))) (*.f64 b b)) (pow.f64 (/.f64 -1 b) -4))) (fma.f64 2 (*.f64 a (*.f64 a (*.f64 b b))) -1)))
(pow.f64 b 2)
(*.f64 b b)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 b b) (*.f64 a a))
(fma.f64 a a (*.f64 b b))
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 b b) (*.f64 a a))
(fma.f64 a a (*.f64 b b))
(+.f64 (*.f64 (+.f64 (*.f64 5/64 (/.f64 1 (pow.f64 b 6))) (*.f64 -1 (+.f64 (*.f64 1/16 (/.f64 1 (pow.f64 b 6))) (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2)))) (pow.f64 a 8)) (+.f64 (pow.f64 b 2) (pow.f64 a 2)))
(fma.f64 (+.f64 (/.f64 5/64 (pow.f64 b 6)) (neg.f64 (+.f64 (/.f64 1/16 (pow.f64 b 6)) (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2)))) (pow.f64 a 8) (+.f64 (*.f64 b b) (*.f64 a a)))
(fma.f64 (pow.f64 a 8) (-.f64 (/.f64 5/64 (pow.f64 b 6)) (+.f64 (/.f64 1/16 (pow.f64 b 6)) (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2))) (fma.f64 a a (*.f64 b b)))
(fma.f64 (pow.f64 a 8) (-.f64 (*.f64 (/.f64 1 (pow.f64 b 6)) 1/64) (pow.f64 (/.f64 -1/8 (pow.f64 b 3)) 2)) (fma.f64 a a (*.f64 b b)))
(pow.f64 a 2)
(*.f64 a a)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 b b) (*.f64 a a))
(fma.f64 a a (*.f64 b b))
(+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (pow.f64 b 2) (pow.f64 a 2))))
(fma.f64 -1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (fma.f64 1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (+.f64 (*.f64 b b) (*.f64 a a))))
(+.f64 (fma.f64 a a (*.f64 b b)) (*.f64 (/.f64 (pow.f64 b 4) (*.f64 a a)) 0))
(+.f64 (fma.f64 a a (*.f64 b b)) 0)
(+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4))) (+.f64 (pow.f64 b 2) (pow.f64 a 2))))))
(fma.f64 -1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (fma.f64 -1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4)) (fma.f64 1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (fma.f64 1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4)) (+.f64 (*.f64 b b) (*.f64 a a))))))
(fma.f64 -1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (fma.f64 -1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4)) (fma.f64 1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (fma.f64 (/.f64 (pow.f64 b 6) (pow.f64 a 4)) 1/8 (fma.f64 a a (*.f64 b b))))))
(pow.f64 a 2)
(*.f64 a a)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 b b) (*.f64 a a))
(fma.f64 a a (*.f64 b b))
(+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (pow.f64 b 2) (pow.f64 a 2))))
(fma.f64 -1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (fma.f64 1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (+.f64 (*.f64 b b) (*.f64 a a))))
(+.f64 (fma.f64 a a (*.f64 b b)) (*.f64 (/.f64 (pow.f64 b 4) (*.f64 a a)) 0))
(+.f64 (fma.f64 a a (*.f64 b b)) 0)
(+.f64 (*.f64 -1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 b 4) (pow.f64 a 2))) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4))) (+.f64 (pow.f64 b 2) (pow.f64 a 2))))))
(fma.f64 -1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (fma.f64 -1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4)) (fma.f64 1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (fma.f64 1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4)) (+.f64 (*.f64 b b) (*.f64 a a))))))
(fma.f64 -1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (fma.f64 -1/8 (/.f64 (pow.f64 b 6) (pow.f64 a 4)) (fma.f64 1/4 (/.f64 (pow.f64 b 4) (*.f64 a a)) (fma.f64 (/.f64 (pow.f64 b 6) (pow.f64 a 4)) 1/8 (fma.f64 a a (*.f64 b b))))))
(pow.f64 a 2)
(*.f64 a a)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 b b) (*.f64 a a))
(fma.f64 a a (*.f64 b b))
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 b b) (*.f64 a a))
(fma.f64 a a (*.f64 b b))
(+.f64 (*.f64 (+.f64 (*.f64 -1 (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2) (*.f64 1/16 (/.f64 1 (pow.f64 a 6))))) (*.f64 5/64 (/.f64 1 (pow.f64 a 6)))) (pow.f64 b 8)) (+.f64 (pow.f64 b 2) (pow.f64 a 2)))
(fma.f64 (fma.f64 -1 (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2) (/.f64 1/16 (pow.f64 a 6))) (/.f64 5/64 (pow.f64 a 6))) (pow.f64 b 8) (+.f64 (*.f64 b b) (*.f64 a a)))
(fma.f64 (-.f64 (/.f64 5/64 (pow.f64 a 6)) (+.f64 (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2) (/.f64 1/16 (pow.f64 a 6)))) (pow.f64 b 8) (fma.f64 a a (*.f64 b b)))
(fma.f64 (+.f64 (neg.f64 (pow.f64 (/.f64 -1/8 (pow.f64 a 3)) 2)) (*.f64 (/.f64 1 (pow.f64 a 6)) 1/64)) (pow.f64 b 8) (fma.f64 a a (*.f64 b b)))
(pow.f64 b 2)
(*.f64 b b)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 b b) (*.f64 a a))
(fma.f64 a a (*.f64 b b))
(+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))) (+.f64 (pow.f64 b 2) (+.f64 (pow.f64 a 2) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))))))
(fma.f64 1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)) (+.f64 (+.f64 (*.f64 b b) (*.f64 a a)) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)))))
(fma.f64 1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)) (fma.f64 b b (fma.f64 a a (*.f64 -1/4 (/.f64 (pow.f64 a 4) (*.f64 b b))))))
(+.f64 (fma.f64 a a (*.f64 b b)) (*.f64 (/.f64 (pow.f64 a 4) (*.f64 b b)) 0))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4))) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))) (+.f64 (pow.f64 b 2) (+.f64 (pow.f64 a 2) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))))))))
(fma.f64 -1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4)) (fma.f64 1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4)) (fma.f64 1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)) (+.f64 (+.f64 (*.f64 b b) (*.f64 a a)) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)))))))
(+.f64 (fma.f64 1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)) (fma.f64 b b (fma.f64 a a (*.f64 -1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)))))) (*.f64 (/.f64 (pow.f64 a 6) (pow.f64 b 4)) 0))
(+.f64 (+.f64 (fma.f64 a a (*.f64 b b)) (*.f64 (/.f64 (pow.f64 a 4) (*.f64 b b)) 0)) 0)
(pow.f64 b 2)
(*.f64 b b)
(+.f64 (pow.f64 b 2) (pow.f64 a 2))
(+.f64 (*.f64 b b) (*.f64 a a))
(fma.f64 a a (*.f64 b b))
(+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))) (+.f64 (pow.f64 b 2) (+.f64 (pow.f64 a 2) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))))))
(fma.f64 1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)) (+.f64 (+.f64 (*.f64 b b) (*.f64 a a)) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)))))
(fma.f64 1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)) (fma.f64 b b (fma.f64 a a (*.f64 -1/4 (/.f64 (pow.f64 a 4) (*.f64 b b))))))
(+.f64 (fma.f64 a a (*.f64 b b)) (*.f64 (/.f64 (pow.f64 a 4) (*.f64 b b)) 0))
(+.f64 (*.f64 -1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4))) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4))) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))) (+.f64 (pow.f64 b 2) (+.f64 (pow.f64 a 2) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (pow.f64 b 2))))))))
(fma.f64 -1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4)) (fma.f64 1/8 (/.f64 (pow.f64 a 6) (pow.f64 b 4)) (fma.f64 1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)) (+.f64 (+.f64 (*.f64 b b) (*.f64 a a)) (*.f64 -1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)))))))
(+.f64 (fma.f64 1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)) (fma.f64 b b (fma.f64 a a (*.f64 -1/4 (/.f64 (pow.f64 a 4) (*.f64 b b)))))) (*.f64 (/.f64 (pow.f64 a 6) (pow.f64 b 4)) 0))
(+.f64 (+.f64 (fma.f64 a a (*.f64 b b)) (*.f64 (/.f64 (pow.f64 a 4) (*.f64 b b)) 0)) 0)
(log.f64 (sqrt.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))))
(log.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))
(+.f64 (log.f64 (sqrt.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))))))
(+.f64 (log.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (*.f64 (*.f64 (*.f64 b b) (*.f64 a a)) (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))))
(fma.f64 (*.f64 a a) (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) (log.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))
(fma.f64 (*.f64 a a) (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4))))) (log.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))
(+.f64 (log.f64 (sqrt.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 12 (*.f64 (-.f64 1 (pow.f64 (*.f64 (sqrt.f64 (/.f64 1 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (pow.f64 b 2)) 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))) (*.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))))))) (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))))
(+.f64 (log.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (fma.f64 1/24 (*.f64 (fma.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (*.f64 b b) (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 2))))) (pow.f64 a 4)) (*.f64 (*.f64 (*.f64 b b) (*.f64 a a)) (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))))
(+.f64 (log.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (fma.f64 1/24 (*.f64 (fma.f64 (*.f64 12 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) (-.f64 1 (pow.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) 2)) (*.f64 (/.f64 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) (/.f64 -12 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (pow.f64 a 4)) (*.f64 (*.f64 a (*.f64 a (*.f64 b b))) (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))))
(+.f64 (log.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (fma.f64 1/24 (*.f64 (fma.f64 (/.f64 (pow.f64 b 4) (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4)) -12 (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4))) (-.f64 1 (*.f64 (pow.f64 b 4) (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))))) (pow.f64 a 4)) (*.f64 (*.f64 a (*.f64 a (*.f64 b b))) (sqrt.f64 (/.f64 1 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4))))))
(+.f64 (log.f64 (sqrt.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (+.f64 (*.f64 1/24 (*.f64 (pow.f64 a 4) (+.f64 (*.f64 12 (*.f64 (-.f64 1 (pow.f64 (*.f64 (sqrt.f64 (/.f64 1 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (pow.f64 b 2)) 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))) (*.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))))))) (+.f64 (*.f64 (*.f64 (pow.f64 a 2) (pow.f64 b 2)) (sqrt.f64 (/.f64 1 (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))))) (*.f64 1/720 (*.f64 (pow.f64 a 6) (+.f64 (*.f64 240 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) 3) (pow.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 3)))) (pow.f64 b 6))) (+.f64 (*.f64 -360 (*.f64 (*.f64 (pow.f64 b 2) (-.f64 1 (pow.f64 (*.f64 (pow.f64 b 2) (sqrt.f64 (/.f64 1 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))) 2))) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) 3) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))) (*.f64 -360 (/.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 (sqrt.f64 (/.f64 1 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))))) (pow.f64 b 2)) 2)) (pow.f64 b 2)) (*.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2))) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))))))))))))
(+.f64 (log.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (fma.f64 1/24 (*.f64 (fma.f64 -12 (/.f64 (pow.f64 b 4) (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (-.f64 1 (pow.f64 (*.f64 (*.f64 b b) (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 2))))) (pow.f64 a 4)) (fma.f64 (*.f64 (*.f64 b b) (*.f64 a a)) (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (*.f64 (*.f64 1/720 (pow.f64 a 6)) (fma.f64 240 (*.f64 (pow.f64 b 6) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 3) (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 3))))) (*.f64 -360 (+.f64 (*.f64 (*.f64 b b) (*.f64 (-.f64 1 (pow.f64 (*.f64 (*.f64 b b) (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 2)) (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 3)))))) (*.f64 (/.f64 (-.f64 1 (pow.f64 (*.f64 (*.f64 b b) (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) 2)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) (/.f64 (*.f64 b b) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))))))))
(+.f64 (log.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (fma.f64 1/24 (*.f64 (fma.f64 (*.f64 12 (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) (-.f64 1 (pow.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) 2)) (*.f64 (/.f64 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) (/.f64 -12 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (pow.f64 a 4)) (fma.f64 (*.f64 a a) (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (*.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) (*.f64 (fma.f64 -360 (fma.f64 (*.f64 b b) (*.f64 (-.f64 1 (pow.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) 2)) (sqrt.f64 (/.f64 1 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 4)))) (*.f64 (/.f64 (-.f64 1 (pow.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) 2)) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) (/.f64 (*.f64 b b) (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (*.f64 (pow.f64 b 6) (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 6))) 240))) (*.f64 (pow.f64 a 6) 1/720)))))
(+.f64 (log.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (fma.f64 1/24 (*.f64 (fma.f64 (/.f64 (pow.f64 b 4) (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4)) -12 (*.f64 12 (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4))) (-.f64 1 (*.f64 (pow.f64 b 4) (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))))) (pow.f64 a 4)) (fma.f64 (*.f64 a a) (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4))))) (*.f64 (fma.f64 -360 (*.f64 (-.f64 1 (*.f64 (pow.f64 b 4) (/.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (+.f64 (*.f64 b (*.f64 b (sqrt.f64 (/.f64 1 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 4))))) (/.f64 b (/.f64 (pow.f64 (sqrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 4) b)))) (*.f64 (pow.f64 b 6) (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 6))) 240))) (*.f64 (pow.f64 a 6) 1/720)))))
(*.f64 -2 (log.f64 (/.f64 1 a)))
(*.f64 -2 (neg.f64 (log.f64 a)))
(*.f64 2 (log.f64 a))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 a))) (/.f64 (pow.f64 b 2) (pow.f64 a 2)))
(fma.f64 -2 (neg.f64 (log.f64 a)) (/.f64 (*.f64 b b) (*.f64 a a)))
(fma.f64 -2 (neg.f64 (log.f64 a)) (*.f64 (/.f64 b a) (/.f64 b a)))
(+.f64 (*.f64 (/.f64 b a) (/.f64 b a)) (*.f64 2 (log.f64 a)))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 a))) (+.f64 (/.f64 (pow.f64 b 2) (pow.f64 a 2)) (*.f64 1/24 (/.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 a 4)))))
(+.f64 (fma.f64 -2 (neg.f64 (log.f64 a)) (/.f64 (*.f64 b b) (*.f64 a a))) (*.f64 1/24 (/.f64 (fma.f64 -12 (pow.f64 b 4) (*.f64 12 (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (pow.f64 a 4))))
(fma.f64 -2 (neg.f64 (log.f64 a)) (fma.f64 1/24 (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (*.f64 (pow.f64 b 4) -12)) (pow.f64 a 4)) (*.f64 (/.f64 b a) (/.f64 b a))))
(+.f64 (fma.f64 1/24 (/.f64 (fma.f64 12 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 (pow.f64 b 4) -12)) (pow.f64 a 4)) (*.f64 (/.f64 b a) (/.f64 b a))) (*.f64 2 (log.f64 a)))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 a))) (+.f64 (/.f64 (pow.f64 b 2) (pow.f64 a 2)) (+.f64 (*.f64 1/720 (/.f64 (+.f64 (*.f64 360 (-.f64 (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2))) (+.f64 (*.f64 1/4 (pow.f64 b 6)) (*.f64 -1/4 (pow.f64 b 6)))) (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2)))) (+.f64 (*.f64 -360 (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2))) (*.f64 240 (pow.f64 b 6)))) (pow.f64 a 6))) (*.f64 1/24 (/.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 a 4))))))
(+.f64 (fma.f64 -2 (neg.f64 (log.f64 a)) (/.f64 (*.f64 b b) (*.f64 a a))) (fma.f64 1/720 (/.f64 (fma.f64 360 (-.f64 (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 (pow.f64 b 4) 0)) (*.f64 (pow.f64 b 6) 0)) (*.f64 (*.f64 b b) (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (fma.f64 -360 (*.f64 (*.f64 b b) (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4))) (*.f64 (pow.f64 b 6) 240))) (pow.f64 a 6)) (*.f64 1/24 (/.f64 (fma.f64 -12 (pow.f64 b 4) (*.f64 12 (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (pow.f64 a 4)))))
(+.f64 (fma.f64 -2 (neg.f64 (log.f64 a)) (*.f64 (/.f64 b a) (/.f64 b a))) (fma.f64 1/24 (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (*.f64 (pow.f64 b 4) -12)) (pow.f64 a 4)) (/.f64 1/720 (/.f64 (pow.f64 a 6) (fma.f64 360 (*.f64 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (neg.f64 (*.f64 b b))) (fma.f64 (pow.f64 b 6) 240 (*.f64 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (*.f64 (*.f64 b b) -360))))))))
(+.f64 (*.f64 (/.f64 b a) (/.f64 b a)) (+.f64 (*.f64 2 (log.f64 a)) (fma.f64 1/24 (/.f64 (fma.f64 12 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 (pow.f64 b 4) -12)) (pow.f64 a 4)) (*.f64 (/.f64 1/720 (pow.f64 a 6)) (fma.f64 360 (*.f64 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 b (neg.f64 b))) (fma.f64 (pow.f64 b 6) 240 (*.f64 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 (*.f64 b b) -360))))))))
(*.f64 -2 (log.f64 (/.f64 -1 a)))
(+.f64 (/.f64 (pow.f64 b 2) (pow.f64 a 2)) (*.f64 -2 (log.f64 (/.f64 -1 a))))
(+.f64 (/.f64 (*.f64 b b) (*.f64 a a)) (*.f64 -2 (log.f64 (/.f64 -1 a))))
(fma.f64 -2 (log.f64 (/.f64 -1 a)) (*.f64 (/.f64 b a) (/.f64 b a)))
(+.f64 (/.f64 (pow.f64 b 2) (pow.f64 a 2)) (+.f64 (*.f64 -2 (log.f64 (/.f64 -1 a))) (*.f64 1/24 (/.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 a 4)))))
(+.f64 (/.f64 (*.f64 b b) (*.f64 a a)) (fma.f64 -2 (log.f64 (/.f64 -1 a)) (*.f64 1/24 (/.f64 (fma.f64 -12 (pow.f64 b 4) (*.f64 12 (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (pow.f64 a 4)))))
(+.f64 (*.f64 (/.f64 b a) (/.f64 b a)) (fma.f64 1/24 (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (*.f64 (pow.f64 b 4) -12)) (pow.f64 a 4)) (*.f64 -2 (log.f64 (/.f64 -1 a)))))
(+.f64 (*.f64 (/.f64 b a) (/.f64 b a)) (fma.f64 1/24 (/.f64 (fma.f64 12 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 (pow.f64 b 4) -12)) (pow.f64 a 4)) (*.f64 -2 (log.f64 (/.f64 -1 a)))))
(+.f64 (/.f64 (pow.f64 b 2) (pow.f64 a 2)) (+.f64 (*.f64 1/720 (/.f64 (+.f64 (*.f64 360 (-.f64 (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 b 4)) (*.f64 1/4 (pow.f64 b 4))) (pow.f64 b 2))) (+.f64 (*.f64 1/4 (pow.f64 b 6)) (*.f64 -1/4 (pow.f64 b 6)))) (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2)))) (+.f64 (*.f64 -360 (*.f64 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)) (pow.f64 b 2))) (*.f64 240 (pow.f64 b 6)))) (pow.f64 a 6))) (+.f64 (*.f64 -2 (log.f64 (/.f64 -1 a))) (*.f64 1/24 (/.f64 (+.f64 (*.f64 -12 (pow.f64 b 4)) (*.f64 12 (-.f64 (+.f64 (*.f64 -1/2 (pow.f64 b 4)) (+.f64 (*.f64 1/2 (pow.f64 b 4)) (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)))) (pow.f64 (pow.f64 b 2) 2)))) (pow.f64 a 4))))))
(+.f64 (/.f64 (*.f64 b b) (*.f64 a a)) (fma.f64 1/720 (/.f64 (fma.f64 360 (-.f64 (fma.f64 2 (*.f64 (*.f64 b b) (*.f64 (pow.f64 b 4) 0)) (*.f64 (pow.f64 b 6) 0)) (*.f64 (*.f64 b b) (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (fma.f64 -360 (*.f64 (*.f64 b b) (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4))) (*.f64 (pow.f64 b 6) 240))) (pow.f64 a 6)) (fma.f64 -2 (log.f64 (/.f64 -1 a)) (*.f64 1/24 (/.f64 (fma.f64 -12 (pow.f64 b 4) (*.f64 12 (-.f64 (fma.f64 -1/2 (pow.f64 b 4) (fma.f64 1/2 (pow.f64 b 4) (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))) (pow.f64 b 4)))) (pow.f64 a 4))))))
(+.f64 (*.f64 (/.f64 b a) (/.f64 b a)) (fma.f64 1/720 (/.f64 (fma.f64 360 (*.f64 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (neg.f64 (*.f64 b b))) (fma.f64 (pow.f64 b 6) 240 (*.f64 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (*.f64 (*.f64 b b) -360)))) (pow.f64 a 6)) (fma.f64 1/24 (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4))) (*.f64 (pow.f64 b 4) -12)) (pow.f64 a 4)) (*.f64 -2 (log.f64 (/.f64 -1 a))))))
(+.f64 (*.f64 (/.f64 b a) (/.f64 b a)) (fma.f64 1/720 (/.f64 (fma.f64 360 (*.f64 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 b (neg.f64 b))) (fma.f64 (pow.f64 b 6) 240 (*.f64 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 (*.f64 b b) -360)))) (pow.f64 a 6)) (fma.f64 1/24 (/.f64 (fma.f64 12 (-.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) (pow.f64 b 4)) (*.f64 (pow.f64 b 4) -12)) (pow.f64 a 4)) (*.f64 -2 (log.f64 (/.f64 -1 a))))))
(log.f64 (pow.f64 a 2))
(*.f64 -2 (neg.f64 (log.f64 a)))
(*.f64 2 (log.f64 a))
(+.f64 (*.f64 1/2 (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (log.f64 (pow.f64 a 2)))
(fma.f64 1/2 (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (*.f64 2 (log.f64 a)))
(fma.f64 2 (log.f64 a) (*.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) (*.f64 (*.f64 b b) 1/2)))
(+.f64 (*.f64 1/24 (*.f64 (+.f64 (*.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2) (pow.f64 a 8))) (*.f64 12 (/.f64 (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2)) (pow.f64 a 4)))) (pow.f64 b 4))) (+.f64 (*.f64 1/2 (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (log.f64 (pow.f64 a 2))))
(fma.f64 1/24 (*.f64 (pow.f64 b 4) (fma.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (pow.f64 a 8)) (/.f64 (*.f64 12 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) (*.f64 a a)) 2))) (pow.f64 a 4)))) (fma.f64 1/2 (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (*.f64 2 (log.f64 a))))
(fma.f64 1/24 (*.f64 (pow.f64 b 4) (fma.f64 12 (/.f64 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 a a)) 2)) (pow.f64 a 4)) (/.f64 -3 (/.f64 (pow.f64 a 8) (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))))) (fma.f64 2 (log.f64 a) (*.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) (*.f64 (*.f64 b b) 1/2))))
(fma.f64 1/24 (*.f64 (pow.f64 b 4) (fma.f64 12 (/.f64 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 a a)) 2)) (pow.f64 a 4)) (*.f64 (/.f64 -3 (pow.f64 a 8)) (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2)))) (fma.f64 2 (log.f64 a) (*.f64 (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4))) (*.f64 (*.f64 b b) 1/2))))
(+.f64 (*.f64 1/24 (*.f64 (+.f64 (*.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2) (pow.f64 a 8))) (*.f64 12 (/.f64 (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2)) (pow.f64 a 4)))) (pow.f64 b 4))) (+.f64 (*.f64 1/2 (*.f64 (+.f64 (*.f64 2 (/.f64 1 (pow.f64 a 2))) (*.f64 4 (/.f64 1 (pow.f64 a 4)))) (pow.f64 b 2))) (+.f64 (*.f64 1/720 (*.f64 (+.f64 (*.f64 -360 (/.f64 (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (-.f64 1 (pow.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 a 2))) 2))) (pow.f64 a 8))) (*.f64 30 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3) (pow.f64 a 12)))) (pow.f64 b 6))) (log.f64 (pow.f64 a 2)))))
(fma.f64 1/24 (*.f64 (pow.f64 b 4) (fma.f64 -3 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (pow.f64 a 8)) (/.f64 (*.f64 12 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) (*.f64 a a)) 2))) (pow.f64 a 4)))) (fma.f64 1/2 (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (fma.f64 1/720 (*.f64 (pow.f64 b 6) (fma.f64 -360 (/.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (/.f64 (pow.f64 a 8) (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) (*.f64 a a)) 2)))) (*.f64 30 (/.f64 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 3) (pow.f64 a 12))))) (*.f64 2 (log.f64 a)))))
(fma.f64 1/24 (*.f64 (pow.f64 b 4) (fma.f64 12 (/.f64 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 a a)) 2)) (pow.f64 a 4)) (/.f64 -3 (/.f64 (pow.f64 a 8) (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))))) (fma.f64 1/2 (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (fma.f64 2 (log.f64 a) (*.f64 (fma.f64 -360 (*.f64 (/.f64 (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 8)) (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 a a)) 2))) (*.f64 30 (/.f64 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3) (pow.f64 a 12)))) (*.f64 (pow.f64 b 6) 1/720)))))
(fma.f64 1/24 (*.f64 (pow.f64 b 4) (fma.f64 12 (/.f64 (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 a a)) 2)) (pow.f64 a 4)) (*.f64 (/.f64 -3 (pow.f64 a 8)) (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2)))) (fma.f64 1/2 (*.f64 (*.f64 b b) (+.f64 (/.f64 2 (*.f64 a a)) (/.f64 4 (pow.f64 a 4)))) (fma.f64 2 (log.f64 a) (*.f64 (fma.f64 -360 (*.f64 (/.f64 (fma.f64 2 (*.f64 a a) 4) (pow.f64 a 8)) (-.f64 1 (pow.f64 (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 a a)) 2))) (*.f64 30 (/.f64 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3) (pow.f64 a 12)))) (*.f64 (pow.f64 b 6) 1/720)))))
(*.f64 -2 (log.f64 (/.f64 1 b)))
(*.f64 -2 (neg.f64 (log.f64 b)))
(*.f64 2 (log.f64 b))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 b))) (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))
(fma.f64 -2 (neg.f64 (log.f64 b)) (/.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) (*.f64 b b)))
(fma.f64 -2 (neg.f64 (log.f64 b)) (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 b b)))
(+.f64 (*.f64 2 (log.f64 b)) (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 b b)))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 b))) (+.f64 (*.f64 1/24 (/.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (pow.f64 b 4))) (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)))))
(fma.f64 -2 (neg.f64 (log.f64 b)) (fma.f64 1/24 (/.f64 (fma.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (*.f64 12 (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))) (pow.f64 b 4)) (/.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) (*.f64 b b))))
(fma.f64 -2 (neg.f64 (log.f64 b)) (fma.f64 1/24 (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (pow.f64 b 4)) (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 b b))))
(+.f64 (*.f64 2 (log.f64 b)) (fma.f64 1/24 (/.f64 (fma.f64 12 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (pow.f64 b 4)) (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 b b))))
(+.f64 (*.f64 -2 (log.f64 (/.f64 1 b))) (+.f64 (*.f64 1/720 (/.f64 (+.f64 (*.f64 -180 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))) (+.f64 (*.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3)) (*.f64 360 (-.f64 (+.f64 (*.f64 1/4 (pow.f64 a 6)) (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2))) (*.f64 -1/4 (pow.f64 a 6)))) (*.f64 1/2 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))))))) (pow.f64 b 6))) (+.f64 (*.f64 1/24 (/.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (pow.f64 b 4))) (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))))))
(fma.f64 -2 (neg.f64 (log.f64 b)) (fma.f64 1/720 (/.f64 (fma.f64 -180 (*.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2))) (fma.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 3) (*.f64 360 (+.f64 (fma.f64 1/4 (pow.f64 a 6) (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 (pow.f64 a 4) 0)) (*.f64 (pow.f64 a 6) -1/4))) (*.f64 -1/2 (*.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))))))) (pow.f64 b 6)) (fma.f64 1/24 (/.f64 (fma.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (*.f64 12 (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))) (pow.f64 b 4)) (/.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) (*.f64 b b)))))
(fma.f64 -2 (neg.f64 (log.f64 b)) (fma.f64 1/720 (/.f64 (fma.f64 -180 (*.f64 (fma.f64 2 (*.f64 a a) 4) (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2)))) (fma.f64 360 (-.f64 (fma.f64 (pow.f64 a 6) 1/4 (fma.f64 (pow.f64 a 6) -1/4 (*.f64 a (*.f64 a 0)))) (*.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))))) (*.f64 30 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3)))) (pow.f64 b 6)) (fma.f64 1/24 (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (pow.f64 b 4)) (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 b b)))))
(+.f64 (*.f64 2 (log.f64 b)) (fma.f64 1/720 (/.f64 (fma.f64 -180 (*.f64 (fma.f64 2 (*.f64 a a) 4) (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2))) (fma.f64 360 (*.f64 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (+.f64 -2 (neg.f64 (*.f64 a a)))) (*.f64 30 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3)))) (pow.f64 b 6)) (fma.f64 1/24 (/.f64 (fma.f64 12 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (pow.f64 b 4)) (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 b b)))))
(*.f64 -2 (log.f64 (/.f64 -1 b)))
(+.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) (*.f64 -2 (log.f64 (/.f64 -1 b))))
(fma.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b)) (*.f64 -2 (log.f64 (/.f64 -1 b))))
(fma.f64 -2 (log.f64 (/.f64 -1 b)) (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 b b)))
(fma.f64 -2 (log.f64 (/.f64 -1 b)) (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 b b)))
(+.f64 (*.f64 1/24 (/.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (pow.f64 b 4))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) (*.f64 -2 (log.f64 (/.f64 -1 b)))))
(fma.f64 1/24 (/.f64 (fma.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (*.f64 12 (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))) (pow.f64 b 4)) (fma.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b)) (*.f64 -2 (log.f64 (/.f64 -1 b)))))
(fma.f64 1/24 (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (pow.f64 b 4)) (fma.f64 -2 (log.f64 (/.f64 -1 b)) (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 b b))))
(fma.f64 1/24 (/.f64 (fma.f64 12 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (pow.f64 b 4)) (fma.f64 -2 (log.f64 (/.f64 -1 b)) (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 b b))))
(+.f64 (*.f64 1/720 (/.f64 (+.f64 (*.f64 -180 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))) (+.f64 (*.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 3)) (*.f64 360 (-.f64 (+.f64 (*.f64 1/4 (pow.f64 a 6)) (+.f64 (*.f64 2 (*.f64 (+.f64 (*.f64 -1/4 (pow.f64 a 4)) (*.f64 1/4 (pow.f64 a 4))) (pow.f64 a 2))) (*.f64 -1/4 (pow.f64 a 6)))) (*.f64 1/2 (*.f64 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)) (+.f64 4 (*.f64 2 (pow.f64 a 2))))))))) (pow.f64 b 6))) (+.f64 (*.f64 1/24 (/.f64 (+.f64 (*.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) 2)) (*.f64 12 (-.f64 (+.f64 (*.f64 1/2 (pow.f64 a 4)) (+.f64 (*.f64 -1/2 (pow.f64 a 4)) (pow.f64 a 4))) (pow.f64 (*.f64 1/2 (+.f64 4 (*.f64 2 (pow.f64 a 2)))) 2)))) (pow.f64 b 4))) (+.f64 (*.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) (*.f64 -2 (log.f64 (/.f64 -1 b))))))
(fma.f64 1/720 (/.f64 (fma.f64 -180 (*.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2))) (fma.f64 30 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 3) (*.f64 360 (+.f64 (fma.f64 1/4 (pow.f64 a 6) (fma.f64 2 (*.f64 (*.f64 a a) (*.f64 (pow.f64 a 4) 0)) (*.f64 (pow.f64 a 6) -1/4))) (*.f64 -1/2 (*.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))))))) (pow.f64 b 6)) (fma.f64 1/24 (/.f64 (fma.f64 -3 (pow.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) 2) (*.f64 12 (-.f64 (fma.f64 1/2 (pow.f64 a 4) (*.f64 (pow.f64 a 4) 1/2)) (pow.f64 (+.f64 2 (*.f64 1/2 (*.f64 2 (*.f64 a a)))) 2)))) (pow.f64 b 4)) (fma.f64 1/2 (/.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b)) (*.f64 -2 (log.f64 (/.f64 -1 b))))))
(fma.f64 1/720 (/.f64 (fma.f64 -180 (*.f64 (fma.f64 2 (*.f64 a a) 4) (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2)))) (fma.f64 360 (-.f64 (fma.f64 (pow.f64 a 6) 1/4 (fma.f64 (pow.f64 a 6) -1/4 (*.f64 a (*.f64 a 0)))) (*.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))))) (*.f64 30 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3)))) (pow.f64 b 6)) (fma.f64 1/24 (/.f64 (fma.f64 12 (+.f64 0 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) 2))) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (pow.f64 b 4)) (fma.f64 -2 (log.f64 (/.f64 -1 b)) (/.f64 (+.f64 2 (*.f64 1 (*.f64 a a))) (*.f64 b b)))))
(fma.f64 1/720 (/.f64 (fma.f64 -180 (*.f64 (fma.f64 2 (*.f64 a a) 4) (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2))) (fma.f64 360 (*.f64 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (+.f64 -2 (neg.f64 (*.f64 a a)))) (*.f64 30 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 3)))) (pow.f64 b 6)) (fma.f64 1/24 (/.f64 (fma.f64 12 (-.f64 (pow.f64 a 4) (pow.f64 (+.f64 2 (*.f64 a a)) 2)) (*.f64 -3 (pow.f64 (fma.f64 2 (*.f64 a a) 4) 2))) (pow.f64 b 4)) (fma.f64 -2 (log.f64 (/.f64 -1 b)) (/.f64 (+.f64 2 (*.f64 a a)) (*.f64 b b)))))

localize9.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (pow.f64 a 4) 1)
Compiler

Compiled 13 to 10 computations (23.1% saved)

series2.0ms (0%)

Counts
1 → 3
Calls

3 calls:

TimeVariablePointExpression
1.0ms
a
@-inf
(-.f64 (pow.f64 a 4) 1)
1.0ms
a
@inf
(-.f64 (pow.f64 a 4) 1)
0.0ms
a
@0
(-.f64 (pow.f64 a 4) 1)

rewrite49.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
551×pow1_binary64
519×add-log-exp_binary64
517×log1p-expm1-u_binary64
517×expm1-log1p-u_binary64
508×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
067
11317
215067
Stop Event
node limit
Counts
1 → 31
Calls
Call 1
Inputs
(-.f64 (pow.f64 a 4) 1)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 a 4) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (pow.f64 a 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (pow.f64 a 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 a 4) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 (pow.f64 a 4) -1)) (pow.f64 (cbrt.f64 (+.f64 (pow.f64 a 4) -1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 (pow.f64 a 4) -1)) 2) (cbrt.f64 (+.f64 (pow.f64 a 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 (pow.f64 a 4) -1)) (sqrt.f64 (+.f64 (pow.f64 a 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 a 12) -1) (/.f64 1 (+.f64 (pow.f64 a 8) (+.f64 (pow.f64 a 4) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 a 8) -1) (/.f64 1 (+.f64 (pow.f64 a 4) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 a 8) (+.f64 (pow.f64 a 4) 1)) (+.f64 (pow.f64 a 12) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 a 4) 1) (+.f64 (pow.f64 a 8) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 a 12) -1) (+.f64 (pow.f64 a 8) (+.f64 (pow.f64 a 4) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 a 12) -1) (+.f64 (pow.f64 a 8) (-.f64 1 (*.f64 (pow.f64 a 4) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 a 8) -1) (+.f64 (pow.f64 a 4) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 a 8) -1) (-.f64 (pow.f64 a 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 a 12) -1)) (neg.f64 (+.f64 (pow.f64 a 8) (+.f64 (pow.f64 a 4) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 a 8) -1)) (neg.f64 (+.f64 (pow.f64 a 4) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (pow.f64 a 4) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (pow.f64 a 4) -1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 (pow.f64 a 4) -1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 (pow.f64 a 4) -1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 (pow.f64 a 4) -1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 (pow.f64 a 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 (pow.f64 a 4) -1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (*.f64 4 (log.f64 a)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 (pow.f64 a 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (+.f64 (pow.f64 a 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (pow.f64 a 4) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 a 8)) (cbrt.f64 (pow.f64 a 4)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 a a) (*.f64 a a) -1)))))

simplify190.0ms (2.1%)

Algorithm
egg-herbie
Rules
1319×sqr-pow_binary64
662×cube-prod_binary64
659×pow-sqr_binary64
519×fabs-mul_binary64
384×unpow3_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
059
199
2159
3269
4519
51359
64929
711429
812669
914359
1016349
1119059
1222629
1327149
1432479
1538719
1646229
1749369
1851609
1953569
2054089
2154309
2262649
2371779
2475799
2578459
Stop Event
node limit
Counts
34 → 33
Calls
Call 1
Inputs
-1
(pow.f64 a 4)
(pow.f64 a 4)
Outputs
-1
(pow.f64 a 4)
(pow.f64 a 4)

localize15.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b)))
0.0b
(*.f64 4 (*.f64 b b))
Compiler

Compiled 36 to 21 computations (41.7% saved)

series2.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
1.0ms
b
@inf
(+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b)))
1.0ms
b
@0
(+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b)))
0.0ms
b
@-inf
(+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b)))

rewrite57.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
755×pow1_binary64
710×add-log-exp_binary64
710×log1p-expm1-u_binary64
710×expm1-log1p-u_binary64
693×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0713
115611
2203811
Stop Event
node limit
Counts
1 → 38
Calls
Call 1
Inputs
(+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 b 8) (+.f64 (pow.f64 b 4) (*.f64 -4 (*.f64 b b)))) (/.f64 (*.f64 (pow.f64 b 4) 16) (+.f64 (pow.f64 b 4) (*.f64 -4 (*.f64 b b)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 b b) (+.f64 4 (*.f64 b b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) (pow.f64 (cbrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 2) (cbrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 (*.f64 b b) (*.f64 b 2)) (hypot.f64 (*.f64 b b) (*.f64 b 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 b 12) (*.f64 64 (pow.f64 b 6))) (/.f64 1 (-.f64 (+.f64 (pow.f64 b 8) (*.f64 (pow.f64 b 4) 16)) (*.f64 (pow.f64 b 6) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 b 8) (*.f64 (pow.f64 b 4) 16)) (/.f64 1 (+.f64 (pow.f64 b 4) (*.f64 -4 (*.f64 b b)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (+.f64 (pow.f64 b 8) (*.f64 (pow.f64 b 4) 16)) (*.f64 (pow.f64 b 6) 4)) (+.f64 (pow.f64 b 12) (*.f64 64 (pow.f64 b 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 b 4) (*.f64 -4 (*.f64 b b))) (-.f64 (pow.f64 b 8) (*.f64 (pow.f64 b 4) 16))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 b 12) (*.f64 64 (pow.f64 b 6))) (-.f64 (+.f64 (pow.f64 b 8) (*.f64 (pow.f64 b 4) 16)) (*.f64 (pow.f64 b 6) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 b 12) (*.f64 64 (pow.f64 b 6))) (+.f64 (*.f64 (pow.f64 b 4) 16) (-.f64 (pow.f64 b 8) (*.f64 (pow.f64 b 6) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 b 8) (*.f64 (pow.f64 b 4) 16)) (+.f64 (pow.f64 b 4) (*.f64 -4 (*.f64 b b))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 b 12) (*.f64 64 (pow.f64 b 6)))) (neg.f64 (-.f64 (+.f64 (pow.f64 b 8) (*.f64 (pow.f64 b 4) 16)) (*.f64 (pow.f64 b 6) 4))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 b 8) (*.f64 (pow.f64 b 4) 16))) (neg.f64 (+.f64 (pow.f64 b 4) (*.f64 -4 (*.f64 b b)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (pow.f64 b 4) 16) (pow.f64 b 8)) (-.f64 (*.f64 b (*.f64 b 4)) (pow.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (hypot.f64 (*.f64 b b) (*.f64 b 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 4 (*.f64 b b) (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b b) 4 (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b b) (*.f64 b b) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (pow.f64 b 4) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 b (*.f64 b 4)) (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 (pow.f64 b 4) 16)) (cbrt.f64 (*.f64 b (*.f64 b 4))) (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 b 8)) (cbrt.f64 (pow.f64 b 4)) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b 2) (*.f64 b 2) (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b 4) b (pow.f64 b 4))))))

simplify240.0ms (2.7%)

Algorithm
egg-herbie
Rules
1319×sqr-pow_binary64
659×pow-sqr_binary64
493×cube-prod_binary64
408×fabs-mul_binary64
392×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
09114
118114
240114
398114
4272114
5933114
61877114
72172114
82357114
92558114
102832114
113194114
123649114
134185114
144811114
155564114
165875114
176103114
186305114
196363114
206385114
217219114
Stop Event
node limit
Counts
50 → 44
Calls
Call 1
Inputs
(*.f64 4 (pow.f64 b 2))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
Outputs
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))

localize13.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(*.f64 b (fma.f64 b b 4))
0.1b
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
Compiler

Compiled 24 to 14 computations (41.7% saved)

series3.0ms (0%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
1.0ms
b
@0
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
1.0ms
b
@-inf
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
1.0ms
b
@inf
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
0.0ms
b
@-inf
(*.f64 b (fma.f64 b b 4))
0.0ms
b
@inf
(*.f64 b (fma.f64 b b 4))

rewrite82.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
612×pow1_binary64
566×add-log-exp_binary64
566×log1p-expm1-u_binary64
566×expm1-log1p-u_binary64
555×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0720
113720
2150720
Stop Event
node limit
Counts
2 → 34
Calls
Call 1
Inputs
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
(*.f64 b (fma.f64 b b 4))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (*.f64 b (*.f64 b (fma.f64 b b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)) (pow.f64 (cbrt.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)) 2) (cbrt.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)) (sqrt.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 3) -1) (+.f64 (*.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) (*.f64 b (*.f64 b (fma.f64 b b 4)))) (-.f64 1 (*.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) (*.f64 b (*.f64 b (fma.f64 b b 4)))) 1) (-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 b 3) (*.f64 4 b))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 b 3) (*.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 b (fma.f64 b b 4))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 b (fma.f64 b b 4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 b (fma.f64 b b 4)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 b (fma.f64 b b 4))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 b (fma.f64 b b 4))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 b (fma.f64 b b 4)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 b) (fma.f64 b b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 b (fma.f64 b b 4)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 b (fma.f64 b b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 b (fma.f64 b b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 b (fma.f64 b b 4))))))))

simplify160.0ms (1.8%)

Algorithm
egg-herbie
Rules
731×fma-neg_binary64
664×distribute-rgt-out_binary64
484×distribute-rgt-neg-in_binary64
456×associate-*l*_binary64
446×distribute-lft-neg-in_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
016207
143207
283195
3171195
4533195
52478195
65303195
Stop Event
node limit
Counts
58 → 46
Calls
Call 1
Inputs
-1
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(*.f64 4 b)
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(pow.f64 b 3)
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(pow.f64 b 3)
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
Outputs
-1
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(fma.f64 4 (*.f64 b b) -1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) -1)
(fma.f64 (*.f64 b b) (fma.f64 b b 4) -1)
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) -1)
(fma.f64 (*.f64 b b) (fma.f64 b b 4) -1)
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) -1)
(fma.f64 (*.f64 b b) (fma.f64 b b 4) -1)
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) -1)
(fma.f64 (*.f64 b b) (fma.f64 b b 4) -1)
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) -1)
(fma.f64 (*.f64 b b) (fma.f64 b b 4) -1)
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
(-.f64 (+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4)) 1)
(+.f64 (fma.f64 4 (*.f64 b b) (pow.f64 b 4)) -1)
(fma.f64 (*.f64 b b) (fma.f64 b b 4) -1)
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
(*.f64 4 b)
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(fma.f64 4 b (pow.f64 b 3))
(*.f64 b (fma.f64 b b 4))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(fma.f64 4 b (pow.f64 b 3))
(*.f64 b (fma.f64 b b 4))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(fma.f64 4 b (pow.f64 b 3))
(*.f64 b (fma.f64 b b 4))
(pow.f64 b 3)
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(fma.f64 4 b (pow.f64 b 3))
(*.f64 b (fma.f64 b b 4))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(fma.f64 4 b (pow.f64 b 3))
(*.f64 b (fma.f64 b b 4))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(fma.f64 4 b (pow.f64 b 3))
(*.f64 b (fma.f64 b b 4))
(pow.f64 b 3)
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(fma.f64 4 b (pow.f64 b 3))
(*.f64 b (fma.f64 b b 4))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(fma.f64 4 b (pow.f64 b 3))
(*.f64 b (fma.f64 b b 4))
(+.f64 (*.f64 4 b) (pow.f64 b 3))
(fma.f64 4 b (pow.f64 b 3))
(*.f64 b (fma.f64 b b 4))

localize14.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 b (*.f64 b 4) (pow.f64 b 4))
Compiler

Compiled 29 to 20 computations (31% saved)

series2.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
1.0ms
b
@0
(fma.f64 b (*.f64 b 4) (pow.f64 b 4))
0.0ms
b
@-inf
(fma.f64 b (*.f64 b 4) (pow.f64 b 4))
0.0ms
b
@inf
(fma.f64 b (*.f64 b 4) (pow.f64 b 4))

rewrite47.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
545×pow1_binary64
522×add-sqr-sqrt_binary64
504×add-log-exp_binary64
504×log1p-expm1-u_binary64
504×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0611
112611
2141411
Stop Event
node limit
Counts
1 → 21
Calls
Call 1
Inputs
(fma.f64 b (*.f64 b 4) (pow.f64 b 4))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 b 4) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 b (*.f64 b 4)) (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 b (*.f64 b 4)) 1) (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))) (pow.f64 (cbrt.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))) 2) (cbrt.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))) (sqrt.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 b (*.f64 b 4)) 3) (pow.f64 (pow.f64 b 4) 3)) (+.f64 (*.f64 (*.f64 b (*.f64 b 4)) (*.f64 b (*.f64 b 4))) (-.f64 (pow.f64 b 8) (*.f64 (*.f64 b (*.f64 b 4)) (pow.f64 b 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 b (*.f64 b 4)) (*.f64 b (*.f64 b 4))) (pow.f64 b 8)) (-.f64 (*.f64 b (*.f64 b 4)) (pow.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4))))))))

simplify180.0ms (2%)

Algorithm
egg-herbie
Rules
1319×sqr-pow_binary64
659×pow-sqr_binary64
493×cube-prod_binary64
408×fabs-mul_binary64
392×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
09114
118114
240114
398114
4272114
5933114
61877114
72172114
82357114
92558114
102832114
113194114
123649114
134185114
144811114
155564114
165875114
176103114
186305114
196363114
206385114
217219114
Stop Event
node limit
Counts
33 → 27
Calls
Call 1
Inputs
(*.f64 4 (pow.f64 b 2))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
Outputs
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))

eval444.0ms (4.9%)

Compiler

Compiled 11934 to 8861 computations (25.7% saved)

prune91.0ms (1%)

Pruning

9 alts after pruning (7 fresh and 2 done)

PrunedKeptTotal
New3887395
Fresh000
Picked011
Done415
Total3929401
Error
0b
Counts
401 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
26.0b
-1
15.0b
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
48.0b
(pow.f64 a 4)
24.9b
(-.f64 (*.f64 4 (*.f64 b b)) 1)
11.3b
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
15.0b
(-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1)
0.2b
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
14.9b
(-.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 1)
52.6b
(pow.f64 b 4)
Compiler

Compiled 148 to 102 computations (31.1% saved)

localize11.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 a a) 1)
0.1b
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
Compiler

Compiled 28 to 13 computations (53.6% saved)

series2.0ms (0%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
1.0ms
a
@0
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
1.0ms
a
@inf
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
0.0ms
a
@-inf
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
0.0ms
a
@0
(+.f64 (*.f64 a a) 1)
0.0ms
a
@inf
(+.f64 (*.f64 a a) 1)

rewrite67.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
738×pow1_binary64
690×add-log-exp_binary64
689×log1p-expm1-u_binary64
689×expm1-log1p-u_binary64
676×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0717
115412
2204612
Stop Event
node limit
Counts
2 → 75
Calls
Call 1
Inputs
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
(+.f64 (*.f64 a a) 1)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 a a -1) (*.f64 (*.f64 a a) (fma.f64 a a -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 a a -1) (*.f64 (fma.f64 a a -1) (*.f64 a a)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 a 4) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 a a) (fma.f64 a a 1)) (*.f64 -1 (fma.f64 a a 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 a a) (fma.f64 a a -1)) (fma.f64 a a -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (fma.f64 a a 1) (*.f64 a a)) (*.f64 (fma.f64 a a 1) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (fma.f64 a a -1) (*.f64 a a)) (fma.f64 a a -1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (pow.f64 a 4) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (+.f64 (pow.f64 a 4) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 (+.f64 (pow.f64 a 4) -1) 2) (+.f64 (pow.f64 a 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1 (pow.f64 a 6)) (+.f64 (pow.f64 a 6) -1)) (*.f64 (-.f64 (+.f64 (pow.f64 a 4) 1) (*.f64 a a)) (+.f64 (fma.f64 a a 1) (pow.f64 a 4))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 4) -1) (+.f64 (pow.f64 a 6) -1)) (*.f64 (fma.f64 a a -1) (+.f64 (fma.f64 a a 1) (pow.f64 a 4))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1 (pow.f64 a 6)) (+.f64 (pow.f64 a 4) -1)) (*.f64 (-.f64 (+.f64 (pow.f64 a 4) 1) (*.f64 a a)) (fma.f64 a a 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 6) -1) (+.f64 1 (pow.f64 a 6))) (*.f64 (+.f64 (fma.f64 a a 1) (pow.f64 a 4)) (-.f64 (+.f64 (pow.f64 a 4) 1) (*.f64 a a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 4) -1) (+.f64 1 (pow.f64 a 6))) (*.f64 (fma.f64 a a 1) (-.f64 (+.f64 (pow.f64 a 4) 1) (*.f64 a a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 6) -1) (+.f64 (pow.f64 a 4) -1)) (*.f64 (+.f64 (fma.f64 a a 1) (pow.f64 a 4)) (fma.f64 a a -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (pow.f64 a 4) 3) 1) (+.f64 (*.f64 (pow.f64 a 4) (pow.f64 a 4)) (+.f64 1 (*.f64 (pow.f64 a 4) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (pow.f64 a 4) (pow.f64 a 4)) 1) (+.f64 (pow.f64 a 4) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1 (pow.f64 a 6)) (fma.f64 a a -1)) (-.f64 (+.f64 (pow.f64 a 4) 1) (*.f64 a a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 4) -1) (fma.f64 a a -1)) (fma.f64 a a -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 6) -1) (fma.f64 a a 1)) (+.f64 (fma.f64 a a 1) (pow.f64 a 4)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 4) -1) (fma.f64 a a 1)) (fma.f64 a a 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 a a 1) (+.f64 (pow.f64 a 6) -1)) (+.f64 (fma.f64 a a 1) (pow.f64 a 4)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 a a 1) (+.f64 (pow.f64 a 4) -1)) (fma.f64 a a 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 a a -1) (+.f64 1 (pow.f64 a 6))) (-.f64 (+.f64 (pow.f64 a 4) 1) (*.f64 a a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 a a -1) (+.f64 (pow.f64 a 4) -1)) (fma.f64 a a -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (pow.f64 a 4) -1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 (pow.f64 a 4) -1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 (pow.f64 a 4) -1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (pow.f64 a 4) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 (pow.f64 a 4) -1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 (pow.f64 a 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 (pow.f64 a 4) -1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 a a 1) 3) (pow.f64 (fma.f64 a a -1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 a a -1) 3) (pow.f64 (fma.f64 a a 1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 (pow.f64 a 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 (pow.f64 a 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (+.f64 (pow.f64 a 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 a a) (*.f64 a a) -1)))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 a a 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 a 4) (fma.f64 a a -1)) (/.f64 1 (fma.f64 a a -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 a a 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 a a 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 a a 1)) (pow.f64 (cbrt.f64 (fma.f64 a a 1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 a a 1)) 2) (cbrt.f64 (fma.f64 a a 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 1 a) (hypot.f64 1 a))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 1 (pow.f64 a 6)) (/.f64 1 (-.f64 (+.f64 (pow.f64 a 4) 1) (*.f64 a a))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 a 4) -1) (/.f64 1 (fma.f64 a a -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 (pow.f64 a 4) -1) (+.f64 (pow.f64 a 6) -1)) (+.f64 (fma.f64 a a 1) (pow.f64 a 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (+.f64 (pow.f64 a 4) -1) (+.f64 (pow.f64 a 4) -1)) (fma.f64 a a 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (+.f64 (pow.f64 a 4) 1) (*.f64 a a)) (+.f64 1 (pow.f64 a 6))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 a a -1) (+.f64 (pow.f64 a 4) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1 (pow.f64 a 6)) (-.f64 (+.f64 (pow.f64 a 4) 1) (*.f64 a a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1 (pow.f64 a 6)) (+.f64 1 (-.f64 (pow.f64 a 4) (*.f64 a a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 a 4) -1) (fma.f64 a a -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 1 (pow.f64 a 6))) (neg.f64 (-.f64 (+.f64 (pow.f64 a 4) 1) (*.f64 a a))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 a 4) -1)) (neg.f64 (fma.f64 a a -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1 (pow.f64 a 4)) (-.f64 1 (*.f64 a a)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (+.f64 (pow.f64 a 4) -1) 1) (fma.f64 a a -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (+.f64 (pow.f64 a 4) -1) (pow.f64 (cbrt.f64 (fma.f64 a a -1)) 2)) (cbrt.f64 (fma.f64 a a -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (+.f64 (pow.f64 a 4) -1) (sqrt.f64 (fma.f64 a a -1))) (sqrt.f64 (fma.f64 a a -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (+.f64 (pow.f64 a 4) -1) (+.f64 a 1)) (+.f64 a -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 a a 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 a a 1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 a a 1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (hypot.f64 1 a) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 a a 1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 a a 1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 a a 1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 a a 1)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 a a 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log1p.f64 (*.f64 a a)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 a a 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 a a) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 a 4)) (cbrt.f64 (*.f64 a a)) 1)))))

simplify50.0ms (0.6%)

Algorithm
egg-herbie
Rules
463×distribute-rgt-in_binary64
444×distribute-rgt-out_binary64
436×distribute-lft-in_binary64
348×fma-neg_binary64
342×unswap-sqr_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
010144
121126
237126
371126
4191126
5723126
62143126
74705126
Stop Event
node limit
Counts
99 → 81
Calls
Call 1
Inputs
-1
(-.f64 (pow.f64 a 4) 1)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (pow.f64 a 4) 1)
(pow.f64 a 4)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (pow.f64 a 4) 1)
(pow.f64 a 4)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (pow.f64 a 4) 1)
1
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (pow.f64 a 2))
(pow.f64 a 2)
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (pow.f64 a 2))
(pow.f64 a 2)
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (pow.f64 a 2))
Outputs
-1
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
(pow.f64 a 4)
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
(pow.f64 a 4)
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
(-.f64 (pow.f64 a 4) 1)
(+.f64 (pow.f64 a 4) -1)
1
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (*.f64 a a))
(fma.f64 a a 1)
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (*.f64 a a))
(fma.f64 a a 1)
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (*.f64 a a))
(fma.f64 a a 1)
(pow.f64 a 2)
(*.f64 a a)
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (*.f64 a a))
(fma.f64 a a 1)
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (*.f64 a a))
(fma.f64 a a 1)
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (*.f64 a a))
(fma.f64 a a 1)
(pow.f64 a 2)
(*.f64 a a)
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (*.f64 a a))
(fma.f64 a a 1)
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (*.f64 a a))
(fma.f64 a a 1)
(+.f64 1 (pow.f64 a 2))
(+.f64 1 (*.f64 a a))
(fma.f64 a a 1)

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (*.f64 4 (*.f64 b b)) 1)
0.0b
(*.f64 4 (*.f64 b b))
Compiler

Compiled 20 to 11 computations (45% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
0.0ms
b
@0
(-.f64 (*.f64 4 (*.f64 b b)) 1)
0.0ms
b
@inf
(-.f64 (*.f64 4 (*.f64 b b)) 1)
0.0ms
b
@-inf
(-.f64 (*.f64 4 (*.f64 b b)) 1)

rewrite141.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
645×pow1_binary64
604×add-log-exp_binary64
602×log1p-expm1-u_binary64
602×expm1-log1p-u_binary64
592×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
078
11498
217488
Stop Event
node limit
Counts
1 → 34
Calls
Call 1
Inputs
(-.f64 (*.f64 4 (*.f64 b b)) 1)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 4 (*.f64 b b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (*.f64 4 (*.f64 b b)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 (*.f64 4 b) b -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (*.f64 4 b) b -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 (*.f64 4 b) b -1)) (pow.f64 (cbrt.f64 (fma.f64 (*.f64 4 b) b -1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 (*.f64 4 b) b -1)) 2) (cbrt.f64 (fma.f64 (*.f64 4 b) b -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 (*.f64 4 b) b -1)) (sqrt.f64 (fma.f64 (*.f64 4 b) b -1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 64 (pow.f64 (*.f64 b b) 3)) -1) (/.f64 1 (+.f64 (*.f64 16 (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 16 (pow.f64 b 4)) -1) (/.f64 1 (fma.f64 4 (*.f64 b b) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 b 2) 1) (-.f64 (*.f64 b 2) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (*.f64 16 (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) 1)) (+.f64 (*.f64 64 (pow.f64 (*.f64 b b) 3)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 4 (*.f64 b b) 1) (+.f64 (*.f64 16 (pow.f64 b 4)) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 64 (pow.f64 (*.f64 b b) 3)) -1) (+.f64 (*.f64 16 (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 64 (pow.f64 (*.f64 b b) 3)) -1) (+.f64 (*.f64 16 (pow.f64 b 4)) (-.f64 1 (*.f64 (*.f64 4 (*.f64 b b)) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 16 (pow.f64 b 4)) -1) (fma.f64 4 (*.f64 b b) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 16 (pow.f64 b 4)) -1) (-.f64 (*.f64 4 (*.f64 b b)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (*.f64 64 (pow.f64 (*.f64 b b) 3)) -1)) (neg.f64 (+.f64 (*.f64 16 (pow.f64 b 4)) (fma.f64 4 (*.f64 b b) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (*.f64 16 (pow.f64 b 4)) -1)) (neg.f64 (fma.f64 4 (*.f64 b b) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 (*.f64 4 b) b -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 (*.f64 4 b) b -1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 (*.f64 4 b) b -1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 (*.f64 4 b) b -1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 (*.f64 4 b) b -1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 (*.f64 4 b) b -1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 (*.f64 4 b) b -1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log.f64 (*.f64 4 (*.f64 b b))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 (*.f64 4 b) b -1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 (*.f64 4 b) b -1)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 4 (*.f64 b b) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b b) 4 -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 4 (*.f64 b b)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 16 (pow.f64 b 4))) (cbrt.f64 (*.f64 4 (*.f64 b b))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b 2) (*.f64 b 2) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 4 b) b -1)))))

simplify155.0ms (1.7%)

Algorithm
egg-herbie
Rules
1082×sqr-pow_binary64
560×cube-prod_binary64
558×fabs-mul_binary64
523×pow-sqr_binary64
449×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0987
11987
23087
35487
412187
535287
6127687
7216987
8233387
9251787
10272587
11302387
12341487
13389787
14446387
15515387
16599487
17638487
18667287
19695087
20702487
21706087
Stop Event
node limit
Counts
46 → 39
Calls
Call 1
Inputs
-1
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(*.f64 4 (pow.f64 b 2))
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(*.f64 4 (pow.f64 b 2))
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
Outputs
-1
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(fma.f64 4 (*.f64 b b) -1)
(fma.f64 b (*.f64 4 b) -1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(fma.f64 4 (*.f64 b b) -1)
(fma.f64 b (*.f64 4 b) -1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(fma.f64 4 (*.f64 b b) -1)
(fma.f64 b (*.f64 4 b) -1)
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(fma.f64 4 (*.f64 b b) -1)
(fma.f64 b (*.f64 4 b) -1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(fma.f64 4 (*.f64 b b) -1)
(fma.f64 b (*.f64 4 b) -1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(fma.f64 4 (*.f64 b b) -1)
(fma.f64 b (*.f64 4 b) -1)
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(fma.f64 4 (*.f64 b b) -1)
(fma.f64 b (*.f64 4 b) -1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(fma.f64 4 (*.f64 b b) -1)
(fma.f64 b (*.f64 4 b) -1)
(-.f64 (*.f64 4 (pow.f64 b 2)) 1)
(fma.f64 4 (*.f64 b b) -1)
(fma.f64 b (*.f64 4 b) -1)

localize11.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4))
Compiler

Compiled 33 to 15 computations (54.5% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
1.0ms
b
@0
(*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4))
0.0ms
b
@inf
(*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4))
0.0ms
b
@-inf
(*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4))

rewrite51.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
676×pow1_binary64
636×add-log-exp_binary64
636×log1p-expm1-u_binary64
636×expm1-log1p-u_binary64
623×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0611
113711
2176711
Stop Event
node limit
Counts
1 → 23
Calls
Call 1
Inputs
(*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 b 4) (*.f64 b (*.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 b (*.f64 b 4)) (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (pow.f64 b 4) 1) (*.f64 (*.f64 b (*.f64 b 4)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 b (*.f64 b (fma.f64 b b 4)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (pow.f64 b 4) 3) (pow.f64 (*.f64 b (*.f64 b 4)) 3)) (+.f64 (*.f64 (pow.f64 b 4) (pow.f64 b 4)) (-.f64 (*.f64 (*.f64 b (*.f64 b 4)) (*.f64 b (*.f64 b 4))) (*.f64 (pow.f64 b 4) (*.f64 b (*.f64 b 4))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (pow.f64 b 4) (pow.f64 b 4)) (*.f64 (*.f64 b (*.f64 b 4)) (*.f64 b (*.f64 b 4)))) (-.f64 (pow.f64 b 4) (*.f64 b (*.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 64 (pow.f64 b 6)) (*.f64 b b)) (+.f64 (pow.f64 b 4) (-.f64 16 (*.f64 b (*.f64 b 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 b 4) -16) (*.f64 b b)) (fma.f64 b b -4))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 b b) (+.f64 64 (pow.f64 b 6))) (+.f64 (pow.f64 b 4) (-.f64 16 (*.f64 b (*.f64 b 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 b b) (+.f64 (pow.f64 b 4) -16)) (fma.f64 b b -4))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 b (*.f64 b (fma.f64 b b 4)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 b (sqrt.f64 (fma.f64 b b 4))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 b 4) (pow.f64 (fma.f64 b b 4) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (exp.f64 b) b) (fma.f64 b b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 b 6) (pow.f64 (fma.f64 b b 4) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 b b 4) 3) (pow.f64 b 6)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 b (*.f64 b (fma.f64 b b 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 b (*.f64 b (fma.f64 b b 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 b (*.f64 b (fma.f64 b b 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b b) (*.f64 b b) (*.f64 b (*.f64 b 4)))))))

simplify178.0ms (2%)

Algorithm
egg-herbie
Rules
1319×sqr-pow_binary64
659×pow-sqr_binary64
493×cube-prod_binary64
408×fabs-mul_binary64
392×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
09114
118114
240114
398114
4272114
5933114
61877114
72172114
82357114
92558114
102832114
113194114
123649114
134185114
144811114
155564114
165875114
176103114
186305114
196363114
206385114
217219114
Stop Event
node limit
Counts
35 → 29
Calls
Call 1
Inputs
(*.f64 4 (pow.f64 b 2))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
Outputs
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))

localize3.0ms (0%)

Compiler

Compiled 7 to 5 computations (28.6% saved)

localize176.0ms (1.9%)

Compiler

Compiled 7 to 5 computations (28.6% saved)

eval55.0ms (0.6%)

Compiler

Compiled 2263 to 1558 computations (31.2% saved)

prune28.0ms (0.3%)

Pruning

12 alts after pruning (5 fresh and 7 done)

PrunedKeptTotal
New1653168
Fresh022
Picked011
Done066
Total16512177
Error
0b
Counts
177 → 12
Alt Table
Click to see full alt table
StatusErrorProgram
26.0b
-1
15.0b
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
48.0b
(pow.f64 a 4)
24.9b
(-.f64 (*.f64 4 (*.f64 b b)) 1)
52.6b
(pow.f64 b 4)
47.7b
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
61.8b
(*.f64 4 (*.f64 b b))
25.4b
(*.f64 1 (-.f64 (*.f64 a a) 1))
11.3b
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
15.0b
(-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1)
0.2b
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
14.9b
(-.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 1)
Compiler

Compiled 118 to 81 computations (31.4% saved)

localize8.0ms (0.1%)

Compiler

Compiled 19 to 10 computations (47.4% saved)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(*.f64 4 (*.f64 b b))
Compiler

Compiled 12 to 6 computations (50% saved)

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
Compiler

Compiled 21 to 9 computations (57.1% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
1.0ms
a
@0
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
0.0ms
a
@inf
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
0.0ms
a
@-inf
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))

rewrite209.0ms (2.3%)

Algorithm
batch-egg-rewrite
Rules
623×pow1_binary64
584×add-log-exp_binary64
582×log1p-expm1-u_binary64
582×expm1-log1p-u_binary64
571×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0611
113111
2169811
Stop Event
node limit
Counts
1 → 17
Calls
Call 1
Inputs
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 a 4) (*.f64 (*.f64 a a) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (pow.f64 a 4) (*.f64 -1 (*.f64 a a)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 (*.f64 a a) (fma.f64 a a -1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 6) -1) (*.f64 a a)) (+.f64 (pow.f64 a 4) (fma.f64 a a 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 a 4) -1) (*.f64 a a)) (fma.f64 a a 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 a a) (+.f64 (pow.f64 a 6) -1)) (+.f64 (pow.f64 a 4) (fma.f64 a a 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 a a) (+.f64 (pow.f64 a 4) -1)) (fma.f64 a a 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (*.f64 a a) (fma.f64 a a -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (fma.f64 a a -1) 3) (pow.f64 a 6)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (*.f64 a a) (fma.f64 a a -1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 a (sqrt.f64 (fma.f64 a a -1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 a 4) (pow.f64 (fma.f64 a a -1) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (exp.f64 a) a) (fma.f64 a a -1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 a a -1) 3) (pow.f64 a 6)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (*.f64 a a) (fma.f64 a a -1))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (*.f64 a a) (fma.f64 a a -1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (*.f64 a a) (fma.f64 a a -1))))))))

simplify70.0ms (0.8%)

Algorithm
egg-herbie
Rules
607×distribute-rgt-neg-in_binary64
551×fma-def_binary64
483×distribute-lft-neg-in_binary64
342×unswap-sqr_binary64
319×distribute-rgt-out_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
09113
120104
247104
3124104
4409104
51707104
65181104
77684104
Stop Event
node limit
Counts
29 → 22
Calls
Call 1
Inputs
(*.f64 -1 (pow.f64 a 2))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(pow.f64 a 4)
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(pow.f64 a 4)
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
Outputs
(*.f64 -1 (pow.f64 a 2))
(neg.f64 (*.f64 a a))
(*.f64 a (neg.f64 a))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(fma.f64 -1 (*.f64 a a) (pow.f64 a 4))
(-.f64 (pow.f64 a 4) (*.f64 a a))
(*.f64 a (-.f64 (pow.f64 a 3) a))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(fma.f64 -1 (*.f64 a a) (pow.f64 a 4))
(-.f64 (pow.f64 a 4) (*.f64 a a))
(*.f64 a (-.f64 (pow.f64 a 3) a))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(fma.f64 -1 (*.f64 a a) (pow.f64 a 4))
(-.f64 (pow.f64 a 4) (*.f64 a a))
(*.f64 a (-.f64 (pow.f64 a 3) a))
(pow.f64 a 4)
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(fma.f64 -1 (*.f64 a a) (pow.f64 a 4))
(-.f64 (pow.f64 a 4) (*.f64 a a))
(*.f64 a (-.f64 (pow.f64 a 3) a))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(fma.f64 -1 (*.f64 a a) (pow.f64 a 4))
(-.f64 (pow.f64 a 4) (*.f64 a a))
(*.f64 a (-.f64 (pow.f64 a 3) a))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(fma.f64 -1 (*.f64 a a) (pow.f64 a 4))
(-.f64 (pow.f64 a 4) (*.f64 a a))
(*.f64 a (-.f64 (pow.f64 a 3) a))
(pow.f64 a 4)
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(fma.f64 -1 (*.f64 a a) (pow.f64 a 4))
(-.f64 (pow.f64 a 4) (*.f64 a a))
(*.f64 a (-.f64 (pow.f64 a 3) a))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(fma.f64 -1 (*.f64 a a) (pow.f64 a 4))
(-.f64 (pow.f64 a 4) (*.f64 a a))
(*.f64 a (-.f64 (pow.f64 a 3) a))
(+.f64 (*.f64 -1 (pow.f64 a 2)) (pow.f64 a 4))
(fma.f64 -1 (*.f64 a a) (pow.f64 a 4))
(-.f64 (pow.f64 a 4) (*.f64 a a))
(*.f64 a (-.f64 (pow.f64 a 3) a))

localize14.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(*.f64 b (fma.f64 b b 4))
0.1b
(*.f64 b (*.f64 b (fma.f64 b b 4)))
Compiler

Compiled 33 to 19 computations (42.4% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
0.0ms
b
@0
(*.f64 b (*.f64 b (fma.f64 b b 4)))
0.0ms
b
@inf
(*.f64 b (*.f64 b (fma.f64 b b 4)))
0.0ms
b
@-inf
(*.f64 b (*.f64 b (fma.f64 b b 4)))

rewrite42.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
553×pow1_binary64
512×add-log-exp_binary64
512×log1p-expm1-u_binary64
512×expm1-log1p-u_binary64
502×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0611
112211
2140511
Stop Event
node limit
Counts
1 → 13
Calls
Call 1
Inputs
(*.f64 b (*.f64 b (fma.f64 b b 4)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 b b) (*.f64 b b)) (*.f64 (*.f64 b b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 b b) (*.f64 b b)) (*.f64 4 (*.f64 b b)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 b (*.f64 b (fma.f64 b b 4)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 b (*.f64 b (fma.f64 b b 4)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 b (sqrt.f64 (fma.f64 b b 4))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (exp.f64 b) (fma.f64 b b 4)) b))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 b (*.f64 b (fma.f64 b b 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 b (*.f64 b (fma.f64 b b 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 b (*.f64 b (fma.f64 b b 4)))))))))

simplify181.0ms (2%)

Algorithm
egg-herbie
Rules
1319×sqr-pow_binary64
659×pow-sqr_binary64
493×cube-prod_binary64
408×fabs-mul_binary64
392×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
09114
118114
240114
398114
4272114
5933114
61877114
72172114
82357114
92558114
102832114
113194114
123649114
134185114
144811114
155564114
165875114
176103114
186305114
196363114
206385114
217219114
Stop Event
node limit
Counts
25 → 19
Calls
Call 1
Inputs
(*.f64 4 (pow.f64 b 2))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
Outputs
(*.f64 4 (pow.f64 b 2))
(*.f64 4 (*.f64 b b))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(pow.f64 b 4)
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 b b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))

eval21.0ms (0.2%)

Compiler

Compiled 798 to 531 computations (33.5% saved)

prune16.0ms (0.2%)

Pruning

13 alts after pruning (3 fresh and 10 done)

PrunedKeptTotal
New75277
Fresh011
Picked011
Done1910
Total761389
Error
0b
Counts
89 → 13
Alt Table
Click to see full alt table
StatusErrorProgram
26.0b
-1
15.0b
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
48.0b
(pow.f64 a 4)
62.0b
(*.f64 a (neg.f64 a))
24.9b
(-.f64 (*.f64 4 (*.f64 b b)) 1)
61.8b
(*.f64 b (*.f64 b 4))
14.9b
(-.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 1)
52.6b
(pow.f64 b 4)
47.7b
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
25.4b
(*.f64 1 (-.f64 (*.f64 a a) 1))
11.3b
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
15.0b
(-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1)
0.2b
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
Compiler

Compiled 124 to 85 computations (31.5% saved)

regimes181.0ms (2%)

Counts
19 → 1
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
(pow.f64 a 4)
(pow.f64 b 4)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1)
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b))) 1)
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
(-.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 1)
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
(expm1.f64 (*.f64 2 (log.f64 (hypot.f64 (pow.f64 (hypot.f64 a b) 2) (*.f64 b 2)))))
Outputs
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
Calls

10 calls:

58.0ms
b
53.0ms
(*.f64 b b)
16.0ms
(+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b)))
11.0ms
a
9.0ms
(*.f64 a a)
Results
ErrorSegmentsBranch
0.0b1a
0.0b1b
0.0b1(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
0.0b1(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
0.0b1(+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b)))
0.0b1(+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b)))
0.0b1(*.f64 a a)
0.0b1(*.f64 a a)
0.0b1(*.f64 b b)
0.0b1(*.f64 b b)
Compiler

Compiled 253 to 151 computations (40.3% saved)

regimes89.0ms (1%)

Counts
17 → 1
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
(pow.f64 a 4)
(pow.f64 b 4)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1)
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b))) 1)
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
(fma.f64 b (*.f64 b (fma.f64 b b 4)) -1)
(-.f64 (fma.f64 b (*.f64 b 4) (pow.f64 b 4)) 1)
Outputs
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
Calls

6 calls:

47.0ms
(*.f64 a a)
10.0ms
a
10.0ms
b
7.0ms
(+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b)))
5.0ms
(*.f64 b b)
Results
ErrorSegmentsBranch
0.2b1a
0.2b1b
0.2b1(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
0.2b1(+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b)))
0.2b1(*.f64 a a)
0.2b1(*.f64 b b)
Compiler

Compiled 182 to 106 computations (41.8% saved)

regimes102.0ms (1.1%)

Counts
14 → 3
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
(pow.f64 a 4)
(pow.f64 b 4)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1)
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b))) 1)
Outputs
(-.f64 (pow.f64 a 4) 1)
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b))) 1)
(pow.f64 a 4)
Calls

6 calls:

29.0ms
(*.f64 a a)
22.0ms
a
21.0ms
b
9.0ms
(*.f64 b b)
9.0ms
(*.f64 b b)
Results
ErrorSegmentsBranch
0.2b3a
1.5b3b
0.4b2(*.f64 a a)
0.4b2(*.f64 a a)
1.5b2(*.f64 b b)
1.5b2(*.f64 b b)
Compiler

Compiled 120 to 70 computations (41.7% saved)

bsearch47.0ms (0.5%)

Algorithm
binary-search
Steps
TimeLeftRight
23.0ms
488683.6418263618
66352664.870279334
23.0ms
-0.05870024564236305
-3.108309055367385e-11
Compiler

Compiled 24 to 16 computations (33.3% saved)

regimes126.0ms (1.4%)

Counts
13 → 3
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
(pow.f64 a 4)
(pow.f64 b 4)
(-.f64 (pow.f64 a 4) 1)
(-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1)
Outputs
(-.f64 (pow.f64 a 4) 1)
(-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1)
(pow.f64 a 4)
Calls

6 calls:

64.0ms
a
24.0ms
b
9.0ms
(*.f64 b b)
8.0ms
(*.f64 b b)
8.0ms
(*.f64 a a)
Results
ErrorSegmentsBranch
0.2b3a
1.5b3b
0.5b2(*.f64 a a)
0.5b2(*.f64 a a)
1.5b2(*.f64 b b)
1.5b2(*.f64 b b)
Compiler

Compiled 109 to 63 computations (42.2% saved)

bsearch277.0ms (3.1%)

Algorithm
binary-search
Steps
TimeLeftRight
39.0ms
488683.6418263618
66352664.870279334
238.0ms
-0.05870024564236305
-3.108309055367385e-11
Compiler

Compiled 24 to 16 computations (33.3% saved)

regimes182.0ms (2%)

Counts
12 → 3
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
(pow.f64 a 4)
(pow.f64 b 4)
(-.f64 (pow.f64 a 4) 1)
Outputs
(-.f64 (pow.f64 a 4) 1)
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(pow.f64 a 4)
Calls

5 calls:

69.0ms
b
41.0ms
(*.f64 a a)
34.0ms
a
17.0ms
(*.f64 b b)
15.0ms
(*.f64 a a)
Results
ErrorSegmentsBranch
0.3b3a
1.6b3b
0.5b2(*.f64 a a)
0.5b2(*.f64 a a)
1.6b2(*.f64 b b)
Compiler

Compiled 94 to 54 computations (42.6% saved)

bsearch50.0ms (0.6%)

Algorithm
binary-search
Steps
TimeLeftRight
25.0ms
488683.6418263618
66352664.870279334
25.0ms
-0.05870024564236305
-3.108309055367385e-11
Compiler

Compiled 24 to 16 computations (33.3% saved)

regimes137.0ms (1.5%)

Counts
11 → 3
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
(pow.f64 a 4)
(pow.f64 b 4)
Outputs
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(pow.f64 a 4)
Calls

4 calls:

98.0ms
a
18.0ms
b
8.0ms
(*.f64 b b)
8.0ms
(*.f64 a a)
Results
ErrorSegmentsBranch
0.3b3a
1.7b3b
0.6b2(*.f64 a a)
1.7b2(*.f64 b b)
Compiler

Compiled 84 to 47 computations (44% saved)

bsearch165.0ms (1.8%)

Algorithm
binary-search
Steps
TimeLeftRight
139.0ms
488683.6418263618
66352664.870279334
25.0ms
-0.05870024564236305
-3.108309055367385e-11
Compiler

Compiled 24 to 16 computations (33.3% saved)

regimes294.0ms (3.3%)

Counts
9 → 3
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
Outputs
(*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
Calls

4 calls:

185.0ms
b
53.0ms
a
36.0ms
(*.f64 a a)
15.0ms
(*.f64 b b)
Results
ErrorSegmentsBranch
0.4b3a
1.7b3b
0.6b2(*.f64 a a)
1.7b2(*.f64 b b)
Compiler

Compiled 78 to 43 computations (44.9% saved)

bsearch248.0ms (2.7%)

Algorithm
binary-search
Steps
TimeLeftRight
205.0ms
488683.6418263618
66352664.870279334
43.0ms
-0.05870024564236305
-3.108309055367385e-11
Compiler

Compiled 24 to 16 computations (33.3% saved)

regimes89.0ms (1%)

Counts
8 → 3
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
Outputs
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
Calls

4 calls:

53.0ms
a
12.0ms
(*.f64 a a)
12.0ms
b
8.0ms
(*.f64 b b)
Results
ErrorSegmentsBranch
0.8b3a
15.0b1b
1.0b2(*.f64 a a)
15.0b1(*.f64 b b)
Compiler

Compiled 67 to 38 computations (43.3% saved)

bsearch221.0ms (2.4%)

Algorithm
binary-search
Steps
TimeLeftRight
38.0ms
488683.6418263618
66352664.870279334
183.0ms
-0.9066612613203575
-0.05870024564236305
Compiler

Compiled 24 to 16 computations (33.3% saved)

regimes73.0ms (0.8%)

Counts
7 → 3
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
Outputs
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))
Calls

4 calls:

32.0ms
a
14.0ms
(*.f64 b b)
12.0ms
(*.f64 a a)
12.0ms
b
Results
ErrorSegmentsBranch
10.7b3a
24.9b1b
10.7b2(*.f64 a a)
23.8b2(*.f64 b b)
Compiler

Compiled 56 to 33 computations (41.1% saved)

bsearch88.0ms (1%)

Algorithm
binary-search
Steps
TimeLeftRight
48.0ms
488683.6418263618
66352664.870279334
39.0ms
-0.9066612613203575
-0.05870024564236305
Compiler

Compiled 24 to 16 computations (33.3% saved)

regimes40.0ms (0.4%)

Counts
6 → 1
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
Outputs
(-.f64 (*.f64 4 (*.f64 b b)) 1)
Calls

4 calls:

11.0ms
b
10.0ms
a
7.0ms
(*.f64 a a)
7.0ms
(*.f64 b b)
Results
ErrorSegmentsBranch
24.9b1a
24.9b1b
24.9b1(*.f64 a a)
24.9b1(*.f64 b b)
Compiler

Compiled 47 to 30 computations (36.2% saved)

regimes36.0ms (0.4%)

Counts
5 → 1
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
(*.f64 1 (-.f64 (*.f64 a a) 1))
Outputs
(*.f64 1 (-.f64 (*.f64 a a) 1))
Calls

4 calls:

10.0ms
a
9.0ms
b
7.0ms
(*.f64 a a)
6.0ms
(*.f64 b b)
Results
ErrorSegmentsBranch
25.4b1a
25.4b1b
25.4b1(*.f64 a a)
25.4b1(*.f64 b b)
Compiler

Compiled 40 to 26 computations (35% saved)

regimes27.0ms (0.3%)

Accuracy

Total -36.8b remaining (-141.8%)

Threshold costs -36.8b (-141.8%)

Counts
4 → 1
Calls
Call 1
Inputs
-1
(*.f64 a (neg.f64 a))
(*.f64 b (*.f64 b 4))
(*.f64 4 (*.f64 b b))
Outputs
-1
Calls

3 calls:

8.0ms
b
8.0ms
a
7.0ms
(*.f64 b b)
Results
ErrorSegmentsBranch
26.0b1a
26.0b1b
26.0b1(*.f64 b b)
Compiler

Compiled 28 to 18 computations (35.7% saved)

simplify28.0ms (0.3%)

Algorithm
egg-herbie
Rules
13×+-commutative_binary64
*-commutative_binary64
sub-neg_binary64
*-lft-identity_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
056382
180382
287382
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
(if (<=.f64 a -4229798470424045/72057594037927936) (-.f64 (pow.f64 a 4) 1) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b))) 1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (-.f64 (pow.f64 a 4) 1) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (-.f64 (pow.f64 a 4) 1) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1)) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1)) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1) (*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))))
(if (<=.f64 a -2041619659316813/2251799813685248) (*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1)) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1) (*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))))
(if (<=.f64 a -2041619659316813/2251799813685248) (*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1)) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 4 (*.f64 b b)) 1) (*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(*.f64 1 (-.f64 (*.f64 a a) 1))
-1
Outputs
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
(-.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) 1)
(+.f64 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))) -1)
(+.f64 -1 (+.f64 (pow.f64 (+.f64 (*.f64 a a) (*.f64 b b)) 2) (*.f64 4 (*.f64 b b))))
(if (<=.f64 a -4229798470424045/72057594037927936) (-.f64 (pow.f64 a 4) 1) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (+.f64 (pow.f64 b 4) (*.f64 4 (*.f64 b b))) 1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (+.f64 (pow.f64 a 4) -1) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 (+.f64 (*.f64 4 (*.f64 b b)) (pow.f64 b 4)) -1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (+.f64 -1 (pow.f64 a 4)) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 -1 (+.f64 (*.f64 4 (*.f64 b b)) (pow.f64 b 4))) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (-.f64 (pow.f64 a 4) 1) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) 1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (+.f64 (pow.f64 a 4) -1) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 (*.f64 b (*.f64 b (fma.f64 b b 4))) -1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (+.f64 -1 (pow.f64 a 4)) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 -1 (*.f64 b (*.f64 b (fma.f64 b b 4)))) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (-.f64 (pow.f64 a 4) 1) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (+.f64 (pow.f64 a 4) -1) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 (*.f64 (*.f64 b b) (+.f64 4 (*.f64 b b))) -1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (+.f64 -1 (pow.f64 a 4)) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 -1 (*.f64 (*.f64 b b) (+.f64 4 (*.f64 b b)))) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1)) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (*.f64 (+.f64 (*.f64 a a) 1) (+.f64 (*.f64 a a) -1)) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 (*.f64 (*.f64 b b) (+.f64 4 (*.f64 b b))) -1) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (*.f64 (+.f64 (*.f64 a a) 1) (+.f64 -1 (*.f64 a a))) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 -1 (*.f64 (*.f64 b b) (+.f64 4 (*.f64 b b)))) (pow.f64 a 4)))
(if (<=.f64 a -4229798470424045/72057594037927936) (*.f64 (+.f64 (*.f64 a a) 1) (-.f64 (*.f64 a a) 1)) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1) (*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))))
(if (<=.f64 a -4229798470424045/72057594037927936) (*.f64 (+.f64 (*.f64 a a) 1) (+.f64 (*.f64 a a) -1)) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 (*.f64 (*.f64 b b) (+.f64 4 (*.f64 b b))) -1) (*.f64 (*.f64 a a) (+.f64 (*.f64 a a) -1))))
(if (<=.f64 a -4229798470424045/72057594037927936) (*.f64 (+.f64 (*.f64 a a) 1) (+.f64 -1 (*.f64 a a))) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 -1 (*.f64 (*.f64 b b) (+.f64 4 (*.f64 b b)))) (*.f64 (*.f64 a a) (+.f64 -1 (*.f64 a a)))))
(if (<=.f64 a -2041619659316813/2251799813685248) (*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1)) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 (*.f64 b b) (+.f64 (*.f64 b b) 4)) 1) (*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))))
(if (<=.f64 a -2041619659316813/2251799813685248) (*.f64 (*.f64 a a) (+.f64 (*.f64 a a) -1)) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 (*.f64 (*.f64 b b) (+.f64 4 (*.f64 b b))) -1) (*.f64 (*.f64 a a) (+.f64 (*.f64 a a) -1))))
(if (<=.f64 a -2041619659316813/2251799813685248) (*.f64 (*.f64 a a) (+.f64 -1 (*.f64 a a))) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 -1 (*.f64 (*.f64 b b) (+.f64 4 (*.f64 b b)))) (*.f64 (*.f64 a a) (+.f64 -1 (*.f64 a a)))))
(if (<=.f64 a -2041619659316813/2251799813685248) (*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1)) (if (<=.f64 a 8395521038937607/17179869184) (-.f64 (*.f64 4 (*.f64 b b)) 1) (*.f64 (*.f64 a a) (-.f64 (*.f64 a a) 1))))
(if (<=.f64 a -2041619659316813/2251799813685248) (*.f64 (*.f64 a a) (+.f64 (*.f64 a a) -1)) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 (*.f64 4 (*.f64 b b)) -1) (*.f64 (*.f64 a a) (+.f64 (*.f64 a a) -1))))
(if (<=.f64 a -2041619659316813/2251799813685248) (*.f64 (*.f64 a a) (+.f64 -1 (*.f64 a a))) (if (<=.f64 a 8395521038937607/17179869184) (+.f64 -1 (*.f64 4 (*.f64 b b))) (*.f64 (*.f64 a a) (+.f64 -1 (*.f64 a a)))))
(-.f64 (*.f64 4 (*.f64 b b)) 1)
(+.f64 (*.f64 4 (*.f64 b b)) -1)
(+.f64 -1 (*.f64 4 (*.f64 b b)))
(*.f64 1 (-.f64 (*.f64 a a) 1))
(+.f64 (*.f64 a a) -1)
(+.f64 -1 (*.f64 a a))
-1
Compiler

Compiled 288 to 185 computations (35.8% saved)

soundness117.0ms (1.3%)

Algorithm
egg-herbie
Rules
776×distribute-rgt-neg-in_binary64
770×unswap-sqr_binary64
617×associate-*l*_binary64
587×fma-def_binary64
311×fma-neg_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01323
13021
26421
319721
477117
5264617
6582617
Stop Event
node limit
Compiler

Compiled 606 to 334 computations (44.9% saved)

end146.0ms (1.6%)

Compiler

Compiled 266 to 151 computations (43.2% saved)

Profiling

Loading profile data...