Details

Time bar (total: 6.2s)

analyze267.0ms (4.3%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
0%99.9%0.1%3
0%99.9%0.1%4
0%99.9%0.1%5
0%99.9%0.1%6
0%99.9%0.1%7
3.1%96.7%0.1%8
3.1%95.2%1.7%9
19.5%76.5%4%10
25.4%70.6%4%11
28.5%65.7%5.8%12
Compiler

Compiled 11 to 7 computations (36.4% saved)

sample1.1s (17.3%)

Results
959.0ms8256×body256valid
105.0ms1062×body256invalid

preprocess210.0ms (3.4%)

Algorithm
egg-herbie
Rules
2068×associate-/l/_binary64
2054×associate-/r/_binary64
1625×fma-def_binary64
408×*-commutative_binary64
372×distribute-rgt-out_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01640
14640
28240
313040
417040
519140
620232
726332
8142632
9233132
10289632
11294532
12294832
13294832
14411932
15423232
16431632
17433132
18437532
19438032
20438032
033
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
2
Call 2
Inputs
(/.f64 (*.f64 x (+.f64 y z)) z)
(/.f64 (*.f64 y (+.f64 x z)) z)
(/.f64 (*.f64 z (+.f64 y x)) x)
(/.f64 (*.f64 x (+.f64 z y)) y)
Outputs
(/.f64 (*.f64 x (+.f64 y z)) z)
(/.f64 x (/.f64 z (+.f64 y z)))
(*.f64 (/.f64 x z) (+.f64 y z))
(*.f64 (+.f64 y z) (/.f64 x z))
(*.f64 x (/.f64 (+.f64 y z) z))
(fma.f64 x (/.f64 y z) x)
(/.f64 (*.f64 y (+.f64 x z)) z)
(*.f64 (/.f64 y z) (+.f64 x z))
(*.f64 (+.f64 x z) (/.f64 y z))
(*.f64 y (/.f64 (+.f64 x z) z))
(fma.f64 x (/.f64 y z) y)
(/.f64 (*.f64 z (+.f64 y x)) x)
(/.f64 z (/.f64 x (+.f64 x y)))
(*.f64 (/.f64 z x) (+.f64 x y))
(*.f64 (+.f64 x y) (/.f64 z x))
(*.f64 z (/.f64 (+.f64 x y) x))
(fma.f64 y (/.f64 z x) z)
(fma.f64 z (/.f64 y x) z)
(/.f64 (*.f64 x (+.f64 z y)) y)
(/.f64 x (/.f64 y (+.f64 y z)))
(*.f64 (/.f64 x y) (+.f64 y z))
(*.f64 (+.f64 y z) (/.f64 x y))
(*.f64 x (/.f64 (+.f64 y z) y))
(fma.f64 z (/.f64 x y) x)
Compiler

Compiled 13 to 9 computations (30.8% saved)

simplify97.0ms (1.6%)

Algorithm
egg-herbie
Rules
772×associate-/l*_binary64
727×associate-/l/_binary64
666×fma-def_binary64
599×associate-/r/_binary64
549×associate-*l/_binary64
Iterations

Useful iterations: 6 (0.0ms)

IterNodesCost
0710
11710
22810
34110
45010
55610
6608
7758
82578
911908
1014508
1115878
1216008
1316058
1416108
1561338
1668398
1771548
1874438
1976428
2078948
Stop Event
node limit
Counts
1 → 2
Calls
Call 1
Inputs
(/.f64 (*.f64 x (+.f64 y z)) z)
Outputs
(/.f64 (*.f64 x (+.f64 y z)) z)
(*.f64 (/.f64 x z) (+.f64 y z))
(*.f64 (+.f64 y z) (/.f64 x z))
(*.f64 x (/.f64 (+.f64 y z) z))
(fma.f64 y (/.f64 x z) x)
(fma.f64 x (/.f64 y z) x)

eval0.0ms (0%)

Compiler

Compiled 16 to 8 computations (50% saved)

prune1.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.1b
Counts
3 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
3.4b
(fma.f64 x (/.f64 y z) x)
12.2b
(/.f64 (*.f64 x (+.f64 y z)) z)
Compiler

Compiled 19 to 11 computations (42.1% saved)

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 21 to 6 computations (71.4% saved)

series10.0ms (0.2%)

Counts
2 → 72
Calls

18 calls:

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

rewrite80.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
709×prod-diff_binary64
475×log-prod_binary64
349×pow-prod-down_binary64
231×pow2_binary64
204×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify272.0ms (4.4%)

Algorithm
egg-herbie
Rules
902×fma-def_binary64
789×associate-/l/_binary64
721×associate-/r/_binary64
611×*-commutative_binary64
519×distribute-rgt-out_binary64
Iterations

Useful iterations: 6 (0.0ms)

IterNodesCost
012558
123558
234558
343558
459558
577558
690498
7144498
8320498
91491498
101898498
112141498
122185498
132194498
142201498
154202498
165118498
175783498
187008498
197347498
207379498
217416498
227467498
237619498
247969498
Stop Event
node limit
Counts
184 → 123
Calls
Call 1
Inputs
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 (+.f64 y z) x)
(*.f64 z x)
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 y x)
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 z x)
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 z x)
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
(+.f64 (*.f64 z x) (*.f64 y x))
Outputs
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (+.f64 y z) (/.f64 z x))
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(*.f64 (+.f64 y z) (/.f64 x z))
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 z x)
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 y x)
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 y x)
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 y x)
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 z x)
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(*.f64 z x)
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))
(+.f64 (*.f64 z x) (*.f64 y x))
(*.f64 (+.f64 y z) x)
(*.f64 x (+.f64 y z))

localize11.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
3.2b
(fma.f64 x (/.f64 y z) x)
Compiler

Compiled 15 to 5 computations (66.7% saved)

series14.0ms (0.2%)

Counts
1 → 36
Calls

9 calls:

TimeVariablePointExpression
4.0ms
x
@-inf
(fma.f64 x (/.f64 y z) x)
3.0ms
y
@-inf
(fma.f64 x (/.f64 y z) x)
2.0ms
x
@0
(fma.f64 x (/.f64 y z) x)
1.0ms
x
@inf
(fma.f64 x (/.f64 y z) x)
1.0ms
y
@inf
(fma.f64 x (/.f64 y z) x)

rewrite69.0ms (1.1%)

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

Useful iterations: 0 (0.0ms)

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

simplify62.0ms (1%)

Algorithm
egg-herbie
Rules
152×fma-def_binary64
143×fma-neg_binary64
54×cancel-sign-sub-inv_binary64
52×distribute-rgt-in_binary64
49×associate-/l*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
016324
136324
277264
3181264
4371264
5688264
6939264
71118264
81132264
91137264
Stop Event
saturated
Counts
57 → 28
Calls
Call 1
Inputs
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
Outputs
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 y (/.f64 x z))
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 y (/.f64 x z))
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 y (/.f64 x z))
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(fma.f64 (/.f64 y z) x x)
(fma.f64 y (/.f64 x z) x)

eval51.0ms (0.8%)

Compiler

Compiled 1760 to 549 computations (68.8% saved)

prune59.0ms (0.9%)

Pruning

10 alts after pruning (8 fresh and 2 done)

PrunedKeptTotal
New1438151
Fresh000
Picked011
Done011
Total14310153
Error
0b
Counts
153 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
3.4b
(*.f64 x (/.f64 1 (/.f64 z (+.f64 y z))))
12.2b
(/.f64 (*.f64 x (+.f64 y z)) z)
13.9b
(pow.f64 (/.f64 (/.f64 z x) (+.f64 y z)) -1)
25.8b
x
3.4b
(*.f64 (+.f64 1 (/.f64 y z)) x)
41.9b
(/.f64 (/.f64 (*.f64 (-.f64 (*.f64 y y) (*.f64 z z)) x) (-.f64 y z)) z)
3.4b
(fma.f64 x (/.f64 y z) x)
41.8b
(*.f64 y (/.f64 x z))
12.3b
(*.f64 (/.f64 1 z) (*.f64 x (+.f64 y z)))
39.1b
(/.f64 (*.f64 y x) z)
Compiler

Compiled 183 to 116 computations (36.6% saved)

localize17.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
3.2b
(*.f64 (+.f64 1 (/.f64 y z)) x)
Compiler

Compiled 22 to 10 computations (54.5% saved)

series7.0ms (0.1%)

Counts
1 → 24
Calls

9 calls:

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

rewrite104.0ms (1.7%)

Algorithm
batch-egg-rewrite
Rules
893×pow1_binary64
827×add-log-exp_binary64
827×log1p-expm1-u_binary64
827×expm1-log1p-u_binary64
810×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify21.0ms (0.3%)

Algorithm
egg-herbie
Rules
27×fma-def_binary64
10×associate-*r*_binary64
associate-/r/_binary64
associate-/l*_binary64
associate-*l*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
07204
111204
215168
322168
429168
536168
646168
774168
887168
9107168
10116168
11118168
Stop Event
saturated
Counts
45 → 26
Calls
Call 1
Inputs
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
Outputs
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
7.8b
(*.f64 y (/.f64 x z))
Compiler

Compiled 14 to 5 computations (64.3% saved)

series5.0ms (0.1%)

Counts
1 → 36
Calls

9 calls:

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

rewrite84.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
681×pow1_binary64
628×add-log-exp_binary64
628×log1p-expm1-u_binary64
628×expm1-log1p-u_binary64
613×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify14.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
06252
19252
213252
316252
417252
Stop Event
saturated
Counts
58 → 23
Calls
Call 1
Inputs
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
Outputs
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
5.5b
(/.f64 (*.f64 y x) z)
Compiler

Compiled 14 to 5 computations (64.3% saved)

series2.0ms (0%)

Counts
1 → 0
Calls

9 calls:

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

rewrite54.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
712×pow1_binary64
659×add-log-exp_binary64
659×log1p-expm1-u_binary64
659×expm1-log1p-u_binary64
644×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify7.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

localize10.0ms (0.2%)

Local error

Found 3 expressions with local error:

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

Compiled 31 to 11 computations (64.5% saved)

series8.0ms (0.1%)

Counts
3 → 84
Calls

21 calls:

TimeVariablePointExpression
1.0ms
z
@0
(/.f64 z (+.f64 y z))
0.0ms
y
@inf
(/.f64 z (+.f64 y z))
0.0ms
z
@inf
(/.f64 z (+.f64 y z))
0.0ms
y
@-inf
(/.f64 z (+.f64 y z))
0.0ms
z
@-inf
(/.f64 z (+.f64 y z))

rewrite89.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
515×log-prod_binary64
482×prod-diff_binary64
332×pow-prod-down_binary64
255×pow2_binary64
199×pow-unpow_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify177.0ms (2.8%)

Algorithm
egg-herbie
Rules
784×fma-def_binary64
753×associate-/l*_binary64
555×associate-/r*_binary64
532×associate-*l/_binary64
394×associate-*r*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
042939
1110903
2315822
31374786
Stop Event
node limit
Counts
225 → 165
Calls
Call 1
Inputs
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 y z)
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
1
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
1
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
1
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
(/.f64 y z)
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
(/.f64 y z)
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
(+.f64 1 (/.f64 y z))
(/.f64 z y)
(+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))
(+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2)))))
(+.f64 (*.f64 -1 (/.f64 (pow.f64 z 4) (pow.f64 y 4))) (+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))))
1
(+.f64 (*.f64 -1 (/.f64 y z)) 1)
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (/.f64 (pow.f64 y 2) (pow.f64 z 2))))
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (+.f64 (/.f64 (pow.f64 y 2) (pow.f64 z 2)) (*.f64 -1 (/.f64 (pow.f64 y 3) (pow.f64 z 3))))))
1
(+.f64 (*.f64 -1 (/.f64 y z)) 1)
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (/.f64 (pow.f64 y 2) (pow.f64 z 2))))
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (+.f64 (/.f64 (pow.f64 y 2) (pow.f64 z 2)) (*.f64 -1 (/.f64 (pow.f64 y 3) (pow.f64 z 3))))))
1
(+.f64 (*.f64 -1 (/.f64 y z)) 1)
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (/.f64 (pow.f64 y 2) (pow.f64 z 2))))
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (+.f64 (/.f64 (pow.f64 y 2) (pow.f64 z 2)) (*.f64 -1 (/.f64 (pow.f64 y 3) (pow.f64 z 3))))))
(/.f64 z y)
(+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))
(+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2)))))
(+.f64 (*.f64 -1 (/.f64 (pow.f64 z 4) (pow.f64 y 4))) (+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))))
(/.f64 z y)
(+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))
(+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2)))))
(+.f64 (*.f64 -1 (/.f64 (pow.f64 z 4) (pow.f64 y 4))) (+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))))
Outputs
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 (+.f64 y z) x) z)
(*.f64 (/.f64 (+.f64 y z) z) x)
(*.f64 x (/.f64 (+.f64 y z) z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 (/.f64 x z) y)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 (/.f64 x z) y)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 (/.f64 x z) y)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 (/.f64 x z) y x)
(/.f64 y z)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
1
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
1
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
1
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(/.f64 y z)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(/.f64 y z)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(+.f64 1 (/.f64 y z))
(+.f64 (/.f64 y z) 1)
(/.f64 z y)
(+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))
(+.f64 (/.f64 z y) (neg.f64 (/.f64 (*.f64 z z) (*.f64 y y))))
(-.f64 (/.f64 z y) (/.f64 (*.f64 z z) (*.f64 y y)))
(-.f64 (/.f64 z y) (*.f64 (/.f64 z y) (/.f64 z y)))
(*.f64 (+.f64 (/.f64 (neg.f64 z) y) 1) (/.f64 z y))
(+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2)))))
(+.f64 (+.f64 (/.f64 z y) (neg.f64 (/.f64 (*.f64 z z) (*.f64 y y)))) (/.f64 (pow.f64 z 3) (pow.f64 y 3)))
(+.f64 (-.f64 (/.f64 z y) (/.f64 (*.f64 z z) (*.f64 y y))) (/.f64 (pow.f64 z 3) (pow.f64 y 3)))
(+.f64 (/.f64 z y) (-.f64 (pow.f64 (/.f64 z y) 3) (*.f64 (/.f64 z y) (/.f64 z y))))
(*.f64 (/.f64 z y) (-.f64 (fma.f64 (/.f64 z y) (/.f64 z y) 1) (/.f64 z y)))
(+.f64 (*.f64 -1 (/.f64 (pow.f64 z 4) (pow.f64 y 4))) (+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))))
(fma.f64 -1 (/.f64 (pow.f64 z 4) (pow.f64 y 4)) (+.f64 (+.f64 (/.f64 z y) (neg.f64 (/.f64 (*.f64 z z) (*.f64 y y)))) (/.f64 (pow.f64 z 3) (pow.f64 y 3))))
(-.f64 (+.f64 (-.f64 (/.f64 z y) (/.f64 (*.f64 z z) (*.f64 y y))) (/.f64 (pow.f64 z 3) (pow.f64 y 3))) (/.f64 (pow.f64 z 4) (pow.f64 y 4)))
(+.f64 (/.f64 z y) (-.f64 (-.f64 (pow.f64 (/.f64 z y) 3) (*.f64 (/.f64 z y) (/.f64 z y))) (/.f64 (pow.f64 z 4) (pow.f64 y 4))))
(+.f64 (/.f64 z y) (-.f64 (pow.f64 (/.f64 z y) 3) (fma.f64 (/.f64 z y) (/.f64 z y) (pow.f64 (/.f64 z y) 4))))
1
(+.f64 (*.f64 -1 (/.f64 y z)) 1)
(fma.f64 -1 (/.f64 y z) 1)
(-.f64 1 (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (/.f64 (pow.f64 y 2) (pow.f64 z 2))))
(+.f64 (fma.f64 -1 (/.f64 y z) 1) (/.f64 (*.f64 y y) (*.f64 z z)))
(+.f64 (-.f64 1 (/.f64 y z)) (*.f64 (/.f64 y z) (/.f64 y z)))
(+.f64 1 (*.f64 (/.f64 y z) (+.f64 -1 (/.f64 y z))))
(fma.f64 (/.f64 y z) (+.f64 (/.f64 y z) -1) 1)
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (+.f64 (/.f64 (pow.f64 y 2) (pow.f64 z 2)) (*.f64 -1 (/.f64 (pow.f64 y 3) (pow.f64 z 3))))))
(+.f64 (fma.f64 -1 (/.f64 y z) 1) (+.f64 (/.f64 (*.f64 y y) (*.f64 z z)) (neg.f64 (/.f64 (pow.f64 y 3) (pow.f64 z 3)))))
(+.f64 (-.f64 1 (/.f64 y z)) (-.f64 (*.f64 (/.f64 y z) (/.f64 y z)) (/.f64 (pow.f64 y 3) (pow.f64 z 3))))
(+.f64 1 (-.f64 (*.f64 (/.f64 y z) (+.f64 -1 (/.f64 y z))) (pow.f64 (/.f64 y z) 3)))
(-.f64 (fma.f64 (/.f64 y z) (+.f64 (/.f64 y z) -1) 1) (pow.f64 (/.f64 y z) 3))
1
(+.f64 (*.f64 -1 (/.f64 y z)) 1)
(fma.f64 -1 (/.f64 y z) 1)
(-.f64 1 (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (/.f64 (pow.f64 y 2) (pow.f64 z 2))))
(+.f64 (fma.f64 -1 (/.f64 y z) 1) (/.f64 (*.f64 y y) (*.f64 z z)))
(+.f64 (-.f64 1 (/.f64 y z)) (*.f64 (/.f64 y z) (/.f64 y z)))
(+.f64 1 (*.f64 (/.f64 y z) (+.f64 -1 (/.f64 y z))))
(fma.f64 (/.f64 y z) (+.f64 (/.f64 y z) -1) 1)
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (+.f64 (/.f64 (pow.f64 y 2) (pow.f64 z 2)) (*.f64 -1 (/.f64 (pow.f64 y 3) (pow.f64 z 3))))))
(+.f64 (fma.f64 -1 (/.f64 y z) 1) (+.f64 (/.f64 (*.f64 y y) (*.f64 z z)) (neg.f64 (/.f64 (pow.f64 y 3) (pow.f64 z 3)))))
(+.f64 (-.f64 1 (/.f64 y z)) (-.f64 (*.f64 (/.f64 y z) (/.f64 y z)) (/.f64 (pow.f64 y 3) (pow.f64 z 3))))
(+.f64 1 (-.f64 (*.f64 (/.f64 y z) (+.f64 -1 (/.f64 y z))) (pow.f64 (/.f64 y z) 3)))
(-.f64 (fma.f64 (/.f64 y z) (+.f64 (/.f64 y z) -1) 1) (pow.f64 (/.f64 y z) 3))
1
(+.f64 (*.f64 -1 (/.f64 y z)) 1)
(fma.f64 -1 (/.f64 y z) 1)
(-.f64 1 (/.f64 y z))
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (/.f64 (pow.f64 y 2) (pow.f64 z 2))))
(+.f64 (fma.f64 -1 (/.f64 y z) 1) (/.f64 (*.f64 y y) (*.f64 z z)))
(+.f64 (-.f64 1 (/.f64 y z)) (*.f64 (/.f64 y z) (/.f64 y z)))
(+.f64 1 (*.f64 (/.f64 y z) (+.f64 -1 (/.f64 y z))))
(fma.f64 (/.f64 y z) (+.f64 (/.f64 y z) -1) 1)
(+.f64 (*.f64 -1 (/.f64 y z)) (+.f64 1 (+.f64 (/.f64 (pow.f64 y 2) (pow.f64 z 2)) (*.f64 -1 (/.f64 (pow.f64 y 3) (pow.f64 z 3))))))
(+.f64 (fma.f64 -1 (/.f64 y z) 1) (+.f64 (/.f64 (*.f64 y y) (*.f64 z z)) (neg.f64 (/.f64 (pow.f64 y 3) (pow.f64 z 3)))))
(+.f64 (-.f64 1 (/.f64 y z)) (-.f64 (*.f64 (/.f64 y z) (/.f64 y z)) (/.f64 (pow.f64 y 3) (pow.f64 z 3))))
(+.f64 1 (-.f64 (*.f64 (/.f64 y z) (+.f64 -1 (/.f64 y z))) (pow.f64 (/.f64 y z) 3)))
(-.f64 (fma.f64 (/.f64 y z) (+.f64 (/.f64 y z) -1) 1) (pow.f64 (/.f64 y z) 3))
(/.f64 z y)
(+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))
(+.f64 (/.f64 z y) (neg.f64 (/.f64 (*.f64 z z) (*.f64 y y))))
(-.f64 (/.f64 z y) (/.f64 (*.f64 z z) (*.f64 y y)))
(-.f64 (/.f64 z y) (*.f64 (/.f64 z y) (/.f64 z y)))
(*.f64 (+.f64 (/.f64 (neg.f64 z) y) 1) (/.f64 z y))
(+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2)))))
(+.f64 (+.f64 (/.f64 z y) (neg.f64 (/.f64 (*.f64 z z) (*.f64 y y)))) (/.f64 (pow.f64 z 3) (pow.f64 y 3)))
(+.f64 (-.f64 (/.f64 z y) (/.f64 (*.f64 z z) (*.f64 y y))) (/.f64 (pow.f64 z 3) (pow.f64 y 3)))
(+.f64 (/.f64 z y) (-.f64 (pow.f64 (/.f64 z y) 3) (*.f64 (/.f64 z y) (/.f64 z y))))
(*.f64 (/.f64 z y) (-.f64 (fma.f64 (/.f64 z y) (/.f64 z y) 1) (/.f64 z y)))
(+.f64 (*.f64 -1 (/.f64 (pow.f64 z 4) (pow.f64 y 4))) (+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))))
(fma.f64 -1 (/.f64 (pow.f64 z 4) (pow.f64 y 4)) (+.f64 (+.f64 (/.f64 z y) (neg.f64 (/.f64 (*.f64 z z) (*.f64 y y)))) (/.f64 (pow.f64 z 3) (pow.f64 y 3))))
(-.f64 (+.f64 (-.f64 (/.f64 z y) (/.f64 (*.f64 z z) (*.f64 y y))) (/.f64 (pow.f64 z 3) (pow.f64 y 3))) (/.f64 (pow.f64 z 4) (pow.f64 y 4)))
(+.f64 (/.f64 z y) (-.f64 (-.f64 (pow.f64 (/.f64 z y) 3) (*.f64 (/.f64 z y) (/.f64 z y))) (/.f64 (pow.f64 z 4) (pow.f64 y 4))))
(+.f64 (/.f64 z y) (-.f64 (pow.f64 (/.f64 z y) 3) (fma.f64 (/.f64 z y) (/.f64 z y) (pow.f64 (/.f64 z y) 4))))
(/.f64 z y)
(+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))
(+.f64 (/.f64 z y) (neg.f64 (/.f64 (*.f64 z z) (*.f64 y y))))
(-.f64 (/.f64 z y) (/.f64 (*.f64 z z) (*.f64 y y)))
(-.f64 (/.f64 z y) (*.f64 (/.f64 z y) (/.f64 z y)))
(*.f64 (+.f64 (/.f64 (neg.f64 z) y) 1) (/.f64 z y))
(+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2)))))
(+.f64 (+.f64 (/.f64 z y) (neg.f64 (/.f64 (*.f64 z z) (*.f64 y y)))) (/.f64 (pow.f64 z 3) (pow.f64 y 3)))
(+.f64 (-.f64 (/.f64 z y) (/.f64 (*.f64 z z) (*.f64 y y))) (/.f64 (pow.f64 z 3) (pow.f64 y 3)))
(+.f64 (/.f64 z y) (-.f64 (pow.f64 (/.f64 z y) 3) (*.f64 (/.f64 z y) (/.f64 z y))))
(*.f64 (/.f64 z y) (-.f64 (fma.f64 (/.f64 z y) (/.f64 z y) 1) (/.f64 z y)))
(+.f64 (*.f64 -1 (/.f64 (pow.f64 z 4) (pow.f64 y 4))) (+.f64 (/.f64 (pow.f64 z 3) (pow.f64 y 3)) (+.f64 (/.f64 z y) (*.f64 -1 (/.f64 (pow.f64 z 2) (pow.f64 y 2))))))
(fma.f64 -1 (/.f64 (pow.f64 z 4) (pow.f64 y 4)) (+.f64 (+.f64 (/.f64 z y) (neg.f64 (/.f64 (*.f64 z z) (*.f64 y y)))) (/.f64 (pow.f64 z 3) (pow.f64 y 3))))
(-.f64 (+.f64 (-.f64 (/.f64 z y) (/.f64 (*.f64 z z) (*.f64 y y))) (/.f64 (pow.f64 z 3) (pow.f64 y 3))) (/.f64 (pow.f64 z 4) (pow.f64 y 4)))
(+.f64 (/.f64 z y) (-.f64 (-.f64 (pow.f64 (/.f64 z y) 3) (*.f64 (/.f64 z y) (/.f64 z y))) (/.f64 (pow.f64 z 4) (pow.f64 y 4))))
(+.f64 (/.f64 z y) (-.f64 (pow.f64 (/.f64 z y) 3) (fma.f64 (/.f64 z y) (/.f64 z y) (pow.f64 (/.f64 z y) 4))))

localize15.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 27 to 11 computations (59.3% saved)

series2.0ms (0%)

Counts
1 → 36
Calls

9 calls:

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

rewrite60.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
691×prod-diff_binary64
511×log-prod_binary64
407×pow-prod-down_binary64
256×pow2_binary64
219×fma-def_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify272.0ms (4.4%)

Algorithm
egg-herbie
Rules
904×fma-def_binary64
760×associate-/l/_binary64
676×associate-/r/_binary64
610×*-commutative_binary64
518×distribute-rgt-out_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
010324
117324
231264
346264
462264
580264
693264
7147264
8323264
91501264
101904264
112147264
122191264
132200264
142207264
154086264
165002264
175667264
186892264
197231264
207263264
217300264
227351264
237503264
247853264
257899264
267973264
Stop Event
node limit
Counts
82 → 52
Calls
Call 1
Inputs
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
(/.f64 (*.f64 (+.f64 y z) x) z)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
Outputs
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 x (/.f64 z y))
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 (+.f64 y z) x) z)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 x (/.f64 z y))
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 x (/.f64 z y))
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 (/.f64 y z) x x)
(fma.f64 x (/.f64 y z) x)
(fma.f64 y (/.f64 x z) x)

eval96.0ms (1.5%)

Compiler

Compiled 4382 to 1717 computations (60.8% saved)

prune66.0ms (1.1%)

Pruning

7 alts after pruning (5 fresh and 2 done)

PrunedKeptTotal
New3655370
Fresh303
Picked101
Done426
Total3737380
Error
0b
Counts
380 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
41.8b
(/.f64 y (/.f64 z x))
41.8b
(*.f64 y (/.f64 x z))
3.4b
(+.f64 (*.f64 (/.f64 y z) x) x)
39.1b
(/.f64 (*.f64 y x) z)
25.8b
x
40.0b
(*.f64 (/.f64 y z) x)
39.6b
(/.f64 x (/.f64 z y))
Compiler

Compiled 54 to 34 computations (37% saved)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
5.6b
(*.f64 (/.f64 y z) x)
Compiler

Compiled 14 to 5 computations (64.3% saved)

series2.0ms (0%)

Counts
1 → 36
Calls

9 calls:

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

rewrite63.0ms (1%)

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

Useful iterations: 0 (0.0ms)

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

simplify27.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
06252
19252
213252
316252
417252
Stop Event
saturated
Counts
59 → 24
Calls
Call 1
Inputs
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
Outputs
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))

localize13.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 21 to 6 computations (71.4% saved)

series5.0ms (0.1%)

Counts
1 → 36
Calls

9 calls:

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

rewrite92.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
950×pow1_binary64
884×add-log-exp_binary64
883×log1p-expm1-u_binary64
883×expm1-log1p-u_binary64
85×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify62.0ms (1%)

Algorithm
egg-herbie
Rules
152×fma-def_binary64
143×fma-neg_binary64
54×cancel-sign-sub-inv_binary64
52×distribute-rgt-in_binary64
49×associate-/l*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
016324
136324
277264
3180264
4369264
5686264
6935264
71113264
81127264
91132264
Stop Event
saturated
Counts
77 → 47
Calls
Call 1
Inputs
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(/.f64 (*.f64 y x) z)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
Outputs
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 (/.f64 x z) y)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 (/.f64 x z) y)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 (/.f64 x z) y)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
x
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(+.f64 x (/.f64 y (/.f64 z x)))
(+.f64 x (*.f64 (/.f64 y z) x))
(fma.f64 x (/.f64 y z) x)

localize15.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
5.4b
(/.f64 x (/.f64 z y))
Compiler

Compiled 14 to 5 computations (64.3% saved)

series5.0ms (0.1%)

Counts
1 → 36
Calls

9 calls:

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

rewrite86.0ms (1.4%)

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

Useful iterations: 0 (0.0ms)

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

simplify26.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
06252
19252
213252
316252
417252
Stop Event
saturated
Counts
77 → 42
Calls
Call 1
Inputs
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
Outputs
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))

localize12.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
8.2b
(/.f64 y (/.f64 z x))
Compiler

Compiled 14 to 5 computations (64.3% saved)

series5.0ms (0.1%)

Counts
1 → 36
Calls

9 calls:

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

rewrite83.0ms (1.3%)

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

Useful iterations: 0 (0.0ms)

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

simplify28.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
06252
19252
213252
316252
417252
Stop Event
saturated
Counts
77 → 42
Calls
Call 1
Inputs
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
Outputs
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(*.f64 x (/.f64 y z))
(*.f64 y (/.f64 x z))

eval59.0ms (0.9%)

Compiler

Compiled 1822 to 589 computations (67.7% saved)

prune56.0ms (0.9%)

Pruning

7 alts after pruning (1 fresh and 6 done)

PrunedKeptTotal
New1781179
Fresh101
Picked011
Done055
Total1797186
Error
0b
Counts
186 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
41.8b
(/.f64 y (/.f64 z x))
41.8b
(*.f64 y (/.f64 x z))
3.4b
(+.f64 (*.f64 (/.f64 y z) x) x)
39.1b
(/.f64 (*.f64 y x) z)
40.0b
(*.f64 (/.f64 y z) x)
39.6b
(/.f64 x (/.f64 z y))
25.8b
x
Compiler

Compiled 54 to 34 computations (37% saved)

eval0.0ms (0%)

Compiler

Compiled 3 to 3 computations (0% saved)

prune5.0ms (0.1%)

Pruning

7 alts after pruning (1 fresh and 6 done)

PrunedKeptTotal
New000
Fresh011
Picked000
Done066
Total077
Error
0b
Counts
7 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
41.8b
(/.f64 y (/.f64 z x))
41.8b
(*.f64 y (/.f64 x z))
3.4b
(+.f64 (*.f64 (/.f64 y z) x) x)
39.1b
(/.f64 (*.f64 y x) z)
40.0b
(*.f64 (/.f64 y z) x)
39.6b
(/.f64 x (/.f64 z y))
25.8b
x
Compiler

Compiled 54 to 34 computations (37% saved)

regimes184.0ms (3%)

Counts
16 → 5
Calls
Call 1
Inputs
x
x
x
(/.f64 y (/.f64 z x))
(*.f64 (/.f64 y z) x)
(/.f64 x (/.f64 z y))
(*.f64 y (/.f64 x z))
(/.f64 (*.f64 y x) z)
(+.f64 (*.f64 (/.f64 y z) x) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(/.f64 (*.f64 x (+.f64 y z)) z)
(*.f64 x (/.f64 1 (/.f64 z (+.f64 y z))))
(*.f64 (/.f64 1 z) (*.f64 x (+.f64 y z)))
(/.f64 (/.f64 (*.f64 (-.f64 (*.f64 y y) (*.f64 z z)) x) (-.f64 y z)) z)
(fma.f64 x (/.f64 y z) x)
(pow.f64 (/.f64 (/.f64 z x) (+.f64 y z)) -1)
Outputs
(+.f64 (*.f64 (/.f64 y z) x) x)
(/.f64 (*.f64 x (+.f64 y z)) z)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(/.f64 (*.f64 x (+.f64 y z)) z)
(+.f64 (*.f64 (/.f64 y z) x) x)
Calls

4 calls:

65.0ms
(/.f64 (*.f64 x (+.f64 y z)) z)
48.0ms
z
42.0ms
y
23.0ms
x
Results
ErrorSegmentsBranch
2.0b3x
2.1b2y
2.1b3z
0.1b5(/.f64 (*.f64 x (+.f64 y z)) z)
Compiler

Compiled 122 to 53 computations (56.6% saved)

bsearch1.0ms (0%)

Algorithm
left-value
Steps
TimeLeftRight
0.0ms
2.9904912395582182e+230
4.8490178843966754e+232
0.0ms
1.0212724482197026e+33
2.9481708467419615e+44
0.0ms
-1259040.0810754213
-10.9853547193232
0.0ms
-5.2086273098488043e+300
-1.0100157027265764e+290
Compiler

Compiled 16 to 11 computations (31.3% saved)

regimes32.0ms (0.5%)

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

3 calls:

16.0ms
y
7.0ms
x
6.0ms
z
Results
ErrorSegmentsBranch
3.4b1x
2.1b3y
3.4b1z
Compiler

Compiled 57 to 26 computations (54.4% saved)

bsearch10.0ms (0.2%)

Algorithm
binary-search
Steps
TimeLeftRight
4.0ms
1.2040631649688945e+261
3.7218568093670114e+261
6.0ms
7.251669748830068e+194
5.507556095360628e+201
Compiler

Compiled 56 to 37 computations (33.9% saved)

regimes61.0ms (1%)

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

3 calls:

29.0ms
x
16.0ms
y
14.0ms
z
Results
ErrorSegmentsBranch
21.6b5x
16.4b3y
17.2b3z
Compiler

Compiled 43 to 22 computations (48.8% saved)

bsearch188.0ms (3%)

Algorithm
binary-search
Steps
TimeLeftRight
130.0ms
4.738008505454273e+134
1.0302360938376571e+144
58.0ms
-2.5819125984737506e+69
-7.835948153336747e+68
Compiler

Compiled 212 to 151 computations (28.8% saved)

regimes154.0ms (2.5%)

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

3 calls:

74.0ms
x
48.0ms
z
29.0ms
y
Results
ErrorSegmentsBranch
20.7b7x
18.0b3y
16.3b5z
Compiler

Compiled 38 to 20 computations (47.4% saved)

bsearch433.0ms (7%)

Algorithm
binary-search
Steps
TimeLeftRight
198.0ms
1.637981118809714e-60
8.080979825772637e-57
65.0ms
-3.1559227891232434e-221
-3.9555455950807696e-258
75.0ms
-5.390078160890779e-196
-2.976717635612461e-198
94.0ms
-1.106136686218659e-107
-3.6620840226270315e-108
Compiler

Compiled 450 to 321 computations (28.7% saved)

regimes153.0ms (2.5%)

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

3 calls:

74.0ms
x
48.0ms
z
28.0ms
y
Results
ErrorSegmentsBranch
20.7b7x
18.0b3y
16.3b5z
Compiler

Compiled 33 to 18 computations (45.5% saved)

bsearch423.0ms (6.8%)

Algorithm
binary-search
Steps
TimeLeftRight
187.0ms
1.637981118809714e-60
8.080979825772637e-57
64.0ms
-3.1559227891232434e-221
-3.9555455950807696e-258
73.0ms
-5.390078160890779e-196
-2.976717635612461e-198
99.0ms
-1.106136686218659e-107
-3.6620840226270315e-108
Compiler

Compiled 450 to 321 computations (28.7% saved)

regimes13.0ms (0.2%)

Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0.0b (-0%)

Counts
3 → 1
Calls
Call 1
Inputs
x
x
x
Outputs
x
Calls

3 calls:

5.0ms
x
4.0ms
y
4.0ms
z
Results
ErrorSegmentsBranch
25.8b1x
25.8b1y
25.8b1z
Compiler

Compiled 18 to 12 computations (33.3% saved)

simplify10.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
058259
168259
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) -5000000000000000262523801276022101243522342905540795774579270577559012289944540978931856875402239320218522219164419390884712616176802152878223960923933534914241936004632879018689151168973940450296844766174853999725405595194838204400373263713900712472896293944100284214190578347360981934327297002700800) (+.f64 (*.f64 (/.f64 y z) x) x) (if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) -1000000) (/.f64 (*.f64 x (+.f64 y z)) z) (if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) 1999999999999999891150461974085632) (*.f64 (+.f64 1 (/.f64 y z)) x) (if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) 500000000000000028237705510260420707420313190991529187350282582077728281983789098594609880794729991489884084673768181048282990322303461938652580072801639889709891970152031159909282119041295638459799794152650876636200924348147564544) (/.f64 (*.f64 x (+.f64 y z)) z) (+.f64 (*.f64 (/.f64 y z) x) x)))))
(if (<=.f64 y 99999999999999996973312221251036165947450327545502362648241750950346848435554075534196338404706251868027512415973882408182135734368278484639385041047239877871023591066789981811181813306167128854888448) (+.f64 (*.f64 (/.f64 y z) x) x) (if (<=.f64 y 1999999999999999857547681040733515073753478641623153224463562961402940190709054988015492682882276552884948779539095127050864586233002245134357428718762445554209708921491609358759288994086416534767263294334755723897091779949617923739887142153550856217846978969600) (/.f64 (*.f64 y x) z) (+.f64 (*.f64 (/.f64 y z) x) x)))
(if (<=.f64 y -2500000000000000181328590953823087815395936024116304888795525388697600) (/.f64 (*.f64 y x) z) (if (<=.f64 y 1000000000000000023745432358651105357408657927828682187473464988670237429542020572568177628216083294129345969133840116075793413169890081573437440) x (/.f64 (*.f64 y x) z)))
(if (<=.f64 z -5024025362805889/1322111937580497197903830616065542079656809365928562438569297590548811582472622691650378420879430569695182424050046716608512) x (if (<=.f64 z -1367635334402577/2630067950774186753620494941440064332775169901411586929749140451534366077148540411056833268138794225613491484428089108856509716125091901931563907385325940424977611835564222299095831878942161358635646625867890688) (*.f64 y (/.f64 x z)) (if (<=.f64 z -8655577598126739/2163894399531684849059183759018052020301198647443953754636127064173256304872345024407213080115843841616586321892381199068702095603722999960578207655784200507016751857659924824755124296402642702553187257992033027703390323887110396882282073697349781407701150027357134841184256) x (if (<=.f64 z 1492632400324779/904625697166532776746648320380374280103671755200316906558262375061821325312) (/.f64 y (/.f64 z x)) x))))
(if (<=.f64 z -5024025362805889/1322111937580497197903830616065542079656809365928562438569297590548811582472622691650378420879430569695182424050046716608512) x (if (<=.f64 z -1367635334402577/2630067950774186753620494941440064332775169901411586929749140451534366077148540411056833268138794225613491484428089108856509716125091901931563907385325940424977611835564222299095831878942161358635646625867890688) (/.f64 y (/.f64 z x)) (if (<=.f64 z -8655577598126739/2163894399531684849059183759018052020301198647443953754636127064173256304872345024407213080115843841616586321892381199068702095603722999960578207655784200507016751857659924824755124296402642702553187257992033027703390323887110396882282073697349781407701150027357134841184256) x (if (<=.f64 z 1492632400324779/904625697166532776746648320380374280103671755200316906558262375061821325312) (/.f64 y (/.f64 z x)) x))))
x
Outputs
(if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) -5000000000000000262523801276022101243522342905540795774579270577559012289944540978931856875402239320218522219164419390884712616176802152878223960923933534914241936004632879018689151168973940450296844766174853999725405595194838204400373263713900712472896293944100284214190578347360981934327297002700800) (+.f64 (*.f64 (/.f64 y z) x) x) (if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) -1000000) (/.f64 (*.f64 x (+.f64 y z)) z) (if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) 1999999999999999891150461974085632) (*.f64 (+.f64 1 (/.f64 y z)) x) (if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) 500000000000000028237705510260420707420313190991529187350282582077728281983789098594609880794729991489884084673768181048282990322303461938652580072801639889709891970152031159909282119041295638459799794152650876636200924348147564544) (/.f64 (*.f64 x (+.f64 y z)) z) (+.f64 (*.f64 (/.f64 y z) x) x)))))
(if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) -5000000000000000262523801276022101243522342905540795774579270577559012289944540978931856875402239320218522219164419390884712616176802152878223960923933534914241936004632879018689151168973940450296844766174853999725405595194838204400373263713900712472896293944100284214190578347360981934327297002700800) (+.f64 x (*.f64 x (/.f64 y z))) (if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) -1000000) (/.f64 (*.f64 x (+.f64 y z)) z) (if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) 1999999999999999891150461974085632) (*.f64 x (+.f64 (/.f64 y z) 1)) (if (<=.f64 (/.f64 (*.f64 x (+.f64 y z)) z) 500000000000000028237705510260420707420313190991529187350282582077728281983789098594609880794729991489884084673768181048282990322303461938652580072801639889709891970152031159909282119041295638459799794152650876636200924348147564544) (/.f64 (*.f64 x (+.f64 y z)) z) (+.f64 x (*.f64 x (/.f64 y z)))))))
(if (<=.f64 y 99999999999999996973312221251036165947450327545502362648241750950346848435554075534196338404706251868027512415973882408182135734368278484639385041047239877871023591066789981811181813306167128854888448) (+.f64 (*.f64 (/.f64 y z) x) x) (if (<=.f64 y 1999999999999999857547681040733515073753478641623153224463562961402940190709054988015492682882276552884948779539095127050864586233002245134357428718762445554209708921491609358759288994086416534767263294334755723897091779949617923739887142153550856217846978969600) (/.f64 (*.f64 y x) z) (+.f64 (*.f64 (/.f64 y z) x) x)))
(if (<=.f64 y 99999999999999996973312221251036165947450327545502362648241750950346848435554075534196338404706251868027512415973882408182135734368278484639385041047239877871023591066789981811181813306167128854888448) (+.f64 x (*.f64 x (/.f64 y z))) (if (<=.f64 y 1999999999999999857547681040733515073753478641623153224463562961402940190709054988015492682882276552884948779539095127050864586233002245134357428718762445554209708921491609358759288994086416534767263294334755723897091779949617923739887142153550856217846978969600) (/.f64 (*.f64 x y) z) (+.f64 x (*.f64 x (/.f64 y z)))))
(if (<=.f64 y -2500000000000000181328590953823087815395936024116304888795525388697600) (/.f64 (*.f64 y x) z) (if (<=.f64 y 1000000000000000023745432358651105357408657927828682187473464988670237429542020572568177628216083294129345969133840116075793413169890081573437440) x (/.f64 (*.f64 y x) z)))
(if (<=.f64 y -2500000000000000181328590953823087815395936024116304888795525388697600) (/.f64 (*.f64 x y) z) (if (<=.f64 y 1000000000000000023745432358651105357408657927828682187473464988670237429542020572568177628216083294129345969133840116075793413169890081573437440) x (/.f64 (*.f64 x y) z)))
(if (<=.f64 z -5024025362805889/1322111937580497197903830616065542079656809365928562438569297590548811582472622691650378420879430569695182424050046716608512) x (if (<=.f64 z -1367635334402577/2630067950774186753620494941440064332775169901411586929749140451534366077148540411056833268138794225613491484428089108856509716125091901931563907385325940424977611835564222299095831878942161358635646625867890688) (*.f64 y (/.f64 x z)) (if (<=.f64 z -8655577598126739/2163894399531684849059183759018052020301198647443953754636127064173256304872345024407213080115843841616586321892381199068702095603722999960578207655784200507016751857659924824755124296402642702553187257992033027703390323887110396882282073697349781407701150027357134841184256) x (if (<=.f64 z 1492632400324779/904625697166532776746648320380374280103671755200316906558262375061821325312) (/.f64 y (/.f64 z x)) x))))
(if (<=.f64 z -5024025362805889/1322111937580497197903830616065542079656809365928562438569297590548811582472622691650378420879430569695182424050046716608512) x (if (<=.f64 z -1367635334402577/2630067950774186753620494941440064332775169901411586929749140451534366077148540411056833268138794225613491484428089108856509716125091901931563907385325940424977611835564222299095831878942161358635646625867890688) (/.f64 y (/.f64 z x)) (if (<=.f64 z -8655577598126739/2163894399531684849059183759018052020301198647443953754636127064173256304872345024407213080115843841616586321892381199068702095603722999960578207655784200507016751857659924824755124296402642702553187257992033027703390323887110396882282073697349781407701150027357134841184256) x (if (<=.f64 z 1492632400324779/904625697166532776746648320380374280103671755200316906558262375061821325312) (/.f64 y (/.f64 z x)) x))))
x
Compiler

Compiled 198 to 88 computations (55.6% saved)

soundness440.0ms (7.1%)

Algorithm
egg-herbie
Rules
772×associate-/l*_binary64
772×associate-/l*_binary64
727×associate-/l/_binary64
727×associate-/l/_binary64
666×fma-def_binary64
Iterations

Useful iterations: 6 (0.0ms)

IterNodesCost
0710
11710
22810
34110
45010
55610
6608
7758
82578
911908
1014508
1115878
1216008
1316058
1416108
1561338
1668398
1771548
1874438
1976428
2078948
0710
11710
22810
34110
45010
55610
6608
7758
82578
911908
1014508
1115878
1216008
1316058
1416108
1561338
1668398
1771548
1874438
1976428
2078948
Stop Event
node limit
node limit
Compiler

Compiled 198 to 116 computations (41.4% saved)

end61.0ms (1%)

Compiler

Compiled 183 to 66 computations (63.9% saved)

Profiling

Loading profile data...