Details

Time bar (total: 2.1s)

analyze104.0ms (4.9%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
0%99.9%0.1%3
0%99.9%0.1%4
25%74.9%0.1%5
25%50%25.1%6
25%31.2%43.8%7
25%21.9%53.2%8
25%14%61%9
28.1%10.9%61%10
31.6%7.4%61%11
33.4%5.7%61%12
35.2%3.8%61%13
36.1%2.9%61%14
Compiler

Compiled 20 to 13 computations (35% saved)

sample1.0s (47.9%)

Results
1.0s8256×body128valid
1.0msbody128invalid
Compiler

Compiled 40 to 26 computations (35% saved)

preprocess38.0ms (1.8%)

Algorithm
egg-herbie
Rules
931×fma-def_binary64
495×fma-neg_binary64
420×associate-+l+_binary64
334×associate-+r+_binary64
241×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01846
14842
29942
328842
4113634
5373434
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 (+.f64 (*.f64 (*.f64 b b) 4) (pow.f64 (fma.f64 b b (*.f64 a a)) 2)) -1)
(+.f64 (pow.f64 (fma.f64 b b (*.f64 a a)) 2) (fma.f64 (*.f64 b b) 4 -1))
(+.f64 (fma.f64 b (*.f64 b 4) (pow.f64 (fma.f64 a a (*.f64 b b)) 2)) -1)
(+.f64 (pow.f64 (fma.f64 a a (*.f64 b b)) 2) (fma.f64 b (*.f64 b 4) -1))
(+.f64 (fma.f64 b (*.f64 b 4) (pow.f64 (hypot.f64 a 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 b b (*.f64 a a)) 2) (-.f64 (*.f64 (*.f64 4 a) a) 1))
(+.f64 (pow.f64 (fma.f64 b b (*.f64 a a)) 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))
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 a (*.f64 a 4) -1))
Compiler

Compiled 19 to 12 computations (36.8% saved)

simplify40.0ms (1.9%)

Algorithm
egg-herbie
Rules
612×fma-def_binary64
603×associate-*l*_binary64
311×fma-neg_binary64
233×associate-+l+_binary64
216×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01323
13021
26421
319321
477917
5263417
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 b) 4 -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))

prune4.0ms (0.2%)

Pruning

3 alts after pruning (3 fresh and 0 done)

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

Compiled 97 to 64 computations (34% saved)

localize7.0ms (0.3%)

Local error

Found 3 expressions with local error:

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

series21.0ms (1%)

Counts
3 → 72
Calls

18 calls:

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

rewrite53.0ms (2.5%)

Algorithm
batch-egg-rewrite
Rules
626×prod-diff_binary64
243×fma-def_binary64
181×expm1-udef_binary64
181×log1p-udef_binary64
151×log-pow_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01028
121228
2262328
Stop Event
node limit
Counts
3 → 93
Calls
Call 1
Inputs
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
(pow.f64 (hypot.f64 a b) 4)
(hypot.f64 a b)
Outputs
((#(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))) (cbrt.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 *.f64 (cbrt.f64 (pow.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)) 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 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 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 b (*.f64 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 (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 (cbrt.f64 (fma.f64 b (*.f64 b 4) -1)) (pow.f64 (cbrt.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 (pow.f64 (cbrt.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 (cbrt.f64 (pow.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)) (cbrt.f64 (pow.f64 (hypot.f64 a b) 4)) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 b) 2) (*.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 (*.f64 (cbrt.f64 (*.f64 b (*.f64 b 4))) (cbrt.f64 (*.f64 b (*.f64 b 4)))) (cbrt.f64 (*.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 (*.f64 b (*.f64 b 4))) (sqrt.f64 (*.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 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 4) (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 (pow.f64 (sqrt.f64 (hypot.f64 a b)) 4) (pow.f64 (sqrt.f64 (hypot.f64 a b)) 4) (fma.f64 b (*.f64 b 4) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 b) (*.f64 2 (sqrt.f64 b))) (*.f64 (sqrt.f64 b) (*.f64 2 (sqrt.f64 b))) (+.f64 -1 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b (cbrt.f64 (pow.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 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 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 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 -.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 (hypot.f64 a b) 2) (pow.f64 (hypot.f64 a b) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.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)) (cbrt.f64 (pow.f64 (hypot.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (hypot.f64 a b)) 2) 4) (pow.f64 (cbrt.f64 (hypot.f64 a b)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (hypot.f64 a b)) 4) (pow.f64 (sqrt.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 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 log1p.f64 (expm1.f64 (pow.f64 (hypot.f64 a b) 4)))))) (#(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 -.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) 2) 1/2)))) (#(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 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 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 log1p.f64 (expm1.f64 (hypot.f64 a b)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (hypot.f64 a b)))))))

simplify55.0ms (2.6%)

Algorithm
egg-herbie
Rules
404×times-frac_binary64
344×associate-/r*_binary64
333×fma-def_binary64
312×associate-/l*_binary64
299×associate-+r+_binary64
Iterations

Useful iterations: 2 (0.0ms)

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

prune198.0ms (9.3%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New1652167
Fresh101
Picked011
Done000
Total1663169
Error
0b
Counts
169 → 3
Alt Table
StatusErrorProgram
12.6b
(-.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)
0.0b
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
12.7b
(fma.f64 (*.f64 b b) (+.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b)) -1)
Compiler

Compiled 4068 to 2790 computations (31.4% saved)

localize11.0ms (0.5%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))
0.0b
(*.f64 4 (pow.f64 b 2))
0.0b
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
2.6b
(*.f64 (pow.f64 a 2) (pow.f64 b 2))

series8.0ms (0.4%)

Counts
4 → 9
Calls

18 calls:

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

rewrite55.0ms (2.6%)

Algorithm
batch-egg-rewrite
Rules
909×prod-diff_binary64
203×log1p-udef_binary64
123×add-sqr-sqrt_binary64
123×pow1_binary64
120×*-un-lft-identity_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01237
126135
2314135
Stop Event
node limit
Counts
4 → 81
Calls
Call 1
Inputs
(*.f64 (pow.f64 a 2) (pow.f64 b 2))
(+.f64 (pow.f64 b 4) (*.f64 4 (pow.f64 b 2)))
(*.f64 4 (pow.f64 b 2))
(*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (pow.f64 (*.f64 a b) 2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 a b) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (pow.f64 (*.f64 a b) 2) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (pow.f64 (*.f64 a b) 2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 a b) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 a b) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (*.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 (*.f64 a b) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 (*.f64 a b) 2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (*.f64 a a) 3) (pow.f64 b 6)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 b 6) (pow.f64 (*.f64 a a) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 2 (log.f64 (*.f64 a b))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (log.f64 (*.f64 a b))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 a b)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (*.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (*.f64 a b) 2)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 (*.f64 b b) 4 (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 (*.f64 b b) 4 (pow.f64 b 4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4))) (pow.f64 (cbrt.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4))) 2) (cbrt.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 (*.f64 b b) (*.f64 2 b)) (hypot.f64 (*.f64 b b) (*.f64 2 b)))))) (#(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 (*.f64 4 b) b) (pow.f64 b 4)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (hypot.f64 (*.f64 b b) (*.f64 2 b)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 b b) (*.f64 b b) (*.f64 (*.f64 4 b) b))))) (#(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 4 (*.f64 b b) (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (pow.f64 b 4) (*.f64 (*.f64 4 b) b))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (*.f64 4 b) b) (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 (*.f64 4 b) b))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 (pow.f64 b 4) 16)) (cbrt.f64 (*.f64 (*.f64 4 b) b)) (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 2 b) (*.f64 2 b) (pow.f64 b 4))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 (*.f64 b b) 4 (pow.f64 b 4))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (*.f64 4 b) b))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (*.f64 4 b) b) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (*.f64 4 b) b)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 2 b) 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 (exp.f64 (*.f64 (*.f64 4 b) b)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (*.f64 4 b) b))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 64 (pow.f64 b 6)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (*.f64 4 b) b)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (*.f64 4 b) b)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (*.f64 4 b) b)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (*.f64 4 b) b)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 2 (pow.f64 (*.f64 a b) 2)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 2 (pow.f64 (*.f64 a b) 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 2 (pow.f64 (*.f64 a b) 2)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 2 (pow.f64 (*.f64 a b) 2))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 2) (*.f64 a b)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 4 (pow.f64 (*.f64 a b) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 2) (pow.f64 (*.f64 a b) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 2 (pow.f64 (*.f64 a b) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 2 (pow.f64 (*.f64 a b) 2)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 2 (pow.f64 (*.f64 a b) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 2 (pow.f64 (*.f64 a b) 2))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 2 (pow.f64 (*.f64 a b) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 2 (pow.f64 (*.f64 a b) 2))))))))

simplify79.0ms (3.7%)

Algorithm
egg-herbie
Rules
614×sqr-pow_binary64
390×fma-def_binary64
342×unswap-sqr_binary64
288×cube-prod_binary64
243×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0881
11881
24081
39681
426481
592481
6185181
7214681
8233181
9253281
10280681
11316681
12361981
13415081
14477681
Stop Event
node limit
Counts
90 → 86
Calls
Call 1
Inputs
(*.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))
(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))
(fma.f64 b (*.f64 4 b) (pow.f64 b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(*.f64 b (fma.f64 4 b (pow.f64 b 3)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(fma.f64 b (*.f64 4 b) (pow.f64 b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(*.f64 b (fma.f64 4 b (pow.f64 b 3)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(fma.f64 b (*.f64 4 b) (pow.f64 b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(*.f64 b (fma.f64 4 b (pow.f64 b 3)))
(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))
(fma.f64 b (*.f64 4 b) (pow.f64 b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(*.f64 b (fma.f64 4 b (pow.f64 b 3)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(fma.f64 b (*.f64 4 b) (pow.f64 b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(*.f64 b (fma.f64 4 b (pow.f64 b 3)))
(+.f64 (*.f64 4 (pow.f64 b 2)) (pow.f64 b 4))
(fma.f64 4 (*.f64 b b) (pow.f64 b 4))
(fma.f64 b (*.f64 4 b) (pow.f64 b 4))
(*.f64 b (*.f64 b (fma.f64 b b 4)))
(*.f64 b (fma.f64 4 b (pow.f64 b 3)))

prune88.0ms (4.1%)

Pruning

3 alts after pruning (1 fresh and 2 done)

PrunedKeptTotal
New86086
Fresh011
Picked011
Done011
Total86389
Error
0b
Counts
89 → 3
Alt Table
StatusErrorProgram
12.6b
(-.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)
0.0b
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
12.7b
(fma.f64 (*.f64 b b) (+.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b)) -1)
Compiler

Compiled 2147 to 1627 computations (24.2% saved)

localize9.0ms (0.4%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 2 (*.f64 a a) 4)
0.1b
(fma.f64 (*.f64 b b) (+.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b)) -1)

series4.0ms (0.2%)

Counts
2 → 36
Calls

9 calls:

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

rewrite45.0ms (2.1%)

Algorithm
batch-egg-rewrite
Rules
495×prod-diff_binary64
431×log-prod_binary64
261×fma-def_binary64
184×expm1-udef_binary64
184×log1p-udef_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify36.0ms (1.7%)

Algorithm
egg-herbie
Rules
654×distribute-rgt-neg-in_binary64
486×fma-neg_binary64
327×fma-def_binary64
311×associate-*l*_binary64
309×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
023560
155500
2150470
3514470
41920470
53906470
Stop Event
node limit
Counts
88 → 70
Calls
Call 1
Inputs
-1
(-.f64 (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)) 1)
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(-.f64 (+.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 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(-.f64 (+.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 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(-.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) 1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
4
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(*.f64 2 (pow.f64 a 2))
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(*.f64 2 (pow.f64 a 2))
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
Outputs
-1
(-.f64 (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2)) 1)
(fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1)
(fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1)
(fma.f64 b (*.f64 (fma.f64 2 (*.f64 a a) 4) b) -1)
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 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)))
(+.f64 (*.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b)) (pow.f64 b 4))
(fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)))
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 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)))
(+.f64 (*.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b)) (pow.f64 b 4))
(fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) (pow.f64 b 4))
(*.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)))
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(-.f64 (+.f64 (pow.f64 b 4) (*.f64 (+.f64 4 (*.f64 2 (pow.f64 a 2))) (pow.f64 b 2))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(-.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) 1)
(fma.f64 (+.f64 4 (*.f64 b b)) (*.f64 b b) -1)
(fma.f64 (*.f64 b b) (fma.f64 b b 4) -1)
(fma.f64 b (fma.f64 4 b (pow.f64 b 3)) -1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))
(*.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)))
(*.f64 a (*.f64 (*.f64 2 a) (*.f64 b b)))
(*.f64 2 (*.f64 a (*.f64 a (*.f64 b b))))
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))
(*.f64 2 (*.f64 (*.f64 a a) (*.f64 b b)))
(*.f64 a (*.f64 (*.f64 2 a) (*.f64 b b)))
(*.f64 2 (*.f64 a (*.f64 a (*.f64 b b))))
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
(-.f64 (+.f64 (*.f64 (+.f64 4 (pow.f64 b 2)) (pow.f64 b 2)) (*.f64 2 (*.f64 (pow.f64 a 2) (pow.f64 b 2)))) 1)
(+.f64 (pow.f64 b 4) (fma.f64 (+.f64 4 (*.f64 2 (*.f64 a a))) (*.f64 b b) -1))
(+.f64 (pow.f64 b 4) (fma.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b) -1))
(fma.f64 (*.f64 b b) (fma.f64 2 (*.f64 a a) (fma.f64 b b 4)) -1)
(fma.f64 b (*.f64 b (fma.f64 2 (*.f64 a a) (fma.f64 b b 4))) -1)
4
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (*.f64 a a)))
(fma.f64 2 (*.f64 a a) 4)
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (*.f64 a a)))
(fma.f64 2 (*.f64 a a) 4)
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (*.f64 a a)))
(fma.f64 2 (*.f64 a a) 4)
(*.f64 2 (pow.f64 a 2))
(*.f64 2 (*.f64 a a))
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (*.f64 a a)))
(fma.f64 2 (*.f64 a a) 4)
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (*.f64 a a)))
(fma.f64 2 (*.f64 a a) 4)
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (*.f64 a a)))
(fma.f64 2 (*.f64 a a) 4)
(*.f64 2 (pow.f64 a 2))
(*.f64 2 (*.f64 a a))
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (*.f64 a a)))
(fma.f64 2 (*.f64 a a) 4)
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (*.f64 a a)))
(fma.f64 2 (*.f64 a a) 4)
(+.f64 4 (*.f64 2 (pow.f64 a 2)))
(+.f64 4 (*.f64 2 (*.f64 a a)))
(fma.f64 2 (*.f64 a a) 4)

prune56.0ms (2.6%)

Pruning

3 alts after pruning (0 fresh and 3 done)

PrunedKeptTotal
New70070
Fresh000
Picked011
Done022
Total70373
Error
0b
Counts
73 → 3
Alt Table
StatusErrorProgram
12.6b
(-.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)
0.0b
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
12.7b
(fma.f64 (*.f64 b b) (+.f64 (fma.f64 2 (*.f64 a a) 4) (*.f64 b b)) -1)
Compiler

Compiled 1417 to 768 computations (45.8% saved)

regimes127.0ms (5.9%)

Accuracy

Total 0.0b remaining (41.3%)

Threshold costs 0.0b (41.3%)

Counts
37 → 1
Compiler

Compiled 593 to 395 computations (33.4% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Rules
+-commutative_binary64
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01017
11217
Stop Event
saturated
Calls
Call 1
Inputs
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))
Outputs
(+.f64 (pow.f64 (hypot.f64 a b) 4) (fma.f64 b (*.f64 b 4) -1))

end69.0ms (3.3%)

Stop Event
done
Compiler

Compiled 82 to 59 computations (28% saved)

Profiling

Loading profile data...