Details

Time bar (total: 7.5s)

analyze831.0ms (11%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.8%0.2%0
0%99.8%0.2%1
0%99.8%0.2%2
0%99.8%0.2%3
0%99.8%0.2%4
0%99.8%0.2%5
0%99.8%0.2%6
0%99.8%0.2%7
0%99.8%0.2%8
6.2%93.6%0.2%9
9.4%90.4%0.2%10
10.9%81.9%7.2%11
15.6%75.4%9%12
Compiler

Compiled 14 to 9 computations (35.7% saved)

sample2.0s (26.4%)

Results
1.5s8256×body256valid
439.0ms2425×body256invalid

preprocess22.0ms (0.3%)

Algorithm
egg-herbie
Rules
156×fma-def_binary64
34×+-commutative_binary64
19×associate-+r+_binary64
19×associate-+l+_binary64
14×distribute-lft-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
03263
17363
212763
324563
435163
044
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
2
3
Outputs
0
1
2
3
Call 2
Inputs
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
(+.f64 (*.f64 (+.f64 (*.f64 y x) z) x) t)
(+.f64 (*.f64 (+.f64 (*.f64 z y) x) y) t)
(+.f64 (*.f64 (+.f64 (*.f64 t y) z) y) x)
(+.f64 (*.f64 (+.f64 (*.f64 x z) y) z) t)
(+.f64 (*.f64 (+.f64 (*.f64 x t) z) t) y)
(+.f64 (*.f64 (+.f64 (*.f64 x y) t) y) z)
Outputs
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
(fma.f64 (fma.f64 x y z) y t)
(fma.f64 y (fma.f64 x y z) t)
(+.f64 (*.f64 (+.f64 (*.f64 y x) z) x) t)
(fma.f64 (fma.f64 x y z) x t)
(fma.f64 x (fma.f64 x y z) t)
(+.f64 (*.f64 (+.f64 (*.f64 z y) x) y) t)
(fma.f64 (fma.f64 z y x) y t)
(fma.f64 y (fma.f64 y z x) t)
(+.f64 (*.f64 (+.f64 (*.f64 t y) z) y) x)
(fma.f64 (fma.f64 t y z) y x)
(fma.f64 y (fma.f64 y t z) x)
(+.f64 (*.f64 (+.f64 (*.f64 x z) y) z) t)
(fma.f64 (fma.f64 x z y) z t)
(fma.f64 z (fma.f64 x z y) t)
(+.f64 (*.f64 (+.f64 (*.f64 x t) z) t) y)
(fma.f64 (fma.f64 x t z) t y)
(fma.f64 t (fma.f64 x t z) y)
(+.f64 (*.f64 (+.f64 (*.f64 x y) t) y) z)
(fma.f64 (fma.f64 x y t) y z)
(fma.f64 y (fma.f64 x y t) z)
Compiler

Compiled 17 to 12 computations (29.4% saved)

simplify7.0ms (0.1%)

Algorithm
egg-herbie
Rules
22×fma-def_binary64
+-commutative_binary64
associate-+r+_binary64
associate-+l+_binary64
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
099
1159
2259
3549
4709
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
Outputs
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
(fma.f64 (fma.f64 x y z) y t)
(fma.f64 y (fma.f64 x y z) t)

eval1.0ms (0%)

Compiler

Compiled 20 to 10 computations (50% saved)

prune1.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
(fma.f64 y (fma.f64 x y z) t)
0.0b
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
Compiler

Compiled 24 to 14 computations (41.7% saved)

localize10.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 x y) z)
0.1b
(*.f64 (+.f64 (*.f64 x y) z) y)
Compiler

Compiled 32 to 8 computations (75% saved)

series8.0ms (0.1%)

Counts
2 → 72
Calls

18 calls:

TimeVariablePointExpression
1.0ms
z
@inf
(*.f64 (+.f64 (*.f64 x y) z) y)
1.0ms
x
@0
(*.f64 (+.f64 (*.f64 x y) z) y)
1.0ms
y
@-inf
(*.f64 (+.f64 (*.f64 x y) z) y)
1.0ms
y
@0
(*.f64 (+.f64 (*.f64 x y) z) y)
1.0ms
x
@inf
(*.f64 (+.f64 (*.f64 x y) z) y)

rewrite55.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
815×pow1_binary64
754×add-log-exp_binary64
754×log1p-expm1-u_binary64
754×expm1-log1p-u_binary64
737×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
114913
2204713
Stop Event
node limit
Counts
2 → 56
Calls
Call 1
Inputs
(*.f64 (+.f64 (*.f64 x y) z) y)
(+.f64 (*.f64 x y) z)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x y) y) (*.f64 z y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 z y) (*.f64 (*.f64 x y) y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y (*.f64 x y)) (*.f64 y z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y z) (*.f64 y (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 y (fma.f64 x y z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 z 3)) y) (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z (-.f64 z (*.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z z)) y) (-.f64 (*.f64 x y) z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 y (+.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 z 3))) (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z (-.f64 z (*.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 y (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z z))) (-.f64 (*.f64 x y) z))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (fma.f64 x y z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (fma.f64 x y z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (fma.f64 x y z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 y (fma.f64 x y z))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (fma.f64 x y z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (fma.f64 x y z)) y))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (fma.f64 x y z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 y 3) (pow.f64 (fma.f64 x y z) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 x y z) 3) (pow.f64 y 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (fma.f64 x y z))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 x y z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (*.f64 x y) 2) (-.f64 (*.f64 x y) z)) (/.f64 (*.f64 z z) (-.f64 (*.f64 x y) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x y z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x y z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x y z)) (pow.f64 (cbrt.f64 (fma.f64 x y z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x y z)) 2) (cbrt.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x y z)) (sqrt.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 z 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z (-.f64 z (*.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z z)) (/.f64 1 (-.f64 (*.f64 x y) z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z (-.f64 z (*.f64 x y)))) (+.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 z 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (*.f64 x y) z) (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 z 3)) (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z (-.f64 z (*.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 z 3)) (+.f64 (*.f64 z z) (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x (*.f64 y z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z z)) (-.f64 (*.f64 x y) z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 z 3))) (neg.f64 (+.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z (-.f64 z (*.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 z z))) (neg.f64 (-.f64 (*.f64 x y) z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 z z) (pow.f64 (*.f64 x y) 2)) (-.f64 z (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x y z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x y z) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x y z)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x y z)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x y z) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x y z) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x y z)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y x z)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x y) z)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 z (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 z) 2) (cbrt.f64 z) (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x y)) 2) (cbrt.f64 (*.f64 x y)) z)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 z) (sqrt.f64 z) (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x y)) (sqrt.f64 (*.f64 x y)) z)))))

simplify213.0ms (2.8%)

Algorithm
egg-herbie
Rules
778×sqr-pow_binary64
565×cube-prod_binary64
560×fabs-mul_binary64
541×associate-*l*_binary64
434×unswap-sqr_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
011507
123507
236426
362426
4154426
5476426
61712426
72963426
83167426
93380426
103600426
113910426
124312426
134823426
145391426
156081426
166920426
177312426
187598426
197876426
207948426
217984426
Stop Event
node limit
Counts
128 → 64
Calls
Call 1
Inputs
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
z
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
z
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
z
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
z
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) z)
Outputs
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
z
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
z
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
z
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
z
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)

localize8.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 y (fma.f64 x y z) t)
Compiler

Compiled 19 to 6 computations (68.4% saved)

series6.0ms (0.1%)

Counts
1 → 48
Calls

12 calls:

TimeVariablePointExpression
1.0ms
z
@0
(fma.f64 y (fma.f64 x y z) t)
1.0ms
x
@-inf
(fma.f64 y (fma.f64 x y z) t)
0.0ms
y
@0
(fma.f64 y (fma.f64 x y z) t)
0.0ms
x
@0
(fma.f64 y (fma.f64 x y z) t)
0.0ms
x
@inf
(fma.f64 y (fma.f64 x y z) t)

rewrite53.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
682×pow1_binary64
622×add-log-exp_binary64
622×log1p-expm1-u_binary64
622×expm1-log1p-u_binary64
606×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
079
11389
216499
Stop Event
node limit
Counts
1 → 21
Calls
Call 1
Inputs
(fma.f64 y (fma.f64 x y z) t)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 t (*.f64 y (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y (fma.f64 x y z)) t)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 y (fma.f64 x y z)) 1) t)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 y (fma.f64 x y z) t)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 y (fma.f64 x y z) t) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 y (fma.f64 x y z) t))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 y (fma.f64 x y z) t)) (pow.f64 (cbrt.f64 (fma.f64 y (fma.f64 x y z) t)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 y (fma.f64 x y z) t)) 2) (cbrt.f64 (fma.f64 y (fma.f64 x y z) t)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 y (fma.f64 x y z) t)) (sqrt.f64 (fma.f64 y (fma.f64 x y z) t)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 y (fma.f64 x y z)) 3) (pow.f64 t 3)) (+.f64 (*.f64 (*.f64 y (fma.f64 x y z)) (*.f64 y (fma.f64 x y z))) (-.f64 (*.f64 t t) (*.f64 (*.f64 y (fma.f64 x y z)) t))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 y (fma.f64 x y z)) (*.f64 y (fma.f64 x y z))) (*.f64 t t)) (-.f64 (*.f64 y (fma.f64 x y z)) t))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 y (fma.f64 x y z) t) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 y (fma.f64 x y z) t) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 y (fma.f64 x y z) t)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 y (fma.f64 x y z) t)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 y (fma.f64 x y z) t) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 y (fma.f64 x y z) t)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 y (fma.f64 x y z) t) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 y (fma.f64 x y z) t)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 y (fma.f64 x y z) t)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 y (fma.f64 x y z) t)))))))

simplify166.0ms (2.2%)

Algorithm
egg-herbie
Rules
778×sqr-pow_binary64
582×associate-*l*_binary64
540×cube-prod_binary64
534×fabs-mul_binary64
496×fma-def_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
017554
137378
263378
398378
4212378
5573378
61903378
73201378
83397378
93610378
103830378
114142378
124544378
135035378
145601378
156289378
167128378
177522378
187806378
Stop Event
node limit
Counts
69 → 35
Calls
Call 1
Inputs
t
(+.f64 (*.f64 y z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 t (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(*.f64 y z)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(*.f64 y z)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(*.f64 (+.f64 (*.f64 y x) z) y)
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
t
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
t
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
Outputs
t
(+.f64 (*.f64 y z) t)
(fma.f64 y z t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) t)
(fma.f64 y z t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 t (*.f64 (pow.f64 y 2) x))
(+.f64 t (*.f64 (*.f64 y y) x))
(fma.f64 (*.f64 y y) x t)
(fma.f64 y (*.f64 y x) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(*.f64 y z)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(*.f64 y z)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 (*.f64 y z) (+.f64 t (*.f64 (pow.f64 y 2) x)))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(*.f64 (+.f64 (*.f64 y x) z) y)
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (fma.f64 y x z))
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
t
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
t
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)
(+.f64 t (*.f64 (+.f64 (*.f64 y x) z) y))
(+.f64 (fma.f64 y z t) (*.f64 (*.f64 y y) x))
(fma.f64 y (fma.f64 y x z) t)

eval19.0ms (0.3%)

Compiler

Compiled 1247 to 428 computations (65.7% saved)

prune25.0ms (0.3%)

Pruning

9 alts after pruning (9 fresh and 0 done)

PrunedKeptTotal
New90999
Fresh000
Picked101
Done101
Total929101
Error
0b
Counts
101 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
33.9b
(+.f64 (*.f64 (pow.f64 (sqrt.f64 (fma.f64 x y z)) 2) y) t)
29.3b
t
33.9b
(*.f64 (+.f64 (*.f64 y x) z) y)
46.2b
(*.f64 y z)
0.0b
(+.f64 (+.f64 (*.f64 (*.f64 x y) y) (*.f64 z y)) t)
16.9b
(+.f64 (*.f64 (*.f64 y x) y) t)
50.2b
(*.f64 y (*.f64 y x))
12.9b
(+.f64 (*.f64 z y) t)
20.4b
(+.f64 (*.f64 (*.f64 y y) x) t)
Compiler

Compiled 181 to 118 computations (34.8% saved)

localize12.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 x y) y)
Compiler

Compiled 39 to 9 computations (76.9% saved)

series3.0ms (0%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
1.0ms
x
@0
(*.f64 (*.f64 x y) y)
1.0ms
y
@0
(*.f64 (*.f64 x y) y)
0.0ms
x
@inf
(*.f64 (*.f64 x y) y)
0.0ms
x
@-inf
(*.f64 (*.f64 x y) y)
0.0ms
y
@inf
(*.f64 (*.f64 x y) y)

rewrite46.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
471×pow1_binary64
447×add-sqr-sqrt_binary64
442×*-un-lft-identity_binary64
431×add-log-exp_binary64
431×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
057
1997
211937
Stop Event
node limit
Counts
1 → 11
Calls
Call 1
Inputs
(*.f64 (*.f64 x y) y)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (*.f64 y y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 y y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (*.f64 y y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (*.f64 y y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 x) y) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (*.f64 y y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 y) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (*.f64 y y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (*.f64 y y))))))))

simplify179.0ms (2.4%)

Algorithm
egg-herbie
Rules
1082×sqr-pow_binary64
617×cube-prod_binary64
551×fabs-mul_binary64
523×pow-sqr_binary64
445×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
06168
112168
223168
344168
4105168
5332168
61258168
72133168
82297168
92481168
102689168
112985168
123378168
133859168
144425168
155113168
165948168
176336168
186624168
196900168
206970168
217006168
227947168
Stop Event
node limit
Counts
35 → 13
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
Outputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))

localize4.0ms (0.1%)

Compiler

Compiled 9 to 5 computations (44.4% saved)

localize6.0ms (0.1%)

Compiler

Compiled 15 to 6 computations (60% saved)

localize9.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 y x) y)
Compiler

Compiled 22 to 7 computations (68.2% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
0.0ms
y
@0
(*.f64 (*.f64 y x) y)
0.0ms
y
@inf
(*.f64 (*.f64 y x) y)
0.0ms
y
@-inf
(*.f64 (*.f64 y x) y)
0.0ms
x
@inf
(*.f64 (*.f64 y x) y)
0.0ms
x
@0
(*.f64 (*.f64 y x) y)

rewrite57.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
468×pow1_binary64
444×add-sqr-sqrt_binary64
439×*-un-lft-identity_binary64
428×add-log-exp_binary64
428×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
057
1997
211827
Stop Event
node limit
Counts
1 → 11
Calls
Call 1
Inputs
(*.f64 (*.f64 y x) y)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 y (*.f64 y x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (*.f64 y x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 y (*.f64 y x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 y) (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (*.f64 y x))))))))

simplify184.0ms (2.4%)

Algorithm
egg-herbie
Rules
1082×sqr-pow_binary64
617×cube-prod_binary64
551×fabs-mul_binary64
523×pow-sqr_binary64
445×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
06168
112168
223168
344168
4105168
5332168
61258168
72133168
82297168
92481168
102689168
112985168
123378168
133859168
144425168
155113168
165948168
176336168
186624168
196900168
206970168
217006168
227947168
Stop Event
node limit
Counts
35 → 13
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
Outputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))

localize16.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(sqrt.f64 (fma.f64 x y z))
0.0b
(*.f64 (pow.f64 (sqrt.f64 (fma.f64 x y z)) 2) y)
0.2b
(pow.f64 (sqrt.f64 (fma.f64 x y z)) 2)
Compiler

Compiled 45 to 16 computations (64.4% saved)

series23.0ms (0.3%)

Counts
3 → 60
Calls

27 calls:

TimeVariablePointExpression
3.0ms
x
@0
(pow.f64 (sqrt.f64 (fma.f64 x y z)) 2)
2.0ms
x
@inf
(pow.f64 (sqrt.f64 (fma.f64 x y z)) 2)
2.0ms
y
@inf
(pow.f64 (sqrt.f64 (fma.f64 x y z)) 2)
2.0ms
z
@0
(pow.f64 (sqrt.f64 (fma.f64 x y z)) 2)
2.0ms
z
@inf
(pow.f64 (sqrt.f64 (fma.f64 x y z)) 2)

rewrite61.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
724×pow1_binary64
666×add-log-exp_binary64
666×log1p-expm1-u_binary64
666×expm1-log1p-u_binary64
649×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0920
118420
2185020
Stop Event
node limit
Counts
3 → 57
Calls
Call 1
Inputs
(pow.f64 (sqrt.f64 (fma.f64 x y z)) 2)
(*.f64 (pow.f64 (sqrt.f64 (fma.f64 x y z)) 2) y)
(sqrt.f64 (fma.f64 x y z))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 z (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x y) z)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x y) 1) z)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 x y z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x y z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x y z)) (sqrt.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x y z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x y z)) (pow.f64 (cbrt.f64 (fma.f64 x y z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x y z)) (*.f64 (cbrt.f64 (sqrt.f64 (fma.f64 x y z))) (sqrt.f64 (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x y z)) 2) (cbrt.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (fma.f64 x y z) 1/4) (*.f64 (pow.f64 (fma.f64 x y z) 1/4) (sqrt.f64 (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (fma.f64 x y z)) (pow.f64 (fma.f64 x y z) 1/4)) (pow.f64 (fma.f64 x y z) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (fma.f64 x y z)) (cbrt.f64 (fma.f64 x y z))) (cbrt.f64 (sqrt.f64 (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x y) 3) (pow.f64 z 3)) (+.f64 (*.f64 (*.f64 x y) (*.f64 x y)) (-.f64 (*.f64 z z) (*.f64 (*.f64 x y) z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 x y) (*.f64 x y)) (*.f64 z z)) (-.f64 (*.f64 x y) z))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x y z) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x y z) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x y z)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x y) y) (*.f64 z y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y (*.f64 x y)) (*.f64 y z))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 y (fma.f64 x y z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (fma.f64 x y z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (fma.f64 x y z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (fma.f64 x y z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 y (fma.f64 x y z))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (fma.f64 x y z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (fma.f64 x y z)) y))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (fma.f64 x y z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 y 3) (pow.f64 (fma.f64 x y z) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 x y z) 3) (pow.f64 y 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (fma.f64 x y z))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (sqrt.f64 (fma.f64 x y z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x y z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x y z)) (cbrt.f64 (sqrt.f64 (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (sqrt.f64 (fma.f64 x y z))) (cbrt.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (fma.f64 x y z) 1/4) (pow.f64 (fma.f64 x y z) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (fma.f64 x y z)) 2)) (sqrt.f64 (cbrt.f64 (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (sqrt.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (fma.f64 x y z)) 2) 1/2) (pow.f64 (cbrt.f64 (fma.f64 x y z)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x y z) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x y z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x y z) 3/2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (sqrt.f64 (fma.f64 x y z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x y z) 1/4) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (sqrt.f64 (fma.f64 x y z)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (sqrt.f64 (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x y z) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (sqrt.f64 (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (sqrt.f64 (fma.f64 x y z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (sqrt.f64 (fma.f64 x y z))))))))

simplify60.0ms (0.8%)

Algorithm
egg-herbie
Rules
621×fma-def_binary64
540×associate-*r*_binary64
512×associate-*l*_binary64
358×unswap-sqr_binary64
337×associate-/l/_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0113952
1342946
21160797
35487723
Stop Event
node limit
Counts
117 → 87
Calls
Call 1
Inputs
z
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) (+.f64 z (*.f64 (+.f64 (*.f64 1/4 (/.f64 (pow.f64 y 2) z)) (*.f64 -1/4 (/.f64 (pow.f64 y 2) z))) (pow.f64 x 2))))
(+.f64 (*.f64 y x) (+.f64 z (+.f64 (*.f64 (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 y 3) (pow.f64 z 2))) (*.f64 1/8 (/.f64 (pow.f64 y 3) (pow.f64 z 2)))) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 1/4 (/.f64 (pow.f64 y 2) z)) (*.f64 -1/4 (/.f64 (pow.f64 y 2) z))) (pow.f64 x 2)))))
z
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) (+.f64 (*.f64 (pow.f64 y 2) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 x 2) z)) (*.f64 -1/4 (/.f64 (pow.f64 x 2) z)))) z))
(+.f64 (*.f64 y x) (+.f64 (*.f64 (pow.f64 y 2) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 x 2) z)) (*.f64 -1/4 (/.f64 (pow.f64 x 2) z)))) (+.f64 (*.f64 (pow.f64 y 3) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 x 3) (pow.f64 z 2))) (*.f64 -1/8 (/.f64 (pow.f64 x 3) (pow.f64 z 2))))) z)))
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(+.f64 (*.f64 y x) (+.f64 (*.f64 (+.f64 (*.f64 1/64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (+.f64 (*.f64 -1 (+.f64 (*.f64 1/16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (pow.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) 2))) (*.f64 1/16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))))) (pow.f64 z 4)) z))
(+.f64 (*.f64 y x) (+.f64 (*.f64 (+.f64 (*.f64 1/64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (+.f64 (*.f64 -1 (+.f64 (*.f64 1/16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (pow.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) 2))) (*.f64 1/16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))))) (pow.f64 z 4)) z))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(sqrt.f64 z)
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z))
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (+.f64 (sqrt.f64 z) (*.f64 -1/8 (*.f64 (*.f64 (pow.f64 y 2) (pow.f64 x 2)) (sqrt.f64 (/.f64 1 (pow.f64 z 3)))))))
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (+.f64 (sqrt.f64 z) (+.f64 (*.f64 1/16 (*.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (sqrt.f64 (/.f64 1 (pow.f64 z 5))))) (*.f64 -1/8 (*.f64 (*.f64 (pow.f64 y 2) (pow.f64 x 2)) (sqrt.f64 (/.f64 1 (pow.f64 z 3))))))))
(sqrt.f64 z)
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z))
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (+.f64 (sqrt.f64 z) (*.f64 -1/8 (*.f64 (*.f64 (pow.f64 y 2) (pow.f64 x 2)) (sqrt.f64 (/.f64 1 (pow.f64 z 3)))))))
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (+.f64 (sqrt.f64 z) (+.f64 (*.f64 1/16 (*.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (sqrt.f64 (/.f64 1 (pow.f64 z 5))))) (*.f64 -1/8 (*.f64 (*.f64 (pow.f64 y 2) (pow.f64 x 2)) (sqrt.f64 (/.f64 1 (pow.f64 z 3))))))))
(sqrt.f64 (*.f64 y x))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 y x))) z)) (sqrt.f64 (*.f64 y x)))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 y x))) z)) (+.f64 (*.f64 -1/8 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (pow.f64 z 2))) (sqrt.f64 (*.f64 y x))))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 y x))) z)) (+.f64 (*.f64 1/16 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 5) (pow.f64 x 5)))) (pow.f64 z 3))) (+.f64 (*.f64 -1/8 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (pow.f64 z 2))) (sqrt.f64 (*.f64 y x)))))
Outputs
z
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) (+.f64 z (*.f64 (+.f64 (*.f64 1/4 (/.f64 (pow.f64 y 2) z)) (*.f64 -1/4 (/.f64 (pow.f64 y 2) z))) (pow.f64 x 2))))
(fma.f64 y x z)
(+.f64 (*.f64 y x) (+.f64 z (+.f64 (*.f64 (+.f64 (*.f64 -1/8 (/.f64 (pow.f64 y 3) (pow.f64 z 2))) (*.f64 1/8 (/.f64 (pow.f64 y 3) (pow.f64 z 2)))) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 1/4 (/.f64 (pow.f64 y 2) z)) (*.f64 -1/4 (/.f64 (pow.f64 y 2) z))) (pow.f64 x 2)))))
(fma.f64 y x z)
z
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) (+.f64 (*.f64 (pow.f64 y 2) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 x 2) z)) (*.f64 -1/4 (/.f64 (pow.f64 x 2) z)))) z))
(fma.f64 y x z)
(+.f64 (*.f64 y x) (+.f64 (*.f64 (pow.f64 y 2) (+.f64 (*.f64 1/4 (/.f64 (pow.f64 x 2) z)) (*.f64 -1/4 (/.f64 (pow.f64 x 2) z)))) (+.f64 (*.f64 (pow.f64 y 3) (+.f64 (*.f64 1/8 (/.f64 (pow.f64 x 3) (pow.f64 z 2))) (*.f64 -1/8 (/.f64 (pow.f64 x 3) (pow.f64 z 2))))) z)))
(fma.f64 y x z)
(*.f64 y x)
(+.f64 (*.f64 y x) z)
(fma.f64 y x z)
(+.f64 (*.f64 y x) (+.f64 (*.f64 (+.f64 (*.f64 1/64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (+.f64 (*.f64 -1 (+.f64 (*.f64 1/16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (pow.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) 2))) (*.f64 1/16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))))) (pow.f64 z 4)) z))
(fma.f64 y x (fma.f64 (+.f64 (/.f64 1/64 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) (fma.f64 -1 (+.f64 (/.f64 1/16 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) (pow.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 (/.f64 1 (pow.f64 y 3)) (pow.f64 x 3)))) 2)) (/.f64 1/16 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) (pow.f64 z 4) z))
(fma.f64 y x (fma.f64 (+.f64 (/.f64 1/64 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) (-.f64 (/.f64 1/16 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) (+.f64 (/.f64 1/16 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) (pow.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) 2)))) (pow.f64 z 4) z))
(fma.f64 y x (fma.f64 (-.f64 (*.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) 5/64) (*.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) 5/64)) (pow.f64 z 4) z))
(fma.f64 y x (fma.f64 0 (pow.f64 z 4) z))
(+.f64 (*.f64 y x) (+.f64 (*.f64 (+.f64 (*.f64 1/64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (+.f64 (*.f64 -1 (+.f64 (*.f64 1/16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (pow.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) 2))) (*.f64 1/16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))))) (pow.f64 z 4)) z))
(fma.f64 y x (fma.f64 (+.f64 (/.f64 1/64 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) (fma.f64 -1 (+.f64 (/.f64 1/16 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) (pow.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 (/.f64 1 (pow.f64 y 3)) (pow.f64 x 3)))) 2)) (/.f64 1/16 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) (pow.f64 z 4) z))
(fma.f64 y x (fma.f64 (+.f64 (/.f64 1/64 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) (-.f64 (/.f64 1/16 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) (+.f64 (/.f64 1/16 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) (pow.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) 2)))) (pow.f64 z 4) z))
(fma.f64 y x (fma.f64 (-.f64 (*.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) 5/64) (*.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))) 5/64)) (pow.f64 z 4) z))
(fma.f64 y x (fma.f64 0 (pow.f64 z 4) z))
(*.f64 y z)
(*.f64 z y)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(*.f64 y z)
(*.f64 z y)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(*.f64 y z)
(*.f64 z y)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(*.f64 y z)
(*.f64 z y)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 x (*.f64 y y)))
(fma.f64 x (*.f64 y y) (*.f64 z y))
(*.f64 y (fma.f64 y x z))
(sqrt.f64 z)
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z))
(fma.f64 1/2 (*.f64 y (*.f64 x (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z))
(fma.f64 y (*.f64 x (*.f64 1/2 (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z))
(fma.f64 y (*.f64 1/2 (*.f64 x (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z))
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (+.f64 (sqrt.f64 z) (*.f64 -1/8 (*.f64 (*.f64 (pow.f64 y 2) (pow.f64 x 2)) (sqrt.f64 (/.f64 1 (pow.f64 z 3)))))))
(+.f64 (fma.f64 1/2 (*.f64 y (*.f64 x (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z)) (*.f64 (*.f64 -1/8 (*.f64 (*.f64 y y) (*.f64 x x))) (sqrt.f64 (/.f64 1 (pow.f64 z 3)))))
(fma.f64 1/2 (*.f64 y (*.f64 x (sqrt.f64 (/.f64 1 z)))) (fma.f64 -1/8 (*.f64 y (*.f64 y (*.f64 (*.f64 x x) (sqrt.f64 (/.f64 1 (pow.f64 z 3)))))) (sqrt.f64 z)))
(fma.f64 y (*.f64 x (*.f64 1/2 (sqrt.f64 (/.f64 1 z)))) (fma.f64 (*.f64 y y) (*.f64 (*.f64 x x) (*.f64 -1/8 (sqrt.f64 (/.f64 1 (pow.f64 z 3))))) (sqrt.f64 z)))
(+.f64 (sqrt.f64 z) (*.f64 (*.f64 y x) (+.f64 (*.f64 1/2 (sqrt.f64 (/.f64 1 z))) (*.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 1 (pow.f64 z 3)))) (*.f64 y x)))))
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (+.f64 (sqrt.f64 z) (+.f64 (*.f64 1/16 (*.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (sqrt.f64 (/.f64 1 (pow.f64 z 5))))) (*.f64 -1/8 (*.f64 (*.f64 (pow.f64 y 2) (pow.f64 x 2)) (sqrt.f64 (/.f64 1 (pow.f64 z 3))))))))
(+.f64 (fma.f64 1/2 (*.f64 y (*.f64 x (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z)) (fma.f64 1/16 (*.f64 (pow.f64 y 3) (*.f64 (pow.f64 x 3) (sqrt.f64 (/.f64 1 (pow.f64 z 5))))) (*.f64 (*.f64 -1/8 (*.f64 (*.f64 y y) (*.f64 x x))) (sqrt.f64 (/.f64 1 (pow.f64 z 3))))))
(+.f64 (fma.f64 1/2 (*.f64 y (*.f64 x (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z)) (fma.f64 -1/8 (*.f64 y (*.f64 y (*.f64 (*.f64 x x) (sqrt.f64 (/.f64 1 (pow.f64 z 3)))))) (*.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 z 5))) 1/16))))
(fma.f64 y (*.f64 x (*.f64 1/2 (sqrt.f64 (/.f64 1 z)))) (fma.f64 (*.f64 y y) (*.f64 (*.f64 x x) (*.f64 -1/8 (sqrt.f64 (/.f64 1 (pow.f64 z 3))))) (fma.f64 (pow.f64 y 3) (*.f64 (pow.f64 x 3) (*.f64 1/16 (sqrt.f64 (/.f64 1 (pow.f64 z 5))))) (sqrt.f64 z))))
(+.f64 (fma.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (*.f64 1/16 (sqrt.f64 (/.f64 1 (pow.f64 z 5)))) (sqrt.f64 z)) (*.f64 (*.f64 y x) (+.f64 (*.f64 1/2 (sqrt.f64 (/.f64 1 z))) (*.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 1 (pow.f64 z 3)))) (*.f64 y x)))))
(sqrt.f64 z)
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z))
(fma.f64 1/2 (*.f64 y (*.f64 x (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z))
(fma.f64 y (*.f64 x (*.f64 1/2 (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z))
(fma.f64 y (*.f64 1/2 (*.f64 x (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z))
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (+.f64 (sqrt.f64 z) (*.f64 -1/8 (*.f64 (*.f64 (pow.f64 y 2) (pow.f64 x 2)) (sqrt.f64 (/.f64 1 (pow.f64 z 3)))))))
(+.f64 (fma.f64 1/2 (*.f64 y (*.f64 x (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z)) (*.f64 (*.f64 -1/8 (*.f64 (*.f64 y y) (*.f64 x x))) (sqrt.f64 (/.f64 1 (pow.f64 z 3)))))
(fma.f64 1/2 (*.f64 y (*.f64 x (sqrt.f64 (/.f64 1 z)))) (fma.f64 -1/8 (*.f64 y (*.f64 y (*.f64 (*.f64 x x) (sqrt.f64 (/.f64 1 (pow.f64 z 3)))))) (sqrt.f64 z)))
(fma.f64 y (*.f64 x (*.f64 1/2 (sqrt.f64 (/.f64 1 z)))) (fma.f64 (*.f64 y y) (*.f64 (*.f64 x x) (*.f64 -1/8 (sqrt.f64 (/.f64 1 (pow.f64 z 3))))) (sqrt.f64 z)))
(+.f64 (sqrt.f64 z) (*.f64 (*.f64 y x) (+.f64 (*.f64 1/2 (sqrt.f64 (/.f64 1 z))) (*.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 1 (pow.f64 z 3)))) (*.f64 y x)))))
(+.f64 (*.f64 1/2 (*.f64 (*.f64 y x) (sqrt.f64 (/.f64 1 z)))) (+.f64 (sqrt.f64 z) (+.f64 (*.f64 1/16 (*.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (sqrt.f64 (/.f64 1 (pow.f64 z 5))))) (*.f64 -1/8 (*.f64 (*.f64 (pow.f64 y 2) (pow.f64 x 2)) (sqrt.f64 (/.f64 1 (pow.f64 z 3))))))))
(+.f64 (fma.f64 1/2 (*.f64 y (*.f64 x (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z)) (fma.f64 1/16 (*.f64 (pow.f64 y 3) (*.f64 (pow.f64 x 3) (sqrt.f64 (/.f64 1 (pow.f64 z 5))))) (*.f64 (*.f64 -1/8 (*.f64 (*.f64 y y) (*.f64 x x))) (sqrt.f64 (/.f64 1 (pow.f64 z 3))))))
(+.f64 (fma.f64 1/2 (*.f64 y (*.f64 x (sqrt.f64 (/.f64 1 z)))) (sqrt.f64 z)) (fma.f64 -1/8 (*.f64 y (*.f64 y (*.f64 (*.f64 x x) (sqrt.f64 (/.f64 1 (pow.f64 z 3)))))) (*.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (*.f64 (sqrt.f64 (/.f64 1 (pow.f64 z 5))) 1/16))))
(fma.f64 y (*.f64 x (*.f64 1/2 (sqrt.f64 (/.f64 1 z)))) (fma.f64 (*.f64 y y) (*.f64 (*.f64 x x) (*.f64 -1/8 (sqrt.f64 (/.f64 1 (pow.f64 z 3))))) (fma.f64 (pow.f64 y 3) (*.f64 (pow.f64 x 3) (*.f64 1/16 (sqrt.f64 (/.f64 1 (pow.f64 z 5))))) (sqrt.f64 z))))
(+.f64 (fma.f64 (*.f64 (pow.f64 y 3) (pow.f64 x 3)) (*.f64 1/16 (sqrt.f64 (/.f64 1 (pow.f64 z 5)))) (sqrt.f64 z)) (*.f64 (*.f64 y x) (+.f64 (*.f64 1/2 (sqrt.f64 (/.f64 1 z))) (*.f64 (*.f64 -1/8 (sqrt.f64 (/.f64 1 (pow.f64 z 3)))) (*.f64 y x)))))
(sqrt.f64 (*.f64 y x))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 y x))) z)) (sqrt.f64 (*.f64 y x)))
(fma.f64 1/2 (*.f64 z (sqrt.f64 (/.f64 1 (*.f64 y x)))) (sqrt.f64 (*.f64 y x)))
(fma.f64 1/2 (*.f64 z (sqrt.f64 (/.f64 (/.f64 1 y) x))) (sqrt.f64 (*.f64 y x)))
(fma.f64 z (*.f64 1/2 (sqrt.f64 (/.f64 1 (*.f64 y x)))) (sqrt.f64 (*.f64 y x)))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 y x))) z)) (+.f64 (*.f64 -1/8 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (pow.f64 z 2))) (sqrt.f64 (*.f64 y x))))
(fma.f64 1/2 (*.f64 z (sqrt.f64 (/.f64 1 (*.f64 y x)))) (fma.f64 -1/8 (*.f64 (*.f64 z z) (sqrt.f64 (/.f64 (/.f64 1 (pow.f64 y 3)) (pow.f64 x 3)))) (sqrt.f64 (*.f64 y x))))
(fma.f64 1/2 (*.f64 z (sqrt.f64 (/.f64 (/.f64 1 y) x))) (fma.f64 -1/8 (*.f64 (*.f64 z z) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) (sqrt.f64 (*.f64 y x))))
(fma.f64 z (*.f64 1/2 (sqrt.f64 (/.f64 1 (*.f64 y x)))) (fma.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (*.f64 z (*.f64 z -1/8)) (sqrt.f64 (*.f64 y x))))
(fma.f64 z (*.f64 1/2 (sqrt.f64 (/.f64 1 (*.f64 y x)))) (fma.f64 (sqrt.f64 (/.f64 (/.f64 1 (pow.f64 y 3)) (pow.f64 x 3))) (*.f64 z (*.f64 z -1/8)) (sqrt.f64 (*.f64 y x))))
(+.f64 (*.f64 1/2 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 y x))) z)) (+.f64 (*.f64 1/16 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 5) (pow.f64 x 5)))) (pow.f64 z 3))) (+.f64 (*.f64 -1/8 (*.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))) (pow.f64 z 2))) (sqrt.f64 (*.f64 y x)))))
(fma.f64 1/2 (*.f64 z (sqrt.f64 (/.f64 1 (*.f64 y x)))) (fma.f64 1/16 (*.f64 (pow.f64 z 3) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 5) (pow.f64 x 5))))) (fma.f64 -1/8 (*.f64 (*.f64 z z) (sqrt.f64 (/.f64 (/.f64 1 (pow.f64 y 3)) (pow.f64 x 3)))) (sqrt.f64 (*.f64 y x)))))
(fma.f64 1/2 (*.f64 z (sqrt.f64 (/.f64 (/.f64 1 y) x))) (fma.f64 1/16 (*.f64 (pow.f64 z 3) (sqrt.f64 (/.f64 (/.f64 1 (pow.f64 y 5)) (pow.f64 x 5)))) (fma.f64 -1/8 (*.f64 (*.f64 z z) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) (sqrt.f64 (*.f64 y x)))))
(fma.f64 z (*.f64 1/2 (sqrt.f64 (/.f64 1 (*.f64 y x)))) (fma.f64 -1/8 (*.f64 (*.f64 z z) (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 3))))) (fma.f64 (sqrt.f64 (/.f64 1 (*.f64 (pow.f64 y 5) (pow.f64 x 5)))) (*.f64 1/16 (pow.f64 z 3)) (sqrt.f64 (*.f64 y x)))))
(fma.f64 z (*.f64 1/2 (sqrt.f64 (/.f64 1 (*.f64 y x)))) (fma.f64 -1/8 (*.f64 z (*.f64 z (sqrt.f64 (/.f64 (/.f64 1 (pow.f64 y 3)) (pow.f64 x 3))))) (fma.f64 (sqrt.f64 (/.f64 (/.f64 1 (pow.f64 y 5)) (pow.f64 x 5))) (*.f64 1/16 (pow.f64 z 3)) (sqrt.f64 (*.f64 y x)))))

eval33.0ms (0.4%)

Compiler

Compiled 1844 to 909 computations (50.7% saved)

prune58.0ms (0.8%)

Pruning

9 alts after pruning (5 fresh and 4 done)

PrunedKeptTotal
New1121113
Fresh044
Picked101
Done044
Total1139122
Error
0b
Counts
122 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
50.2b
(*.f64 y (*.f64 y x))
37.2b
(+.f64 (*.f64 (pow.f64 (sqrt.f64 (*.f64 y x)) 2) y) t)
29.3b
t
33.9b
(*.f64 (+.f64 (*.f64 y x) z) y)
46.2b
(*.f64 y z)
0.0b
(+.f64 (+.f64 (*.f64 (*.f64 x y) y) (*.f64 z y)) t)
16.9b
(+.f64 (*.f64 (*.f64 y x) y) t)
12.9b
(+.f64 (*.f64 z y) t)
20.4b
(+.f64 (*.f64 (*.f64 y y) x) t)
Compiler

Compiled 92 to 61 computations (33.7% saved)

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 y (*.f64 y x))
Compiler

Compiled 14 to 6 computations (57.1% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
0.0ms
y
@0
(*.f64 y (*.f64 y x))
0.0ms
y
@-inf
(*.f64 y (*.f64 y x))
0.0ms
y
@inf
(*.f64 y (*.f64 y x))
0.0ms
x
@-inf
(*.f64 y (*.f64 y x))
0.0ms
x
@inf
(*.f64 y (*.f64 y x))

rewrite112.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
471×pow1_binary64
447×add-sqr-sqrt_binary64
442×*-un-lft-identity_binary64
431×add-log-exp_binary64
431×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
057
1997
211947
Stop Event
node limit
Counts
1 → 11
Calls
Call 1
Inputs
(*.f64 y (*.f64 y x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 y (*.f64 y x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (*.f64 y x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (sqrt.f64 x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 y) (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (*.f64 y x))))))))

simplify182.0ms (2.4%)

Algorithm
egg-herbie
Rules
1082×sqr-pow_binary64
617×cube-prod_binary64
551×fabs-mul_binary64
523×pow-sqr_binary64
445×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
06168
112168
223168
344168
4105168
5332168
61258168
72133168
82297168
92481168
102689168
112985168
123378168
133859168
144425168
155113168
165948168
176336168
186624168
196900168
206970168
217006168
227947168
Stop Event
node limit
Counts
35 → 13
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
Outputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))

localize8.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 y x) z)
0.1b
(*.f64 (+.f64 (*.f64 y x) z) y)
Compiler

Compiled 22 to 7 computations (68.2% saved)

series5.0ms (0.1%)

Counts
2 → 45
Calls

18 calls:

TimeVariablePointExpression
0.0ms
y
@0
(*.f64 (+.f64 (*.f64 y x) z) y)
0.0ms
y
@inf
(*.f64 (+.f64 (*.f64 y x) z) y)
0.0ms
z
@-inf
(+.f64 (*.f64 y x) z)
0.0ms
x
@inf
(*.f64 (+.f64 (*.f64 y x) z) y)
0.0ms
y
@-inf
(*.f64 (+.f64 (*.f64 y x) z) y)

rewrite70.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
815×pow1_binary64
754×add-log-exp_binary64
754×log1p-expm1-u_binary64
754×expm1-log1p-u_binary64
737×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
114913
2204713
Stop Event
node limit
Counts
2 → 56
Calls
Call 1
Inputs
(*.f64 (+.f64 (*.f64 y x) z) y)
(+.f64 (*.f64 y x) z)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 y x) y) (*.f64 z y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 z y) (*.f64 (*.f64 y x) y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y (*.f64 y x)) (*.f64 y z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y z) (*.f64 y (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 y (fma.f64 y x z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 3)) y) (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z (-.f64 z (*.f64 y x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z z)) y) (-.f64 (*.f64 y x) z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 y (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 3))) (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z (-.f64 z (*.f64 y x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 y (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z z))) (-.f64 (*.f64 y x) z))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (fma.f64 y x z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (fma.f64 y x z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (fma.f64 y x z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 y (fma.f64 y x z))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (fma.f64 y x z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (fma.f64 y x z)) y))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (fma.f64 y x z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 y 3) (pow.f64 (fma.f64 y x z) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 y x z) 3) (pow.f64 y 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (fma.f64 y x z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (fma.f64 y x z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (fma.f64 y x z))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 y x z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (*.f64 y x) 2) (-.f64 (*.f64 y x) z)) (/.f64 (*.f64 z z) (-.f64 (*.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 y x z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 y x z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 y x z)) (pow.f64 (cbrt.f64 (fma.f64 y x z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 y x z)) 2) (cbrt.f64 (fma.f64 y x z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 y x z)) (sqrt.f64 (fma.f64 y x z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z (-.f64 z (*.f64 y x))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z z)) (/.f64 1 (-.f64 (*.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z (-.f64 z (*.f64 y x)))) (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (*.f64 y x) z) (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 3)) (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z (-.f64 z (*.f64 y x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 3)) (+.f64 (*.f64 z z) (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 y (*.f64 x z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z z)) (-.f64 (*.f64 y x) z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 3))) (neg.f64 (+.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z (-.f64 z (*.f64 y x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 z z))) (neg.f64 (-.f64 (*.f64 y x) z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 z z) (pow.f64 (*.f64 y x) 2)) (-.f64 z (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 y x z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 y x z) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 y x z)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 y x z)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 y x z) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 y x z)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 y x z) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 y x z)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 y x z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 y x z)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y x z)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x y z)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 y x) z)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 z (*.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 z) 2) (cbrt.f64 z) (*.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) (cbrt.f64 (*.f64 y x)) z)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 z) (sqrt.f64 z) (*.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 (*.f64 y x)) z)))))

simplify233.0ms (3.1%)

Algorithm
egg-herbie
Rules
778×sqr-pow_binary64
561×cube-prod_binary64
556×fabs-mul_binary64
536×associate-*l*_binary64
434×unswap-sqr_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
010372
120372
232345
361291
4158291
5471291
61726291
72978291
83182291
93395291
103615291
113924291
124324291
134835291
145403291
156091291
166926291
177320291
187610291
197886291
207960291
217996291
Stop Event
node limit
Counts
101 → 63
Calls
Call 1
Inputs
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
z
(*.f64 y x)
(*.f64 y x)
z
(*.f64 y x)
(*.f64 y x)
(*.f64 y x)
z
z
Outputs
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(*.f64 y z)
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
(+.f64 (*.f64 y z) (*.f64 (pow.f64 y 2) x))
(fma.f64 y z (*.f64 (*.f64 y y) x))
(*.f64 y (+.f64 z (*.f64 y x)))
(*.f64 y (fma.f64 y x z))
z
(*.f64 y x)
(*.f64 y x)
z
(*.f64 y x)
(*.f64 y x)
(*.f64 y x)
z
z

localize8.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
10.1b
(*.f64 (*.f64 y y) x)
Compiler

Compiled 22 to 7 computations (68.2% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
0.0ms
y
@0
(*.f64 (*.f64 y y) x)
0.0ms
y
@inf
(*.f64 (*.f64 y y) x)
0.0ms
y
@-inf
(*.f64 (*.f64 y y) x)
0.0ms
x
@-inf
(*.f64 (*.f64 y y) x)
0.0ms
x
@inf
(*.f64 (*.f64 y y) x)

rewrite66.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
457×pow1_binary64
434×add-sqr-sqrt_binary64
428×*-un-lft-identity_binary64
420×add-log-exp_binary64
420×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
057
11007
212057
Stop Event
node limit
Counts
1 → 11
Calls
Call 1
Inputs
(*.f64 (*.f64 y y) x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 y (*.f64 y x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (*.f64 y x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (sqrt.f64 x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 y 4) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (*.f64 y y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (*.f64 y x))))))))

simplify181.0ms (2.4%)

Algorithm
egg-herbie
Rules
1082×sqr-pow_binary64
617×cube-prod_binary64
551×fabs-mul_binary64
523×pow-sqr_binary64
445×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
06168
112168
223168
344168
4105168
5332168
61258168
72133168
82297168
92481168
102689168
112985168
123378168
133859168
144425168
155113168
165948168
176336168
186624168
196900168
206970168
217006168
227947168
Stop Event
node limit
Counts
35 → 13
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
Outputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))

localize15.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 y x)) 2) y)
0.2b
(pow.f64 (sqrt.f64 (*.f64 y x)) 2)
11.1b
(sqrt.f64 (*.f64 y x))
Compiler

Compiled 39 to 16 computations (59% saved)

series23.0ms (0.3%)

Counts
3 → 24
Calls

18 calls:

TimeVariablePointExpression
4.0ms
y
@inf
(sqrt.f64 (*.f64 y x))
3.0ms
y
@-inf
(pow.f64 (sqrt.f64 (*.f64 y x)) 2)
3.0ms
x
@-inf
(*.f64 (pow.f64 (sqrt.f64 (*.f64 y x)) 2) y)
2.0ms
x
@-inf
(sqrt.f64 (*.f64 y x))
1.0ms
y
@-inf
(*.f64 (pow.f64 (sqrt.f64 (*.f64 y x)) 2) y)

rewrite105.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
616×pow1_binary64
568×add-log-exp_binary64
568×log1p-expm1-u_binary64
568×expm1-log1p-u_binary64
554×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0817
116517
2162317
Stop Event
node limit
Counts
3 → 61
Calls
Call 1
Inputs
(sqrt.f64 (*.f64 y x))
(pow.f64 (sqrt.f64 (*.f64 y x)) 2)
(*.f64 (pow.f64 (sqrt.f64 (*.f64 y x)) 2) y)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (sqrt.f64 (*.f64 y x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 y x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (sqrt.f64 (*.f64 y x))) (cbrt.f64 (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 y x)) (cbrt.f64 (sqrt.f64 (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 y x) 1/4) (pow.f64 (*.f64 y x) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 y) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (sqrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2)) (sqrt.f64 (cbrt.f64 (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (sqrt.f64 (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) 1/2) (pow.f64 (cbrt.f64 (*.f64 y x)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y x) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 y x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y x) 3/2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (sqrt.f64 (*.f64 y x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y x) 1/4) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (sqrt.f64 (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (sqrt.f64 (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y x) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (sqrt.f64 (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (sqrt.f64 (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (sqrt.f64 (*.f64 y x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 y x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 y x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x y)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 y x)) (pow.f64 (cbrt.f64 (*.f64 y x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 y x)) (*.f64 (cbrt.f64 (sqrt.f64 (*.f64 y x))) (sqrt.f64 (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) (cbrt.f64 (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 y (*.f64 y x))) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 y x) 1/4) (*.f64 (pow.f64 (*.f64 y x) 1/4) (sqrt.f64 (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 x) (sqrt.f64 (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 y x)) (pow.f64 (*.f64 y x) 1/4)) (pow.f64 (*.f64 y x) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (sqrt.f64 y)) (sqrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 y x)) (cbrt.f64 (*.f64 y x))) (cbrt.f64 (sqrt.f64 (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 y) x))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y x)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 y (*.f64 y x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (*.f64 y x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 y (*.f64 y x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 y) (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (*.f64 y x))))))))

simplify85.0ms (1.1%)

Algorithm
egg-herbie
Rules
1282×fma-def_binary64
358×fma-neg_binary64
347×distribute-rgt-neg-in_binary64
321×neg-sub0_binary64
311×distribute-lft-neg-out_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
011168
127168
284168
3275168
41373168
53438168
65133168
76563168
87082168
Stop Event
node limit
Counts
85 → 64
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
Outputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))

eval34.0ms (0.5%)

Compiler

Compiled 1742 to 676 computations (61.2% saved)

prune30.0ms (0.4%)

Pruning

10 alts after pruning (3 fresh and 7 done)

PrunedKeptTotal
New1512153
Fresh011
Picked011
Done167
Total15210162
Error
0b
Counts
162 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
33.9b
(+.f64 (*.f64 (*.f64 y x) y) (*.f64 z y))
37.2b
(+.f64 (*.f64 (pow.f64 (sqrt.f64 (*.f64 y x)) 2) y) t)
50.2b
(*.f64 y (*.f64 y x))
29.3b
t
53.4b
(*.f64 (*.f64 y y) x)
33.9b
(*.f64 (+.f64 (*.f64 y x) z) y)
46.2b
(*.f64 y z)
16.9b
(+.f64 (*.f64 (*.f64 y x) y) t)
12.9b
(+.f64 (*.f64 z y) t)
20.4b
(+.f64 (*.f64 (*.f64 y y) x) t)
Compiler

Compiled 99 to 66 computations (33.3% saved)

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
10.1b
(*.f64 (*.f64 y y) x)
Compiler

Compiled 14 to 6 computations (57.1% saved)

localize11.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 y x) y)
Compiler

Compiled 27 to 8 computations (70.4% saved)

eval5.0ms (0.1%)

Compiler

Compiled 244 to 85 computations (65.2% saved)

prune16.0ms (0.2%)

Pruning

10 alts after pruning (1 fresh and 9 done)

PrunedKeptTotal
New26026
Fresh011
Picked011
Done088
Total261036
Error
0b
Counts
36 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
33.9b
(+.f64 (*.f64 (*.f64 y x) y) (*.f64 z y))
37.2b
(+.f64 (*.f64 (pow.f64 (sqrt.f64 (*.f64 y x)) 2) y) t)
50.2b
(*.f64 y (*.f64 y x))
29.3b
t
53.4b
(*.f64 (*.f64 y y) x)
33.9b
(*.f64 (+.f64 (*.f64 y x) z) y)
46.2b
(*.f64 y z)
16.9b
(+.f64 (*.f64 (*.f64 y x) y) t)
12.9b
(+.f64 (*.f64 z y) t)
20.4b
(+.f64 (*.f64 (*.f64 y y) x) t)
Compiler

Compiled 99 to 66 computations (33.3% saved)

regimes116.0ms (1.5%)

Counts
14 → 1
Calls
Call 1
Inputs
t
(*.f64 y z)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 z y) t)
(*.f64 (+.f64 (*.f64 y x) z) y)
(+.f64 (*.f64 (*.f64 y x) y) t)
(+.f64 (*.f64 (*.f64 y y) x) t)
(+.f64 (*.f64 (*.f64 y x) y) (*.f64 z y))
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
(+.f64 (+.f64 (*.f64 (*.f64 x y) y) (*.f64 z y)) t)
(fma.f64 y (fma.f64 x y z) t)
(+.f64 (*.f64 (pow.f64 (sqrt.f64 (*.f64 y x)) 2) y) t)
(+.f64 (*.f64 (pow.f64 (sqrt.f64 (fma.f64 x y z)) 2) y) t)
Outputs
(+.f64 (+.f64 (*.f64 (*.f64 x y) y) (*.f64 z y)) t)
Calls

7 calls:

18.0ms
t
16.0ms
z
16.0ms
y
16.0ms
x
16.0ms
(*.f64 (+.f64 (*.f64 x y) z) y)
Results
ErrorSegmentsBranch
0.0b1x
0.0b1y
0.0b1z
0.0b1t
0.0b1(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
0.0b1(*.f64 (+.f64 (*.f64 x y) z) y)
0.0b1(*.f64 (+.f64 (*.f64 x y) z) y)
Compiler

Compiled 156 to 74 computations (52.6% saved)

regimes89.0ms (1.2%)

Counts
10 → 1
Calls
Call 1
Inputs
t
(*.f64 y z)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 z y) t)
(*.f64 (+.f64 (*.f64 y x) z) y)
(+.f64 (*.f64 (*.f64 y x) y) t)
(+.f64 (*.f64 (*.f64 y y) x) t)
(+.f64 (*.f64 (*.f64 y x) y) (*.f64 z y))
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
Outputs
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
Calls

6 calls:

14.0ms
x
13.0ms
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
13.0ms
z
13.0ms
t
12.0ms
y
Results
ErrorSegmentsBranch
0.0b1x
0.0b1y
0.0b1z
0.0b1t
0.0b1(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
0.0b1(*.f64 (+.f64 (*.f64 x y) z) y)
Compiler

Compiled 106 to 52 computations (50.9% saved)

regimes242.0ms (3.2%)

Counts
9 → 3
Calls
Call 1
Inputs
t
(*.f64 y z)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 z y) t)
(*.f64 (+.f64 (*.f64 y x) z) y)
(+.f64 (*.f64 (*.f64 y x) y) t)
(+.f64 (*.f64 (*.f64 y y) x) t)
(+.f64 (*.f64 (*.f64 y x) y) (*.f64 z y))
Outputs
(+.f64 (*.f64 z y) t)
(+.f64 (*.f64 (*.f64 y x) y) t)
(+.f64 (*.f64 z y) t)
Calls

4 calls:

80.0ms
z
73.0ms
x
53.0ms
t
32.0ms
y
Results
ErrorSegmentsBranch
9.0b5x
7.5b3y
5.0b3z
8.3b5t
Compiler

Compiled 73 to 33 computations (54.8% saved)

bsearch75.0ms (1%)

Algorithm
binary-search
Steps
TimeLeftRight
42.0ms
2.797961030596841e+41
7.308845516439637e+43
33.0ms
-1849051290919909600.0
-1656028318963966.0
Compiler

Compiled 20 to 14 computations (30% saved)

regimes200.0ms (2.7%)

Counts
6 → 3
Calls
Call 1
Inputs
t
(*.f64 y z)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 z y) t)
(*.f64 (+.f64 (*.f64 y x) z) y)
Outputs
(*.f64 (+.f64 (*.f64 y x) z) y)
(+.f64 (*.f64 z y) t)
(*.f64 (+.f64 (*.f64 y x) z) y)
Calls

4 calls:

63.0ms
y
28.0ms
t
28.0ms
z
12.0ms
x
Results
ErrorSegmentsBranch
12.9b1x
7.6b3y
11.7b3z
10.2b3t
Compiler

Compiled 50 to 29 computations (42% saved)

bsearch227.0ms (3%)

Algorithm
binary-search
Steps
TimeLeftRight
79.0ms
9.144752934837097e-13
8.391294968023866e-7
148.0ms
-1.95589569390443e+87
-1.3909672735577008e+75
Compiler

Compiled 240 to 164 computations (31.7% saved)

regimes110.0ms (1.5%)

Counts
5 → 4
Calls
Call 1
Inputs
t
(*.f64 y z)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 z y) t)
Outputs
(+.f64 (*.f64 z y) t)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 z y) t)
(*.f64 y (*.f64 y x))
Calls

4 calls:

42.0ms
y
42.0ms
z
14.0ms
x
9.0ms
t
Results
ErrorSegmentsBranch
11.5b3x
10.3b4y
11.8b3z
12.9b1t
Compiler

Compiled 43 to 27 computations (37.2% saved)

bsearch276.0ms (3.7%)

Algorithm
binary-search
Steps
TimeLeftRight
112.0ms
4.941952993790199e+48
1.540665105195884e+54
144.0ms
1.9211979732639173e+26
2.838885227454513e+27
20.0ms
1024955.113786615
525334052.83295196
Compiler

Compiled 320 to 224 computations (30% saved)

regimes68.0ms (0.9%)

Counts
4 → 7
Calls
Call 1
Inputs
t
(*.f64 y z)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
Outputs
t
(*.f64 y z)
(*.f64 y (*.f64 y x))
(*.f64 y z)
(*.f64 y (*.f64 y x))
(*.f64 y z)
t
Calls

4 calls:

28.0ms
t
23.0ms
z
12.0ms
y
4.0ms
x
Results
ErrorSegmentsBranch
29.3b1x
24.1b3y
24.1b5z
20.2b7t
Compiler

Compiled 38 to 25 computations (34.2% saved)

bsearch158.0ms (2.1%)

Algorithm
binary-search
Steps
TimeLeftRight
41.0ms
1.6949710219950935e-46
4.7226231465980267e-42
25.0ms
6.309788258062418e-67
2.705348011372824e-63
24.0ms
2.7229447038234774e-114
1.2139419646672136e-107
20.0ms
1.9282024663912063e-165
1.5223353852025487e-150
23.0ms
2.0461205227154176e-229
8.319199590910977e-222
24.0ms
-3.257442775400132e-79
-1.75006976417969e-82
Compiler

Compiled 20 to 14 computations (30% saved)

regimes131.0ms (1.7%)

Counts
3 → 5
Calls
Call 1
Inputs
t
(*.f64 y z)
(*.f64 (*.f64 y y) x)
Outputs
t
(*.f64 y z)
(*.f64 (*.f64 y y) x)
(*.f64 y z)
t
Calls

4 calls:

45.0ms
z
44.0ms
t
29.0ms
y
10.0ms
x
Results
ErrorSegmentsBranch
29.3b1x
24.6b4y
24.1b5z
21.4b5t
Compiler

Compiled 33 to 23 computations (30.3% saved)

bsearch164.0ms (2.2%)

Algorithm
binary-search
Steps
TimeLeftRight
42.0ms
1.936231027305437e-95
1.7604514983774282e-94
39.0ms
1.9282024663912063e-165
1.5223353852025487e-150
41.0ms
2.0461205227154176e-229
8.319199590910977e-222
42.0ms
-3.257442775400132e-79
-1.75006976417969e-82
Compiler

Compiled 20 to 14 computations (30% saved)

regimes61.0ms (0.8%)

Accuracy

Total -39.6b remaining (-174.9%)

Threshold costs -39.6b (-174.9%)

Counts
2 → 3
Calls
Call 1
Inputs
t
(*.f64 y z)
Outputs
t
(*.f64 y z)
t
Calls

4 calls:

27.0ms
t
15.0ms
z
13.0ms
y
3.0ms
x
Results
ErrorSegmentsBranch
29.3b1x
26.5b3y
25.3b3z
22.6b3t
Compiler

Compiled 28 to 21 computations (25% saved)

bsearch82.0ms (1.1%)

Algorithm
binary-search
Steps
TimeLeftRight
40.0ms
1.936231027305437e-95
1.7604514983774282e-94
41.0ms
-3.257442775400132e-79
-1.75006976417969e-82
Compiler

Compiled 20 to 14 computations (30% saved)

simplify23.0ms (0.3%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
070274
186274
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(+.f64 (+.f64 (*.f64 (*.f64 x y) y) (*.f64 z y)) t)
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
(if (<=.f64 z -1849051290919909632) (+.f64 (*.f64 z y) t) (if (<=.f64 z 279796103059684096762681213058982610993152) (+.f64 (*.f64 (*.f64 y x) y) t) (+.f64 (*.f64 z y) t)))
(if (<=.f64 y -1950000000000000097547319167721640284739142449106331890104380756684968461914981259018240) (*.f64 (+.f64 (*.f64 y x) z) y) (if (<=.f64 y 4528262322962933/4951760157141521099596496896) (+.f64 (*.f64 z y) t) (*.f64 (+.f64 (*.f64 y x) z) y)))
(if (<=.f64 y 2201074346790735/2147483648) (+.f64 (*.f64 z y) t) (if (<=.f64 y 200000000000000009529458688) (*.f64 y (*.f64 y x)) (if (<=.f64 y 1519999999999999989695841985029674524221796831754977280) (+.f64 (*.f64 z y) t) (*.f64 y (*.f64 y x)))))
(if (<=.f64 t -5435824639460087/16687398718132110018711107079449625895333629080911349765211262561111091607661254297054391304192) t (if (<=.f64 t 1397100664512315/6828046779268970776657768233698567984276232522051489956245767999246374131525255241237946573692471593720760228447675638216590132893818229842292076597586769967201441361422350907866192164773697561322460176523147880429251325990375896362151810433024) (*.f64 y z) (if (<=.f64 t 500069134640315/259344723055062059907025491480697571938277889515152306249728583105665800713306759149981690559193987143012367913206299323899696942213235956742929677132122730441323862712594345230336) (*.f64 y (*.f64 y x)) (if (<=.f64 t 3774913129529067/1386334847060407429789207092071541851718218537687908287585239790307310653902812811519987203052069789048695605480701785914487078912) (*.f64 y z) (if (<=.f64 t 1197053648971585/1897137590064188545819787018382342682267975428761855001222473056385648716020711424) (*.f64 y (*.f64 y x)) (if (<=.f64 t 1089485367664183/6427752177035961102167848369364650410088811975131171341205504) (*.f64 y z) t))))))
(if (<=.f64 t -5435824639460087/16687398718132110018711107079449625895333629080911349765211262561111091607661254297054391304192) t (if (<=.f64 t 1397100664512315/6828046779268970776657768233698567984276232522051489956245767999246374131525255241237946573692471593720760228447675638216590132893818229842292076597586769967201441361422350907866192164773697561322460176523147880429251325990375896362151810433024) (*.f64 y z) (if (<=.f64 t 500069134640315/259344723055062059907025491480697571938277889515152306249728583105665800713306759149981690559193987143012367913206299323899696942213235956742929677132122730441323862712594345230336) (*.f64 (*.f64 y y) x) (if (<=.f64 t 727571362834359/37576681324381331646231689548629392438010920782533117931316655544515344401833735095419183974156299248510959616) (*.f64 y z) t))))
(if (<=.f64 t -5435824639460087/16687398718132110018711107079449625895333629080911349765211262561111091607661254297054391304192) t (if (<=.f64 t 727571362834359/37576681324381331646231689548629392438010920782533117931316655544515344401833735095419183974156299248510959616) (*.f64 y z) t))
t
Outputs
(+.f64 (+.f64 (*.f64 (*.f64 x y) y) (*.f64 z y)) t)
(+.f64 (+.f64 (*.f64 y (*.f64 x y)) (*.f64 y z)) t)
(+.f64 (*.f64 (+.f64 (*.f64 x y) z) y) t)
(+.f64 t (*.f64 y (+.f64 z (*.f64 x y))))
(if (<=.f64 z -1849051290919909632) (+.f64 (*.f64 z y) t) (if (<=.f64 z 279796103059684096762681213058982610993152) (+.f64 (*.f64 (*.f64 y x) y) t) (+.f64 (*.f64 z y) t)))
(if (<=.f64 z -1849051290919909632) (+.f64 t (*.f64 y z)) (if (<=.f64 z 279796103059684096762681213058982610993152) (+.f64 t (*.f64 y (*.f64 x y))) (+.f64 t (*.f64 y z))))
(if (<=.f64 y -1950000000000000097547319167721640284739142449106331890104380756684968461914981259018240) (*.f64 (+.f64 (*.f64 y x) z) y) (if (<=.f64 y 4528262322962933/4951760157141521099596496896) (+.f64 (*.f64 z y) t) (*.f64 (+.f64 (*.f64 y x) z) y)))
(if (<=.f64 y -1950000000000000097547319167721640284739142449106331890104380756684968461914981259018240) (*.f64 y (+.f64 z (*.f64 x y))) (if (<=.f64 y 4528262322962933/4951760157141521099596496896) (+.f64 t (*.f64 y z)) (*.f64 y (+.f64 z (*.f64 x y)))))
(if (<=.f64 y 2201074346790735/2147483648) (+.f64 (*.f64 z y) t) (if (<=.f64 y 200000000000000009529458688) (*.f64 y (*.f64 y x)) (if (<=.f64 y 1519999999999999989695841985029674524221796831754977280) (+.f64 (*.f64 z y) t) (*.f64 y (*.f64 y x)))))
(if (<=.f64 y 2201074346790735/2147483648) (+.f64 t (*.f64 y z)) (if (<=.f64 y 200000000000000009529458688) (*.f64 y (*.f64 x y)) (if (<=.f64 y 1519999999999999989695841985029674524221796831754977280) (+.f64 t (*.f64 y z)) (*.f64 y (*.f64 x y)))))
(if (<=.f64 t -5435824639460087/16687398718132110018711107079449625895333629080911349765211262561111091607661254297054391304192) t (if (<=.f64 t 1397100664512315/6828046779268970776657768233698567984276232522051489956245767999246374131525255241237946573692471593720760228447675638216590132893818229842292076597586769967201441361422350907866192164773697561322460176523147880429251325990375896362151810433024) (*.f64 y z) (if (<=.f64 t 500069134640315/259344723055062059907025491480697571938277889515152306249728583105665800713306759149981690559193987143012367913206299323899696942213235956742929677132122730441323862712594345230336) (*.f64 y (*.f64 y x)) (if (<=.f64 t 3774913129529067/1386334847060407429789207092071541851718218537687908287585239790307310653902812811519987203052069789048695605480701785914487078912) (*.f64 y z) (if (<=.f64 t 1197053648971585/1897137590064188545819787018382342682267975428761855001222473056385648716020711424) (*.f64 y (*.f64 y x)) (if (<=.f64 t 1089485367664183/6427752177035961102167848369364650410088811975131171341205504) (*.f64 y z) t))))))
(if (<=.f64 t -5435824639460087/16687398718132110018711107079449625895333629080911349765211262561111091607661254297054391304192) t (if (<=.f64 t 1397100664512315/6828046779268970776657768233698567984276232522051489956245767999246374131525255241237946573692471593720760228447675638216590132893818229842292076597586769967201441361422350907866192164773697561322460176523147880429251325990375896362151810433024) (*.f64 y z) (if (<=.f64 t 500069134640315/259344723055062059907025491480697571938277889515152306249728583105665800713306759149981690559193987143012367913206299323899696942213235956742929677132122730441323862712594345230336) (*.f64 y (*.f64 x y)) (if (<=.f64 t 3774913129529067/1386334847060407429789207092071541851718218537687908287585239790307310653902812811519987203052069789048695605480701785914487078912) (*.f64 y z) (if (<=.f64 t 1197053648971585/1897137590064188545819787018382342682267975428761855001222473056385648716020711424) (*.f64 y (*.f64 x y)) (if (<=.f64 t 1089485367664183/6427752177035961102167848369364650410088811975131171341205504) (*.f64 y z) t))))))
(if (<=.f64 t -5435824639460087/16687398718132110018711107079449625895333629080911349765211262561111091607661254297054391304192) t (if (<=.f64 t 1397100664512315/6828046779268970776657768233698567984276232522051489956245767999246374131525255241237946573692471593720760228447675638216590132893818229842292076597586769967201441361422350907866192164773697561322460176523147880429251325990375896362151810433024) (*.f64 y z) (if (<=.f64 t 500069134640315/259344723055062059907025491480697571938277889515152306249728583105665800713306759149981690559193987143012367913206299323899696942213235956742929677132122730441323862712594345230336) (*.f64 (*.f64 y y) x) (if (<=.f64 t 727571362834359/37576681324381331646231689548629392438010920782533117931316655544515344401833735095419183974156299248510959616) (*.f64 y z) t))))
(if (<=.f64 t -5435824639460087/16687398718132110018711107079449625895333629080911349765211262561111091607661254297054391304192) t (if (<=.f64 t 1397100664512315/6828046779268970776657768233698567984276232522051489956245767999246374131525255241237946573692471593720760228447675638216590132893818229842292076597586769967201441361422350907866192164773697561322460176523147880429251325990375896362151810433024) (*.f64 y z) (if (<=.f64 t 500069134640315/259344723055062059907025491480697571938277889515152306249728583105665800713306759149981690559193987143012367913206299323899696942213235956742929677132122730441323862712594345230336) (*.f64 x (*.f64 y y)) (if (<=.f64 t 727571362834359/37576681324381331646231689548629392438010920782533117931316655544515344401833735095419183974156299248510959616) (*.f64 y z) t))))
(if (<=.f64 t -5435824639460087/16687398718132110018711107079449625895333629080911349765211262561111091607661254297054391304192) t (if (<=.f64 t 727571362834359/37576681324381331646231689548629392438010920782533117931316655544515344401833735095419183974156299248510959616) (*.f64 y z) t))
t
Compiler

Compiled 228 to 123 computations (46.1% saved)

soundness0.0ms (0%)

end149.0ms (2%)

Compiler

Compiled 196 to 73 computations (62.8% saved)

Profiling

Loading profile data...