Details

Time bar (total: 7.2s)

analyze506.0ms (7%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
0%0%99.9%0.1%0%0%0%5
0%0%99.9%0.1%0%0%0%6
12.5%12.5%87.4%0.1%0%0%0%7
18.8%18.7%81.1%0.1%0%0%0%8
26.2%25%70.2%0.1%4.7%0%0%9
32.7%25%51.5%0.1%23.4%0%0%10
39.4%29.6%45.6%0.1%24.6%0%0%11
46.6%33.5%38.4%0.1%27.9%0%0%12
Compiler

Compiled 19 to 9 computations (52.6% saved)

sample1.3s (17.8%)

Results
1.1s8256×body256valid
191.0ms925×body256infinite
Bogosity

preprocess27.0ms (0.4%)

Algorithm
egg-herbie
Rules
96×fma-def_binary64
15×*-commutative_binary64
14×associate-+l+_binary64
12×associate-*r*_binary64
11×+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02380
15160
29944
316244
421244
523044
033
133
Stop Event
unsound
saturated
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
0
2
Call 2
Inputs
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
(+.f64 (+.f64 (+.f64 (*.f64 y x) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
(+.f64 (+.f64 (+.f64 (*.f64 z y) (*.f64 x x)) (*.f64 x x)) (*.f64 x x))
(+.f64 (+.f64 (+.f64 (*.f64 x z) (*.f64 y y)) (*.f64 y y)) (*.f64 y y))
Outputs
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
(+.f64 (fma.f64 x y (*.f64 z z)) (+.f64 (*.f64 z z) (*.f64 z z)))
(fma.f64 z z (fma.f64 x y (*.f64 z (+.f64 z z))))
(fma.f64 x y (*.f64 3 (*.f64 z z)))
(fma.f64 x y (*.f64 z (*.f64 3 z)))
(fma.f64 x y (*.f64 z (*.f64 z 3)))
(+.f64 (+.f64 (+.f64 (*.f64 y x) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
(+.f64 (fma.f64 x y (*.f64 z z)) (+.f64 (*.f64 z z) (*.f64 z z)))
(fma.f64 z z (fma.f64 x y (*.f64 z (+.f64 z z))))
(fma.f64 x y (*.f64 3 (*.f64 z z)))
(fma.f64 x y (*.f64 z (*.f64 3 z)))
(fma.f64 x y (*.f64 z (*.f64 z 3)))
(+.f64 (+.f64 (+.f64 (*.f64 z y) (*.f64 x x)) (*.f64 x x)) (*.f64 x x))
(+.f64 (fma.f64 z y (*.f64 x x)) (+.f64 (*.f64 x x) (*.f64 x x)))
(fma.f64 x x (fma.f64 y z (*.f64 2 (*.f64 x x))))
(fma.f64 y z (*.f64 3 (*.f64 x x)))
(fma.f64 x (*.f64 3 x) (*.f64 y z))
(fma.f64 x (*.f64 x 3) (*.f64 y z))
(+.f64 (+.f64 (+.f64 (*.f64 x z) (*.f64 y y)) (*.f64 y y)) (*.f64 y y))
(+.f64 (fma.f64 x z (*.f64 y y)) (+.f64 (*.f64 y y) (*.f64 y y)))
(fma.f64 y y (fma.f64 x z (*.f64 y (+.f64 y y))))
(fma.f64 x z (*.f64 3 (*.f64 y y)))
(fma.f64 y (*.f64 3 y) (*.f64 x z))
(fma.f64 y (*.f64 y 3) (*.f64 x z))
Symmetry

(sort x y)

Compiler

Compiled 21 to 11 computations (47.6% saved)

simplify8.0ms (0.1%)

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

Useful iterations: 2 (0.0ms)

IterNodesCost
0920
11715
23411
35711
47511
58111
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
Outputs
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
(+.f64 (*.f64 z z) (+.f64 (*.f64 z z) (fma.f64 x y (*.f64 z z))))
(fma.f64 z z (fma.f64 x y (*.f64 z (+.f64 z z))))
(fma.f64 x y (*.f64 3 (*.f64 z z)))
(fma.f64 z (*.f64 3 z) (*.f64 x y))
(fma.f64 z (*.f64 z 3) (*.f64 x y))

eval1.0ms (0%)

Compiler

Compiled 26 to 11 computations (57.7% 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.1b
(fma.f64 z (*.f64 z 3) (*.f64 x y))
0.1b
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
Compiler

Compiled 29 to 15 computations (48.3% saved)

localize15.0ms (0.2%)

Local error

Found 6 expressions with local error:

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

Compiled 45 to 8 computations (82.2% saved)

series11.0ms (0.2%)

Counts
3 → 108
Calls

27 calls:

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

rewrite113.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
853×fma-def_binary64
523×log-prod_binary64
351×fma-neg_binary64
293×pow2_binary64
199×pow1/3_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify265.0ms (3.7%)

Algorithm
egg-herbie
Rules
2020×unswap-sqr_binary64
1080×sqr-pow_binary64
636×fabs-mul_binary64
612×pow-sqr_binary64
610×cube-prod_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0151158
132942
264942
3118942
4263942
5699942
61107942
71610942
81821942
91962942
102152942
112419942
122749942
133129942
143601942
154206942
164921942
175779942
186201942
196517942
206823942
216901942
226935942
Stop Event
node limit
Counts
386 → 293
Calls
Call 1
Inputs
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(pow.f64 z 2)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(pow.f64 z 2)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(pow.f64 z 2)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(pow.f64 z 2)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 2 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 2 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 2 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 2 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
Outputs
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(*.f64 (*.f64 z z) 3)
(*.f64 z (*.f64 z 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(*.f64 (*.f64 z z) 3)
(*.f64 z (*.f64 z 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(*.f64 3 (pow.f64 z 2))
(*.f64 (*.f64 z z) 3)
(*.f64 z (*.f64 z 3))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(*.f64 3 (pow.f64 z 2))
(*.f64 (*.f64 z z) 3)
(*.f64 z (*.f64 z 3))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(pow.f64 z 2)
(*.f64 z z)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(pow.f64 z 2)
(*.f64 z z)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(pow.f64 z 2)
(*.f64 z z)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(pow.f64 z 2)
(*.f64 z z)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(fma.f64 z z (*.f64 y x))
(*.f64 2 (pow.f64 z 2))
(*.f64 2 (*.f64 z z))
(*.f64 z (*.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(*.f64 2 (pow.f64 z 2))
(*.f64 2 (*.f64 z z))
(*.f64 z (*.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(*.f64 2 (pow.f64 z 2))
(*.f64 2 (*.f64 z z))
(*.f64 z (*.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(*.f64 2 (pow.f64 z 2))
(*.f64 2 (*.f64 z z))
(*.f64 z (*.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 2) (*.f64 y x))

localize9.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 z (*.f64 z 3) (*.f64 x y))
0.1b
(fma.f64 z (*.f64 z 3) (*.f64 x y))
Compiler

Compiled 21 to 10 computations (52.4% saved)

series5.0ms (0.1%)

Counts
1 → 36
Calls

9 calls:

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

rewrite62.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
740×pow1_binary64
678×add-log-exp_binary64
678×log1p-expm1-u_binary64
678×expm1-log1p-u_binary64
663×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify186.0ms (2.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010345
119345
233345
358345
4121345
5354345
61304345
72204345
82368345
92552345
102760345
113058345
123451345
133936345
144502345
155192345
166029345
176419345
186709345
196985345
207059345
217093345
Stop Event
node limit
Counts
57 → 26
Calls
Call 1
Inputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
Outputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))

eval114.0ms (1.6%)

Compiler

Compiled 6045 to 1611 computations (73.3% saved)

prune97.0ms (1.3%)

Pruning

8 alts after pruning (7 fresh and 1 done)

PrunedKeptTotal
New3127319
Fresh000
Picked101
Done011
Total3138321
Error
0b
Counts
321 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
19.6b
(pow.f64 (sqrt.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))) 2)
0.1b
(+.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))
0.1b
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
36.9b
(*.f64 3 (*.f64 z z))
0.1b
(+.f64 (fma.f64 (hypot.f64 z z) (hypot.f64 z z) (*.f64 x y)) (*.f64 z z))
0.0b
(fma.f64 y x (fma.f64 z z (*.f64 z (+.f64 z z))))
36.9b
(*.f64 z (*.f64 z 3))
22.1b
(*.f64 y x)
Compiler

Compiled 176 to 106 computations (39.8% saved)

localize10.0ms (0.1%)

Local error

Found 4 expressions with local error:

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

Compiled 33 to 7 computations (78.8% saved)

series6.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite203.0ms (2.8%)

Algorithm
batch-egg-rewrite
Rules
732×pow1_binary64
678×add-log-exp_binary64
677×log1p-expm1-u_binary64
677×expm1-log1p-u_binary64
663×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify238.0ms (3.3%)

Algorithm
egg-herbie
Rules
2020×unswap-sqr_binary64
1080×sqr-pow_binary64
633×fabs-mul_binary64
612×pow-sqr_binary64
610×cube-prod_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
014591
131429
264429
3119429
4266429
5703429
61115429
71618429
81829429
91970429
102160429
112425429
122757429
133135429
143609429
154206429
164917429
175773429
186203429
196517429
206825429
216905429
226939429
Stop Event
node limit
Counts
92 → 51
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
Outputs
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(*.f64 3 (*.f64 z z))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(*.f64 3 (*.f64 z z))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))

localize3.0ms (0%)

Compiler

Compiled 8 to 4 computations (50% saved)

localize6.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.2b
(*.f64 z (*.f64 z 3))
0.2b
(*.f64 z (*.f64 z 3))
Compiler

Compiled 13 to 9 computations (30.8% saved)

series2.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
1.0ms
z
@inf
(*.f64 z (*.f64 z 3))
1.0ms
z
@0
(*.f64 z (*.f64 z 3))
0.0ms
z
@-inf
(*.f64 z (*.f64 z 3))

rewrite76.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
448×pow1_binary64
432×add-sqr-sqrt_binary64
425×*-un-lft-identity_binary64
414×add-log-exp_binary64
414×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify181.0ms (2.5%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0684
11284
22384
34484
410484
531884
6126884
7214084
8230484
9248884
10269684
11299184
12338284
13386384
14443184
15512384
16595884
17635084
18664084
19691884
20698884
21702484
22796584
Stop Event
node limit
Counts
23 → 13
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
Outputs
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))

localize5.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.2b
(*.f64 3 (*.f64 z z))
0.2b
(*.f64 3 (*.f64 z z))
Compiler

Compiled 13 to 7 computations (46.2% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
0.0ms
z
@inf
(*.f64 3 (*.f64 z z))
0.0ms
z
@0
(*.f64 3 (*.f64 z z))
0.0ms
z
@-inf
(*.f64 3 (*.f64 z z))

rewrite81.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
432×pow1_binary64
419×add-sqr-sqrt_binary64
411×*-un-lft-identity_binary64
400×add-log-exp_binary64
400×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify190.0ms (2.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0684
11284
22384
34484
410484
531884
6126884
7214084
8230484
9248884
10269684
11299184
12338284
13386384
14443184
15512384
16595884
17635084
18664084
19691884
20698884
21702484
22796584
Stop Event
node limit
Counts
26 → 16
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (pow.f64 z 2))
Outputs
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 3 z))

localize10.0ms (0.1%)

Local error

Found 4 expressions with local error:

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

Compiled 27 to 14 computations (48.1% saved)

series3.0ms (0%)

Counts
1 → 36
Calls

9 calls:

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

rewrite101.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
979×pow1_binary64
905×add-log-exp_binary64
905×log1p-expm1-u_binary64
905×expm1-log1p-u_binary64
97×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0911
119011
2248111
Stop Event
node limit
Counts
1 → 39
Calls
Call 1
Inputs
(+.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (*.f64 z (*.f64 z 3)) 2) (-.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))) (/.f64 (pow.f64 (*.f64 x y) 2) (-.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 z (*.f64 z 3) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))) (pow.f64 (cbrt.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))) 2) (cbrt.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))) (sqrt.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 (pow.f64 (*.f64 z z) 3) 27) (pow.f64 (*.f64 x y) 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 z (*.f64 z 3)) 2) (*.f64 (*.f64 x y) (-.f64 (*.f64 x y) (*.f64 z (*.f64 z 3)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (*.f64 z (*.f64 z 3)) 2) (pow.f64 (*.f64 x y) 2)) (/.f64 1 (-.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (*.f64 z (*.f64 z 3)) 2) (*.f64 (*.f64 x y) (-.f64 (*.f64 x y) (*.f64 z (*.f64 z 3))))) (+.f64 (*.f64 (pow.f64 (*.f64 z z) 3) 27) (pow.f64 (*.f64 x y) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y)) (-.f64 (pow.f64 (*.f64 z (*.f64 z 3)) 2) (pow.f64 (*.f64 x y) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 (pow.f64 (*.f64 z z) 3) 27) (pow.f64 (*.f64 x y) 3)) (+.f64 (pow.f64 (*.f64 z (*.f64 z 3)) 2) (*.f64 (*.f64 x y) (-.f64 (*.f64 x y) (*.f64 z (*.f64 z 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 (pow.f64 (*.f64 z z) 3) 27) (pow.f64 (*.f64 x y) 3)) (+.f64 (pow.f64 (*.f64 x y) 2) (-.f64 (pow.f64 (*.f64 z (*.f64 z 3)) 2) (*.f64 z (*.f64 (*.f64 z 3) (*.f64 x y))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 z (*.f64 z 3)) 2) (pow.f64 (*.f64 x y) 2)) (-.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (*.f64 (pow.f64 (*.f64 z z) 3) 27) (pow.f64 (*.f64 x y) 3))) (neg.f64 (+.f64 (pow.f64 (*.f64 z (*.f64 z 3)) 2) (*.f64 (*.f64 x y) (-.f64 (*.f64 x y) (*.f64 z (*.f64 z 3)))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 z (*.f64 z 3)) 2) (pow.f64 (*.f64 x y) 2))) (neg.f64 (-.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (pow.f64 (*.f64 z (*.f64 z 3)) 2)) (-.f64 (*.f64 x y) (*.f64 z (*.f64 z 3))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 z (*.f64 z 3) (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 z 3) z (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x y (*.f64 z (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y x (*.f64 z (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 z (*.f64 z 3)) (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x y) (*.f64 z (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 z z) 3 (*.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)) (*.f64 z (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 z (*.f64 z 3))) 2) (cbrt.f64 (*.f64 z (*.f64 z 3))) (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x y)) (sqrt.f64 (*.f64 x y)) (*.f64 z (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 z (sqrt.f64 3)) (*.f64 z (sqrt.f64 3)) (*.f64 x y))))))

simplify185.0ms (2.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010345
119345
233345
358345
4121345
5354345
61304345
72204345
82368345
92552345
102760345
113058345
123451345
133936345
144502345
155192345
166029345
176419345
186709345
196985345
207059345
217093345
Stop Event
node limit
Counts
75 → 44
Calls
Call 1
Inputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
Outputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))

eval30.0ms (0.4%)

Compiler

Compiled 1751 to 785 computations (55.2% saved)

prune41.0ms (0.6%)

Pruning

9 alts after pruning (4 fresh and 5 done)

PrunedKeptTotal
New1343137
Fresh112
Picked011
Done145
Total1369145
Error
0b
Counts
145 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
36.9b
(*.f64 z (*.f64 z 3))
37.3b
(pow.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 3)
0.1b
(+.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))
0.1b
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
36.9b
(*.f64 3 (*.f64 z z))
0.1b
(+.f64 (fma.f64 (hypot.f64 z z) (hypot.f64 z z) (*.f64 x y)) (*.f64 z z))
37.1b
(pow.f64 (*.f64 z (sqrt.f64 3)) 2)
0.1b
(fma.f64 3 (*.f64 z z) (*.f64 y x))
22.1b
(*.f64 y x)
Compiler

Compiled 100 to 64 computations (36% saved)

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 3 (*.f64 z z) (*.f64 y x))
0.1b
(fma.f64 3 (*.f64 z z) (*.f64 y x))
Compiler

Compiled 21 to 8 computations (61.9% saved)

series3.0ms (0%)

Counts
1 → 36
Calls

9 calls:

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

rewrite105.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
711×pow1_binary64
652×add-log-exp_binary64
652×log1p-expm1-u_binary64
652×expm1-log1p-u_binary64
637×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify194.0ms (2.7%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010345
119345
233345
358345
4121345
5354345
61304345
72204345
82368345
92552345
102760345
113058345
123451345
133936345
144502345
155192345
166029345
176419345
186709345
196985345
207059345
217093345
Stop Event
node limit
Counts
57 → 26
Calls
Call 1
Inputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
Outputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))

localize9.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.4b
(*.f64 z (sqrt.f64 3))
0.3b
(pow.f64 (*.f64 z (sqrt.f64 3)) 2)
0.3b
(pow.f64 (*.f64 z (sqrt.f64 3)) 2)
0.4b
(*.f64 z (sqrt.f64 3))
Compiler

Compiled 18 to 15 computations (16.7% saved)

series4.0ms (0.1%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
2.0ms
z
@inf
(*.f64 z (sqrt.f64 3))
1.0ms
z
@0
(*.f64 z (sqrt.f64 3))
1.0ms
z
@-inf
(pow.f64 (*.f64 z (sqrt.f64 3)) 2)
0.0ms
z
@0
(pow.f64 (*.f64 z (sqrt.f64 3)) 2)
0.0ms
z
@-inf
(*.f64 z (sqrt.f64 3))

rewrite87.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
550×pow1_binary64
511×add-log-exp_binary64
510×log1p-expm1-u_binary64
510×expm1-log1p-u_binary64
498×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify195.0ms (2.7%)

Algorithm
egg-herbie
Rules
834×sqr-pow_binary64
691×cube-prod_binary64
682×fabs-mul_binary64
635×associate-*l*_binary64
573×pow-sqr_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
09216
119156
238156
393156
4383156
52082156
62195156
72404156
82600156
92829156
103136156
113768156
124243156
134872156
145586156
156511156
167021156
177405156
187777156
197869156
207899156
Stop Event
node limit
Counts
59 → 37
Calls
Call 1
Inputs
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
Outputs
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (sqrt.f64 3) z)
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 z z))
(*.f64 z (*.f64 z 3))
(*.f64 3 (*.f64 z z))

localize12.0ms (0.2%)

Local error

Found 6 expressions with local error:

NewErrorProgram
0.2b
(fma.f64 (hypot.f64 z z) (hypot.f64 z z) (*.f64 x y))
0.1b
(+.f64 (fma.f64 (hypot.f64 z z) (hypot.f64 z z) (*.f64 x y)) (*.f64 z z))
0.1b
(hypot.f64 z z)
0.1b
(hypot.f64 z z)
0.1b
(+.f64 (fma.f64 (hypot.f64 z z) (hypot.f64 z z) (*.f64 x y)) (*.f64 z z))
0.2b
(fma.f64 (hypot.f64 z z) (hypot.f64 z z) (*.f64 x y))
Compiler

Compiled 39 to 8 computations (79.5% saved)

series8.0ms (0.1%)

Counts
3 → 84
Calls

21 calls:

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

rewrite76.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
977×pow1_binary64
903×add-log-exp_binary64
903×log1p-expm1-u_binary64
903×expm1-log1p-u_binary64
100×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify195.0ms (2.7%)

Algorithm
egg-herbie
Rules
940×fma-def_binary64
617×unswap-sqr_binary64
468×fma-neg_binary64
306×distribute-rgt-neg-in_binary64
304×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0201173
147770
2114770
3263770
4834770
51568770
62843770
73524770
84622770
95635770
106698770
Stop Event
node limit
Counts
158 → 88
Calls
Call 1
Inputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 -1 (*.f64 (sqrt.f64 2) z))
(*.f64 -1 (*.f64 (sqrt.f64 2) z))
(*.f64 -1 (*.f64 (sqrt.f64 2) z))
(*.f64 -1 (*.f64 (sqrt.f64 2) z))
Outputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z))
(*.f64 2 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z))
(*.f64 2 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z))
(*.f64 2 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))
(*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z))
(*.f64 2 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (pow.f64 (sqrt.f64 2) 2) (*.f64 z z)))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
(*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1))
(*.f64 z (*.f64 z 3))
(*.f64 (*.f64 z z) 3)
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
(*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1))
(*.f64 z (*.f64 z 3))
(*.f64 (*.f64 z z) 3)
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2)))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1))
(*.f64 z (*.f64 z 3))
(*.f64 (*.f64 z z) 3)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2)))
(*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1))
(*.f64 z (*.f64 z 3))
(*.f64 (*.f64 z z) 3)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 (pow.f64 (sqrt.f64 2) 2) (pow.f64 z 2))))
(fma.f64 y x (*.f64 (*.f64 z z) (+.f64 (pow.f64 (sqrt.f64 2) 2) 1)))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 z (*.f64 z 3)))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 (sqrt.f64 2) z)
(*.f64 -1 (*.f64 (sqrt.f64 2) z))
(neg.f64 (*.f64 (sqrt.f64 2) z))
(*.f64 (sqrt.f64 2) (neg.f64 z))
(*.f64 -1 (*.f64 (sqrt.f64 2) z))
(neg.f64 (*.f64 (sqrt.f64 2) z))
(*.f64 (sqrt.f64 2) (neg.f64 z))
(*.f64 -1 (*.f64 (sqrt.f64 2) z))
(neg.f64 (*.f64 (sqrt.f64 2) z))
(*.f64 (sqrt.f64 2) (neg.f64 z))
(*.f64 -1 (*.f64 (sqrt.f64 2) z))
(neg.f64 (*.f64 (sqrt.f64 2) z))
(*.f64 (sqrt.f64 2) (neg.f64 z))

localize14.0ms (0.2%)

Local error

Found 6 expressions with local error:

NewErrorProgram
21.0b
(cbrt.f64 (*.f64 3 (*.f64 z z)))
0.5b
(pow.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 3)
0.2b
(*.f64 3 (*.f64 z z))
0.2b
(*.f64 3 (*.f64 z z))
0.5b
(pow.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 3)
21.0b
(cbrt.f64 (*.f64 3 (*.f64 z z)))
Compiler

Compiled 27 to 15 computations (44.4% saved)

series6.0ms (0.1%)

Counts
2 → 0
Calls

6 calls:

TimeVariablePointExpression
2.0ms
z
@0
(pow.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 3)
1.0ms
z
@0
(cbrt.f64 (*.f64 3 (*.f64 z z)))
1.0ms
z
@inf
(pow.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 3)
1.0ms
z
@-inf
(pow.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 3)
1.0ms
z
@inf
(cbrt.f64 (*.f64 3 (*.f64 z z)))

rewrite68.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
532×pow1_binary64
519×add-sqr-sqrt_binary64
501×add-log-exp_binary64
501×log1p-expm1-u_binary64
501×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0716
114916
2147416
Stop Event
node limit
Counts
2 → 54
Calls
Call 1
Inputs
(cbrt.f64 (*.f64 3 (*.f64 z z)))
(pow.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 3)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (cbrt.f64 (*.f64 3 (*.f64 z z)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cbrt.f64 (*.f64 3 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))) (cbrt.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))) (pow.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4)))) (cbrt.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 3) (cbrt.f64 (*.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 z z)) (cbrt.f64 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 z (sqrt.f64 3))) (cbrt.f64 (*.f64 z (sqrt.f64 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 3 z)) (cbrt.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4))) 1/3) (cbrt.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (cbrt.f64 (*.f64 3 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 z (sqrt.f64 3)) 1/3) (pow.f64 (*.f64 z (sqrt.f64 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 3 z) 1/3) (cbrt.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (*.f64 z z)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 z (sqrt.f64 3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 3 (*.f64 z z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 z (*.f64 3 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 z z) 3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 (*.f64 z z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) (cbrt.f64 (*.f64 9 (pow.f64 z 4))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 3 (*.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4))) (cbrt.f64 (*.f64 3 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4)))) (*.f64 (cbrt.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))) (cbrt.f64 (*.f64 9 (pow.f64 z 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 3) (*.f64 (cbrt.f64 (*.f64 z z)) (cbrt.f64 (*.f64 9 (pow.f64 z 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 z 4)) (*.f64 (cbrt.f64 (*.f64 z z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 z (sqrt.f64 3))) (*.f64 (cbrt.f64 (*.f64 z (sqrt.f64 3))) (cbrt.f64 (*.f64 9 (pow.f64 z 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 z (sqrt.f64 3)) (*.f64 z (sqrt.f64 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 z) z)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4)))) 3) (cbrt.f64 (*.f64 3 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 3) 3) (*.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 z (sqrt.f64 3))) 3) (pow.f64 (cbrt.f64 (*.f64 z (sqrt.f64 3))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 (cbrt.f64 (pow.f64 z 4))) (cbrt.f64 (*.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4))) 1) (cbrt.f64 (*.f64 3 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4))) (cbrt.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4))))) (cbrt.f64 (cbrt.f64 (*.f64 3 (*.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4))) (cbrt.f64 3)) (cbrt.f64 (*.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (*.f64 9 (pow.f64 z 4))) (cbrt.f64 (*.f64 z (sqrt.f64 3)))) (cbrt.f64 (*.f64 z (sqrt.f64 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 3 z) 1) z)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 3 z) (cbrt.f64 (*.f64 z z))) (cbrt.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 3 z) (sqrt.f64 z)) (sqrt.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 9 (pow.f64 z 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 3) (*.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 3 (*.f64 z z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 3 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 3 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 3 (*.f64 z z))))))))

simplify29.0ms (0.4%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
000
Stop Event
saturated
Counts
54 → 54
Calls
Call 1
Inputs
Outputs

eval96.0ms (1.3%)

Compiler

Compiled 3514 to 1457 computations (58.5% saved)

prune125.0ms (1.7%)

Pruning

10 alts after pruning (4 fresh and 6 done)

PrunedKeptTotal
New2384242
Fresh000
Picked101
Done268
Total24110251
Error
0b
Counts
251 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
18.8b
(+.f64 (*.f64 y x) (*.f64 z z))
36.9b
(*.f64 3 (*.f64 z z))
37.1b
(pow.f64 (*.f64 z (sqrt.f64 3)) 2)
36.9b
(*.f64 z (*.f64 z 3))
37.1b
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
0.1b
(fma.f64 3 (*.f64 z z) (*.f64 y x))
0.1b
(+.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))
0.1b
(+.f64 (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))) (*.f64 z z))
0.0b
(fma.f64 z z (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))))
22.1b
(*.f64 y x)
Compiler

Compiled 108 to 74 computations (31.5% saved)

localize12.0ms (0.2%)

Local error

Found 4 expressions with local error:

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

Compiled 38 to 8 computations (78.9% saved)

series6.0ms (0.1%)

Counts
2 → 72
Calls

18 calls:

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

rewrite71.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
954×pow1_binary64
886×add-log-exp_binary64
885×log1p-expm1-u_binary64
885×expm1-log1p-u_binary64
105×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0926
119820
2297120
Stop Event
node limit
Counts
2 → 61
Calls
Call 1
Inputs
(fma.f64 z z (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))))
(+.f64 (*.f64 x y) (*.f64 z (+.f64 z z)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 x y (+.f64 z z)) (*.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 z z) (fma.f64 x y (+.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 z z) (+.f64 z z)) (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 z z) 1) (fma.f64 x y (+.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (*.f64 z z) (*.f64 x y)) (+.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 z z (fma.f64 x y (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z)))) (pow.f64 (cbrt.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z)))) 2) (cbrt.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 z (sqrt.f64 (fma.f64 x y (+.f64 z z)))) (hypot.f64 z (sqrt.f64 (fma.f64 x y (+.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 z z) 3) (pow.f64 (fma.f64 x y (+.f64 z z)) 3)) (+.f64 (*.f64 (*.f64 z z) (*.f64 z z)) (-.f64 (pow.f64 (fma.f64 x y (+.f64 z z)) 2) (*.f64 (*.f64 z z) (fma.f64 x y (+.f64 z z))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 z z) (*.f64 z z)) (pow.f64 (fma.f64 x y (+.f64 z z)) 2)) (-.f64 (*.f64 z z) (fma.f64 x y (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (hypot.f64 z (sqrt.f64 (fma.f64 x y (+.f64 z z)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 z z (fma.f64 x y (+.f64 z z)))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 x y (+.f64 z z)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (*.f64 x y) 2) (-.f64 (*.f64 x y) (+.f64 z z))) (/.f64 (+.f64 z z) (-.f64 (*.f64 x y) (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x y (+.f64 z z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x y (+.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x y (+.f64 z z))) (pow.f64 (cbrt.f64 (fma.f64 x y (+.f64 z z))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x y (+.f64 z z))) 2) (cbrt.f64 (fma.f64 x y (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x y (+.f64 z z))) (sqrt.f64 (fma.f64 x y (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (+.f64 z z) (pow.f64 (*.f64 x y) 3)) (/.f64 1 (+.f64 (pow.f64 (*.f64 x y) 2) (-.f64 (+.f64 z z) (*.f64 x (*.f64 y (+.f64 z z)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (+.f64 z z)) (/.f64 1 (-.f64 (*.f64 x y) (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (*.f64 x y) 2) (-.f64 (+.f64 z z) (*.f64 x (*.f64 y (+.f64 z z))))) (+.f64 (+.f64 z z) (pow.f64 (*.f64 x y) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (*.f64 x y) (+.f64 z z)) (-.f64 (pow.f64 (*.f64 x y) 2) (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (+.f64 z z) (pow.f64 (*.f64 x y) 3)) (+.f64 (pow.f64 (*.f64 x y) 2) (-.f64 (+.f64 z z) (*.f64 x (*.f64 y (+.f64 z z))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (+.f64 z z) (pow.f64 (*.f64 x y) 3)) (+.f64 (+.f64 z z) (-.f64 (pow.f64 (*.f64 x y) 2) (*.f64 x (*.f64 y (+.f64 z z))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 x y) 2) (+.f64 z z)) (-.f64 (*.f64 x y) (+.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (+.f64 z z) (pow.f64 (*.f64 x y) 3))) (neg.f64 (+.f64 (pow.f64 (*.f64 x y) 2) (-.f64 (+.f64 z z) (*.f64 x (*.f64 y (+.f64 z z)))))))))) (#(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) (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (+.f64 z z) (pow.f64 (*.f64 x y) 2)) (-.f64 (+.f64 z z) (*.f64 x y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x y (+.f64 z z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x y (+.f64 z z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x y (+.f64 z z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x y (+.f64 z z))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x y (+.f64 z z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x y (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 x y (+.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x y (+.f64 z z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x y (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x y (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x y (+.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 z (+.f64 z z) (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x y (+.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y x (+.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 z z) z (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 z z) (+.f64 z z) (*.f64 x y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x y) (+.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 z 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)) (+.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x y)) (sqrt.f64 (*.f64 x y)) (+.f64 z z))))))

simplify292.0ms (4%)

Algorithm
egg-herbie
Rules
2020×unswap-sqr_binary64
1080×sqr-pow_binary64
630×fabs-mul_binary64
612×pow-sqr_binary64
610×cube-prod_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
014690
131690
264690
3120690
4266690
5705690
61120690
71623690
81834690
91975690
102165690
112432690
122764690
133142690
143611690
154214690
164929690
175789690
186211690
196523690
206829690
216905690
226939690
Stop Event
node limit
Counts
133 → 72
Calls
Call 1
Inputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 2 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 2 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 2 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(*.f64 2 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
Outputs
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 3 (pow.f64 z 2))
(*.f64 3 (*.f64 z z))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(*.f64 3 (*.f64 z z))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(*.f64 3 (*.f64 z z))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(fma.f64 y x (*.f64 3 (*.f64 z z)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(*.f64 2 (pow.f64 z 2))
(*.f64 2 (*.f64 z z))
(*.f64 z (*.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(*.f64 2 (pow.f64 z 2))
(*.f64 2 (*.f64 z z))
(*.f64 z (*.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(*.f64 2 (pow.f64 z 2))
(*.f64 2 (*.f64 z z))
(*.f64 z (*.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(*.f64 2 (pow.f64 z 2))
(*.f64 2 (*.f64 z z))
(*.f64 z (*.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2)))
(fma.f64 y x (*.f64 2 (*.f64 z z)))
(fma.f64 y x (*.f64 z (*.f64 z 2)))
(fma.f64 z (*.f64 z 2) (*.f64 y x))
(fma.f64 2 (*.f64 z z) (*.f64 y x))

localize12.0ms (0.2%)

Local error

Found 4 expressions with local error:

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

Compiled 42 to 9 computations (78.6% saved)

series3.0ms (0%)

Counts
1 → 36
Calls

9 calls:

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

rewrite93.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
574×fma-neg_binary64
502×log-prod_binary64
386×pow-prod-down_binary64
272×pow2_binary64
199×pow-unpow_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify248.0ms (3.4%)

Algorithm
egg-herbie
Rules
2020×unswap-sqr_binary64
1080×sqr-pow_binary64
635×fabs-mul_binary64
612×pow-sqr_binary64
610×cube-prod_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
014507
131345
264345
3120345
4264345
5699345
61123345
71626345
81837345
91978345
102168345
112433345
122765345
133143345
143617345
154222345
164933345
175795345
186217345
196533345
206841345
216915345
226951345
Stop Event
node limit
Counts
94 → 65
Calls
Call 1
Inputs
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(*.f64 3 (pow.f64 z 2))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
Outputs
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(*.f64 (*.f64 z z) 3)
(*.f64 z (*.f64 z 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 2 (pow.f64 z 2)))
(*.f64 (*.f64 z z) 3)
(*.f64 z (*.f64 z 3))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (pow.f64 z 2) (+.f64 (*.f64 y x) (*.f64 2 (pow.f64 z 2))))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 3 (pow.f64 z 2))
(*.f64 (*.f64 z z) 3)
(*.f64 z (*.f64 z 3))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(*.f64 3 (pow.f64 z 2))
(*.f64 (*.f64 z z) 3)
(*.f64 z (*.f64 z 3))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))
(+.f64 (*.f64 y x) (*.f64 3 (pow.f64 z 2)))
(+.f64 (*.f64 z z) (fma.f64 y x (*.f64 2 (*.f64 z z))))
(fma.f64 (*.f64 z z) 3 (*.f64 y x))
(fma.f64 y x (*.f64 (*.f64 z z) 3))
(fma.f64 z (*.f64 z 3) (*.f64 y x))

localize17.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
1.0b
(pow.f64 (sqrt.f64 2) 2)
0.2b
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
0.2b
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
1.0b
(pow.f64 (sqrt.f64 2) 2)
Compiler

Compiled 31 to 28 computations (9.7% saved)

series2.0ms (0%)

Counts
2 → 0
Calls

3 calls:

TimeVariablePointExpression
1.0ms
z
@0
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
1.0ms
z
@inf
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
0.0ms
z
@-inf
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))

rewrite61.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
569×pow1_binary64
528×add-log-exp_binary64
527×log1p-expm1-u_binary64
527×expm1-log1p-u_binary64
516×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
098
11978
216028
Stop Event
node limit
Counts
2 → 12
Calls
Call 1
Inputs
(pow.f64 (sqrt.f64 2) 2)
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x . 2)))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 3 (*.f64 z z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (*.f64 z z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 3 (*.f64 z z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 z (sqrt.f64 3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 z 4) 9))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 3) (*.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 3 (*.f64 z z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 3 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 3 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 3 (*.f64 z z))))))))

simplify9.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
000
Stop Event
saturated
Counts
12 → 12
Calls
Call 1
Inputs
Outputs

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 19 to 6 computations (68.4% saved)

series2.0ms (0%)

Counts
1 → 36
Calls

9 calls:

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

rewrite61.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
777×pow1_binary64
721×add-log-exp_binary64
721×log1p-expm1-u_binary64
721×expm1-log1p-u_binary64
703×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
078
11498
220208
Stop Event
node limit
Counts
1 → 35
Calls
Call 1
Inputs
(+.f64 (*.f64 y x) (*.f64 z z))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 y x (*.f64 z z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (*.f64 y x) 2) (fma.f64 y x (neg.f64 (*.f64 z z)))) (/.f64 (pow.f64 z 4) (fma.f64 y x (neg.f64 (*.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 y x (*.f64 z z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 y x (*.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 y x (*.f64 z z))) (pow.f64 (cbrt.f64 (fma.f64 y x (*.f64 z z))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 y x (*.f64 z z))) 2) (cbrt.f64 (fma.f64 y x (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 z (sqrt.f64 (*.f64 y x))) (hypot.f64 z (sqrt.f64 (*.f64 y x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 6)) (/.f64 1 (+.f64 (pow.f64 (*.f64 y x) 2) (-.f64 (pow.f64 z 4) (*.f64 y (*.f64 x (*.f64 z z)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 z 4)) (/.f64 1 (fma.f64 y x (neg.f64 (*.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (*.f64 y x) 2) (-.f64 (pow.f64 z 4) (*.f64 y (*.f64 x (*.f64 z z))))) (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 6))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 y x (neg.f64 (*.f64 z z))) (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 z 4))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 6)) (+.f64 (pow.f64 (*.f64 y x) 2) (-.f64 (pow.f64 z 4) (*.f64 y (*.f64 x (*.f64 z z))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 6)) (+.f64 (pow.f64 z 4) (-.f64 (pow.f64 (*.f64 y x) 2) (*.f64 y (*.f64 x (*.f64 z z))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 z 4)) (fma.f64 y x (neg.f64 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 y x) 3) (pow.f64 z 6))) (neg.f64 (+.f64 (pow.f64 (*.f64 y x) 2) (-.f64 (pow.f64 z 4) (*.f64 y (*.f64 x (*.f64 z z)))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 y x) 2) (pow.f64 z 4))) (neg.f64 (fma.f64 y x (neg.f64 (*.f64 z z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 z 4) (pow.f64 (*.f64 y x) 2)) (-.f64 (*.f64 z z) (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 y x (*.f64 z z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 y x (*.f64 z z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 y x (*.f64 z z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (hypot.f64 z (sqrt.f64 (*.f64 y x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 y x (*.f64 z z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 y x (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 y x (*.f64 z z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 y x (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 y x (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 y x (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y x (*.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x y (*.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 z z (*.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 y x) (*.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 z z) (*.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 z 4)) (pow.f64 (cbrt.f64 z) 2) (*.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)) (*.f64 z z))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 y x)) (sqrt.f64 (*.f64 y x)) (*.f64 z z))))))

simplify187.0ms (2.6%)

Algorithm
egg-herbie
Rules
1366×sqr-pow_binary64
695×pow-sqr_binary64
617×cube-prod_binary64
610×fabs-mul_binary64
434×unswap-sqr_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
08306
115252
226252
337252
466252
5161252
6589252
71456252
81640252
91824252
102032252
112327252
122720252
133203252
143769252
154461252
165296252
175688252
185978252
196256252
206328252
216364252
227305252
Stop Event
node limit
Counts
71 → 39
Calls
Call 1
Inputs
(pow.f64 z 2)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(pow.f64 z 2)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(pow.f64 z 2)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(pow.f64 z 2)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (pow.f64 z 2) (*.f64 y x))
Outputs
(pow.f64 z 2)
(*.f64 z z)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(pow.f64 z 2)
(*.f64 z z)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(*.f64 y x)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(pow.f64 z 2)
(*.f64 z z)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(pow.f64 z 2)
(*.f64 z z)
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))
(+.f64 (pow.f64 z 2) (*.f64 y x))
(+.f64 (*.f64 z z) (*.f64 y x))
(fma.f64 z z (*.f64 y x))
(fma.f64 y x (*.f64 z z))

eval91.0ms (1.3%)

Compiler

Compiled 3455 to 991 computations (71.3% saved)

prune49.0ms (0.7%)

Pruning

10 alts after pruning (2 fresh and 8 done)

PrunedKeptTotal
New2272229
Fresh000
Picked011
Done279
Total22910239
Error
0b
Counts
239 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
37.1b
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
55.1b
(*.f64 z z)
18.8b
(+.f64 (*.f64 y x) (*.f64 z z))
36.9b
(*.f64 3 (*.f64 z z))
36.9b
(fma.f64 z z (*.f64 z (*.f64 z 2)))
22.1b
(*.f64 y x)
37.1b
(pow.f64 (*.f64 z (sqrt.f64 3)) 2)
36.9b
(*.f64 z (*.f64 z 3))
0.1b
(+.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))
0.1b
(+.f64 (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))) (*.f64 z z))
Compiler

Compiled 99 to 70 computations (29.3% saved)

regimes84.0ms (1.2%)

Counts
18 → 1
Calls
Call 1
Inputs
(*.f64 z z)
(*.f64 y x)
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 z 3))
(+.f64 (*.f64 y x) (*.f64 z z))
(+.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))
(+.f64 (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))) (*.f64 z z))
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
(fma.f64 z z (*.f64 z (*.f64 z 2)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 x y))
(fma.f64 z z (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))))
(pow.f64 (*.f64 z (sqrt.f64 3)) 2)
(pow.f64 (cbrt.f64 (*.f64 3 (*.f64 z z))) 3)
(fma.f64 y x (fma.f64 z z (*.f64 z (+.f64 z z))))
(*.f64 (+.f64 1 (pow.f64 (sqrt.f64 2) 2)) (pow.f64 z 2))
(pow.f64 (sqrt.f64 (fma.f64 z (*.f64 z 3) (*.f64 x y))) 2)
(+.f64 (fma.f64 (hypot.f64 z z) (hypot.f64 z z) (*.f64 x y)) (*.f64 z z))
Outputs
(fma.f64 y x (fma.f64 z z (*.f64 z (+.f64 z z))))
Calls

8 calls:

17.0ms
y
11.0ms
z
10.0ms
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
10.0ms
x
9.0ms
(*.f64 x y)
Results
ErrorSegmentsBranch
0.0b1x
0.0b1y
0.0b1z
0.0b1(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
0.0b1(*.f64 x y)
0.0b1(*.f64 x y)
0.0b1(*.f64 z z)
0.0b1(*.f64 z z)
Compiler

Compiled 213 to 96 computations (54.9% saved)

regimes66.0ms (0.9%)

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

7 calls:

11.0ms
z
10.0ms
(*.f64 x y)
10.0ms
x
10.0ms
y
8.0ms
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
Results
ErrorSegmentsBranch
0.0b1x
0.0b1y
0.0b1z
0.0b1(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
0.0b1(*.f64 x y)
0.0b1(*.f64 z z)
0.0b1(*.f64 z z)
Compiler

Compiled 161 to 72 computations (55.3% saved)

regimes56.0ms (0.8%)

Counts
11 → 1
Calls
Call 1
Inputs
(*.f64 z z)
(*.f64 y x)
(*.f64 3 (*.f64 z z))
(*.f64 z (*.f64 z 3))
(+.f64 (*.f64 y x) (*.f64 z z))
(+.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))
(+.f64 (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))) (*.f64 z z))
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
(fma.f64 z z (*.f64 z (*.f64 z 2)))
(fma.f64 3 (*.f64 z z) (*.f64 y x))
(fma.f64 z (*.f64 z 3) (*.f64 x y))
Outputs
(+.f64 (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))) (*.f64 z z))
Calls

7 calls:

9.0ms
(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
9.0ms
(*.f64 z z)
9.0ms
y
7.0ms
x
7.0ms
z
Results
ErrorSegmentsBranch
0.1b1x
0.1b1y
0.1b1z
0.1b1(+.f64 (+.f64 (+.f64 (*.f64 x y) (*.f64 z z)) (*.f64 z z)) (*.f64 z z))
0.1b1(*.f64 x y)
0.1b1(*.f64 z z)
0.1b1(*.f64 z z)
Compiler

Compiled 135 to 61 computations (54.8% saved)

regimes35.0ms (0.5%)

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

6 calls:

7.0ms
(*.f64 x y)
6.0ms
y
5.0ms
x
5.0ms
z
5.0ms
(*.f64 z z)
Results
ErrorSegmentsBranch
0.1b1x
0.1b1y
0.1b1z
0.1b1(*.f64 x y)
0.1b1(*.f64 z z)
0.1b1(*.f64 z z)
Compiler

Compiled 65 to 37 computations (43.1% saved)

regimes75.0ms (1%)

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

4 calls:

29.0ms
y
23.0ms
z
15.0ms
x
6.0ms
(*.f64 z z)
Results
ErrorSegmentsBranch
16.6b3x
14.2b5y
7.4b5z
8.8b2(*.f64 z z)
Compiler

Compiled 44 to 24 computations (45.5% saved)

bsearch88.0ms (1.2%)

Algorithm
binary-search
Steps
TimeLeftRight
22.0ms
9.92149702785056e+50
1.8423821370299733e+53
23.0ms
-1.0093204801178489e-117
-3.946891965484816e-120
21.0ms
-1.487393591883637e-57
-5.147294753670836e-63
22.0ms
-27689.12722169995
-816.093354181578
Compiler

Compiled 24 to 13 computations (45.8% saved)

regimes101.0ms (1.4%)

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

4 calls:

39.0ms
z
26.0ms
y
18.0ms
(*.f64 z z)
15.0ms
x
Results
ErrorSegmentsBranch
18.7b3x
14.8b7y
7.9b5z
8.6b4(*.f64 z z)
Compiler

Compiled 37 to 23 computations (37.8% saved)

bsearch78.0ms (1.1%)

Algorithm
binary-search
Steps
TimeLeftRight
19.0ms
6.206492760354703e+28
9.626283370536792e+34
20.0ms
-1.0093204801178489e-117
-3.946891965484816e-120
19.0ms
-1.487393591883637e-57
-5.147294753670836e-63
20.0ms
-27689.12722169995
-816.093354181578
Compiler

Compiled 24 to 13 computations (45.8% saved)

regimes18.0ms (0.2%)

Accuracy

Total -37.3b remaining (-177.4%)

Threshold costs -37.3b (-177.4%)

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

4 calls:

6.0ms
z
4.0ms
(*.f64 z z)
3.0ms
y
3.0ms
x
Results
ErrorSegmentsBranch
22.1b1x
22.1b1y
21.0b2z
22.1b1(*.f64 z z)
Compiler

Compiled 27 to 18 computations (33.3% saved)

bsearch20.0ms (0.3%)

Algorithm
binary-search
Steps
TimeLeftRight
20.0ms
9.92149702785056e+50
1.8423821370299733e+53
Compiler

Compiled 24 to 13 computations (45.8% saved)

simplify11.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
040200
150200
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(fma.f64 y x (fma.f64 z z (*.f64 z (+.f64 z z))))
(fma.f64 z z (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))))
(+.f64 (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))) (*.f64 z z))
(+.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))
(if (<=.f64 z -951391166975877/34359738368) (*.f64 3 (*.f64 z z)) (if (<=.f64 z -1313998500994891/883423532389192164791648750371459257913741948437809479060803100646309888) (+.f64 (*.f64 y x) (*.f64 z z)) (if (<=.f64 z -5731353204486615/5678427533559428832416592249125035424637823130369672345949142181098744438385921275985867583701277855943457200048954515105739075223552) (*.f64 3 (*.f64 z z)) (if (<=.f64 z 992149702785056019401500025473471229541780912340992) (+.f64 (*.f64 y x) (*.f64 z z)) (*.f64 3 (*.f64 z z))))))
(if (<=.f64 z -951391166975877/34359738368) (*.f64 3 (*.f64 z z)) (if (<=.f64 z -1313998500994891/883423532389192164791648750371459257913741948437809479060803100646309888) (*.f64 y x) (if (<=.f64 z -5731353204486615/5678427533559428832416592249125035424637823130369672345949142181098744438385921275985867583701277855943457200048954515105739075223552) (*.f64 3 (*.f64 z z)) (if (<=.f64 z 62064927603547025911771561984) (*.f64 y x) (*.f64 3 (*.f64 z z))))))
(if (<=.f64 z 992149702785056019401500025473471229541780912340992) (*.f64 y x) (*.f64 z z))
(*.f64 z z)
Outputs
(fma.f64 y x (fma.f64 z z (*.f64 z (+.f64 z z))))
(fma.f64 z z (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))))
(fma.f64 z z (+.f64 (*.f64 z (+.f64 z z)) (*.f64 y x)))
(+.f64 (+.f64 (*.f64 x y) (*.f64 z (+.f64 z z))) (*.f64 z z))
(+.f64 (+.f64 (*.f64 z (+.f64 z z)) (*.f64 y x)) (*.f64 z z))
(+.f64 (*.f64 z (*.f64 z 3)) (*.f64 x y))
(+.f64 (*.f64 z (*.f64 z 3)) (*.f64 y x))
(if (<=.f64 z -951391166975877/34359738368) (*.f64 3 (*.f64 z z)) (if (<=.f64 z -1313998500994891/883423532389192164791648750371459257913741948437809479060803100646309888) (+.f64 (*.f64 y x) (*.f64 z z)) (if (<=.f64 z -5731353204486615/5678427533559428832416592249125035424637823130369672345949142181098744438385921275985867583701277855943457200048954515105739075223552) (*.f64 3 (*.f64 z z)) (if (<=.f64 z 992149702785056019401500025473471229541780912340992) (+.f64 (*.f64 y x) (*.f64 z z)) (*.f64 3 (*.f64 z z))))))
(if (<=.f64 z -951391166975877/34359738368) (*.f64 (*.f64 z z) 3) (if (<=.f64 z -1313998500994891/883423532389192164791648750371459257913741948437809479060803100646309888) (+.f64 (*.f64 z z) (*.f64 y x)) (if (<=.f64 z -5731353204486615/5678427533559428832416592249125035424637823130369672345949142181098744438385921275985867583701277855943457200048954515105739075223552) (*.f64 (*.f64 z z) 3) (if (<=.f64 z 992149702785056019401500025473471229541780912340992) (+.f64 (*.f64 z z) (*.f64 y x)) (*.f64 (*.f64 z z) 3)))))
(if (<=.f64 z -951391166975877/34359738368) (*.f64 3 (*.f64 z z)) (if (<=.f64 z -1313998500994891/883423532389192164791648750371459257913741948437809479060803100646309888) (*.f64 y x) (if (<=.f64 z -5731353204486615/5678427533559428832416592249125035424637823130369672345949142181098744438385921275985867583701277855943457200048954515105739075223552) (*.f64 3 (*.f64 z z)) (if (<=.f64 z 62064927603547025911771561984) (*.f64 y x) (*.f64 3 (*.f64 z z))))))
(if (<=.f64 z -951391166975877/34359738368) (*.f64 (*.f64 z z) 3) (if (<=.f64 z -1313998500994891/883423532389192164791648750371459257913741948437809479060803100646309888) (*.f64 y x) (if (<=.f64 z -5731353204486615/5678427533559428832416592249125035424637823130369672345949142181098744438385921275985867583701277855943457200048954515105739075223552) (*.f64 (*.f64 z z) 3) (if (<=.f64 z 62064927603547025911771561984) (*.f64 y x) (*.f64 (*.f64 z z) 3)))))
(if (<=.f64 z 992149702785056019401500025473471229541780912340992) (*.f64 y x) (*.f64 z z))
(*.f64 z z)
Compiler

Compiled 164 to 91 computations (44.5% saved)

soundness0.0ms (0%)

end72.0ms (1%)

Remove

(sort x y)

Compiler

Compiled 171 to 70 computations (59.1% saved)

Profiling

Loading profile data...