Details

Time bar (total: 6.5s)

analyze249.0ms (3.8%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
0%0%99.9%0.1%0%0%0%5
0%0%99.9%0.1%0%0%0%6
0%0%99.9%0.1%0%0%0%7
3.1%3.1%96.7%0.1%0%0%0%8
3.2%3.1%95.2%0.1%1.6%0%0%9
20.3%19.5%76.5%0.1%3.9%0%0%10
26.4%25.4%70.6%0.1%3.9%0%0%11
30.2%28.5%65.7%0.1%5.7%0%0%12
Compiler

Compiled 11 to 7 computations (36.4% saved)

sample1.3s (19.2%)

Results
1.1s8256×body256valid
143.0ms1081×body256infinite
Bogosity

preprocess172.0ms (2.6%)

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)

simplify96.0ms (1.5%)

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)

eval1.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.0b
Counts
3 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
2.1b
(fma.f64 x (/.f64 y z) x)
11.0b
(/.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))
10.5b
(/.f64 (*.f64 x (+.f64 y z)) z)
Compiler

Compiled 21 to 6 computations (71.4% saved)

series11.0ms (0.2%)

Counts
2 → 72
Calls

18 calls:

TimeVariablePointExpression
2.0ms
y
@0
(/.f64 (*.f64 x (+.f64 y z)) z)
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)

rewrite72.0ms (1.1%)

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))))))

simplify305.0ms (4.7%)

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))

localize86.0ms (1.3%)

Local error

Found 1 expressions with local error:

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

Compiled 15 to 5 computations (66.7% saved)

series8.0ms (0.1%)

Counts
1 → 36
Calls

9 calls:

TimeVariablePointExpression
2.0ms
y
@-inf
(fma.f64 x (/.f64 y z) x)
1.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)
1.0ms
x
@inf
(fma.f64 x (/.f64 y z) x)

rewrite54.0ms (0.8%)

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)))))))

simplify48.0ms (0.7%)

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)

eval29.0ms (0.5%)

Compiler

Compiled 1760 to 549 computations (68.8% saved)

prune26.0ms (0.4%)

Pruning

6 alts after pruning (6 fresh and 0 done)

PrunedKeptTotal
New1456151
Fresh000
Picked101
Done101
Total1476153
Error
0b
Counts
153 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
41.0b
(*.f64 y (/.f64 x z))
39.8b
(/.f64 (*.f64 y x) z)
25.0b
x
4.2b
(+.f64 (/.f64 (*.f64 y x) z) x)
2.1b
(*.f64 (+.f64 1 (/.f64 y z)) x)
2.2b
(*.f64 x (*.f64 (+.f64 y z) (/.f64 1 z)))
Compiler

Compiled 100 to 65 computations (35% saved)

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 22 to 10 computations (54.5% saved)

series11.0ms (0.2%)

Counts
1 → 24
Calls

9 calls:

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

rewrite64.0ms (1%)

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)))))))

simplify19.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
6.4b
(*.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
z
@0
(*.f64 y (/.f64 x z))
1.0ms
x
@0
(*.f64 y (/.f64 x z))
0.0ms
y
@inf
(*.f64 y (/.f64 x z))
0.0ms
z
@-inf
(*.f64 y (/.f64 x z))

rewrite60.0ms (0.9%)

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))))))))

simplify16.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
4.2b
(/.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
@0
(/.f64 (*.f64 y x) z)

rewrite61.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)))))))

simplify14.0ms (0.2%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

localize8.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 21 to 6 computations (71.4% saved)

series3.0ms (0%)

Counts
1 → 18
Calls

9 calls:

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

rewrite69.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
970×pow1_binary64
904×add-log-exp_binary64
904×log1p-expm1-u_binary64
904×expm1-log1p-u_binary64
84×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify40.0ms (0.6%)

Algorithm
egg-herbie
Rules
151×fma-def_binary64
147×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
015144
134144
273120
3181120
4369120
5685120
6940120
71118120
81132120
91137120
Stop Event
saturated
Counts
53 → 41
Calls
Call 1
Inputs
x
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 y x) z)
(*.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))
(/.f64 (*.f64 y x) z)
x
x
Outputs
x
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 x y) z)
(*.f64 x (/.f64 y z))
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 x y) z)
(*.f64 x (/.f64 y z))
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 (+.f64 1 (/.f64 y z)) x)
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (/.f64 y z)) 1) x))
(*.f64 x (+.f64 1 (/.f64 y z)))
(fma.f64 x (/.f64 y z) x)
(/.f64 (*.f64 y x) z)
(/.f64 (*.f64 x y) z)
(*.f64 x (/.f64 y z))
x
x

localize13.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 29 to 14 computations (51.7% saved)

series5.0ms (0.1%)

Counts
2 → 60
Calls

15 calls:

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

rewrite91.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
484×log-prod_binary64
464×prod-diff_binary64
388×pow-prod-down_binary64
246×pow2_binary64
189×pow-unpow_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify253.0ms (3.9%)

Algorithm
egg-herbie
Rules
904×fma-def_binary64
797×associate-/l/_binary64
686×associate-/r/_binary64
611×*-commutative_binary64
518×distribute-rgt-out_binary64
Iterations

Useful iterations: 6 (0.0ms)

IterNodesCost
013465
123465
236465
349465
462465
580465
693405
7147405
8322405
91497405
101902405
112145405
122189405
132198405
142205405
154162405
165078405
175743405
186968405
197307405
207339405
217376405
227427405
237579405
247929405
257975405
Stop Event
node limit
Counts
138 → 87
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)
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 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))
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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x 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 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x 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 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x 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 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y 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 y (/.f64 x z) x)
(fma.f64 x (/.f64 y z) x)
1
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(/.f64 y z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(/.f64 y z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(/.f64 y z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
1
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
1
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)
(+.f64 1 (/.f64 y z))
(/.f64 (+.f64 y z) z)

eval72.0ms (1.1%)

Compiler

Compiled 2903 to 989 computations (65.9% saved)

prune44.0ms (0.7%)

Pruning

7 alts after pruning (3 fresh and 4 done)

PrunedKeptTotal
New2563259
Fresh101
Picked101
Done044
Total2587265
Error
0b
Counts
265 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
41.0b
(*.f64 y (/.f64 x z))
39.8b
(/.f64 (*.f64 y x) z)
39.3b
(*.f64 (/.f64 y z) x)
2.1b
(*.f64 (+.f64 1 (/.f64 y z)) x)
25.0b
x
39.3b
(*.f64 x (*.f64 y (/.f64 1 z)))
4.2b
(+.f64 (/.f64 (*.f64 y x) z) x)
Compiler

Compiled 58 to 38 computations (34.5% saved)

localize10.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.2b
(*.f64 y (/.f64 1 z))
5.0b
(*.f64 x (*.f64 y (/.f64 1 z)))
Compiler

Compiled 22 to 13 computations (40.9% saved)

series5.0ms (0.1%)

Counts
2 → 60
Calls

15 calls:

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

rewrite67.0ms (1%)

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

Useful iterations: 0 (0.0ms)

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

simplify17.0ms (0.3%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
07348
110348
213348
316348
417348
Stop Event
saturated
Counts
100 → 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)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y 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))
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)
(/.f64 y z)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
5.0b
(*.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
y
@inf
(*.f64 (/.f64 y z) x)
0.0ms
z
@-inf
(*.f64 (/.f64 y z) x)
0.0ms
x
@0
(*.f64 (/.f64 y z) x)
0.0ms
y
@-inf
(*.f64 (/.f64 y z) x)

rewrite53.0ms (0.8%)

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)))))))

simplify13.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
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))

eval17.0ms (0.3%)

Compiler

Compiled 519 to 228 computations (56.1% saved)

prune14.0ms (0.2%)

Pruning

7 alts after pruning (2 fresh and 5 done)

PrunedKeptTotal
New65166
Fresh011
Picked011
Done145
Total66773
Error
0b
Counts
73 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
41.0b
(*.f64 y (/.f64 x z))
39.8b
(/.f64 (*.f64 y x) z)
39.3b
(*.f64 (/.f64 y z) x)
2.1b
(*.f64 (+.f64 1 (/.f64 y z)) x)
25.0b
x
39.3b
(/.f64 x (/.f64 z y))
4.2b
(+.f64 (/.f64 (*.f64 y x) z) x)
Compiler

Compiled 56 to 36 computations (35.7% saved)

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 14 to 5 computations (64.3% saved)

series2.0ms (0%)

Counts
1 → 36
Calls

9 calls:

TimeVariablePointExpression
0.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
z
@-inf
(/.f64 x (/.f64 z y))

rewrite107.0ms (1.6%)

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))))))))

simplify17.0ms (0.3%)

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))

eval7.0ms (0.1%)

Compiler

Compiled 401 to 153 computations (61.8% saved)

prune13.0ms (0.2%)

Pruning

7 alts after pruning (1 fresh and 6 done)

PrunedKeptTotal
New42042
Fresh011
Picked011
Done055
Total42749
Error
0b
Counts
49 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
41.0b
(*.f64 y (/.f64 x z))
39.8b
(/.f64 (*.f64 y x) z)
39.3b
(*.f64 (/.f64 y z) x)
2.1b
(*.f64 (+.f64 1 (/.f64 y z)) x)
25.0b
x
39.3b
(/.f64 x (/.f64 z y))
4.2b
(+.f64 (/.f64 (*.f64 y x) z) x)
Compiler

Compiled 56 to 36 computations (35.7% saved)

regimes102.0ms (1.6%)

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

4 calls:

60.0ms
(/.f64 (*.f64 x (+.f64 y z)) z)
21.0ms
z
9.0ms
x
8.0ms
y
Results
ErrorSegmentsBranch
2.1b1x
2.1b1y
0.8b3z
0.8b3(/.f64 (*.f64 x (+.f64 y z)) z)
Compiler

Compiled 90 to 42 computations (53.3% saved)

bsearch21.0ms (0.3%)

Algorithm
binary-search
Steps
TimeLeftRight
9.0ms
1.162399423345765e-219
1.2022083660181407e-216
12.0ms
-1.1286901233761418e-70
-7.760740763160586e-77
Compiler

Compiled 59 to 39 computations (33.9% saved)

regimes56.0ms (0.8%)

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

4 calls:

20.0ms
z
18.0ms
(/.f64 (*.f64 x (+.f64 y z)) z)
7.0ms
y
7.0ms
x
Results
ErrorSegmentsBranch
2.1b1x
2.1b1y
0.8b3z
0.8b3(/.f64 (*.f64 x (+.f64 y z)) z)
Compiler

Compiled 84 to 41 computations (51.2% saved)

bsearch19.0ms (0.3%)

Algorithm
binary-search
Steps
TimeLeftRight
6.0ms
1.162399423345765e-219
1.2022083660181407e-216
13.0ms
-1.1286901233761418e-70
-7.760740763160586e-77
Compiler

Compiled 60 to 41 computations (31.7% saved)

regimes42.0ms (0.6%)

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

3 calls:

28.0ms
z
6.0ms
x
6.0ms
y
Results
ErrorSegmentsBranch
4.2b1x
4.2b1y
4.2b1z
Compiler

Compiled 51 to 25 computations (51% saved)

regimes75.0ms (1.2%)

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

3 calls:

37.0ms
x
23.0ms
z
14.0ms
y
Results
ErrorSegmentsBranch
20.2b7x
16.9b3y
13.5b5z
Compiler

Compiled 44 to 24 computations (45.5% saved)

bsearch224.0ms (3.4%)

Algorithm
binary-search
Steps
TimeLeftRight
18.0ms
1.8530160075359368e+70
2.823610324191786e+70
17.0ms
5.001782469883468e+25
4.1281161425676926e+27
111.0ms
1.0957014740819257e-40
2.8377568240634264e-35
78.0ms
-8.143699823974242e-82
-6.1419558175496435e-83
Compiler

Compiled 226 to 161 computations (28.8% saved)

regimes183.0ms (2.8%)

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

3 calls:

119.0ms
x
34.0ms
z
28.0ms
y
Results
ErrorSegmentsBranch
20.7b7x
17.6b3y
13.9b5z
Compiler

Compiled 32 to 18 computations (43.8% saved)

bsearch483.0ms (7.4%)

Algorithm
binary-search
Steps
TimeLeftRight
36.0ms
1.8530160075359368e+70
2.823610324191786e+70
30.0ms
5.001782469883468e+25
4.1281161425676926e+27
256.0ms
1.0957014740819257e-40
2.8377568240634264e-35
161.0ms
-8.143699823974242e-82
-6.1419558175496435e-83
Compiler

Compiled 226 to 161 computations (28.8% saved)

regimes183.0ms (2.8%)

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

3 calls:

94.0ms
x
45.0ms
z
41.0ms
y
Results
ErrorSegmentsBranch
20.7b7x
17.1b5y
14.2b5z
Compiler

Compiled 27 to 16 computations (40.7% saved)

bsearch587.0ms (9%)

Algorithm
binary-search
Steps
TimeLeftRight
28.0ms
1.8530160075359368e+70
2.823610324191786e+70
34.0ms
5.001782469883468e+25
4.1281161425676926e+27
260.0ms
1.0957014740819257e-40
2.8377568240634264e-35
264.0ms
-1.1915673025757525e-115
-1.4613392001296791e-124
Compiler

Compiled 268 to 191 computations (28.7% saved)

regimes81.0ms (1.2%)

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

3 calls:

45.0ms
x
17.0ms
y
17.0ms
z
Results
ErrorSegmentsBranch
20.7b7x
17.1b5y
14.2b5z
Compiler

Compiled 22 to 14 computations (36.4% saved)

bsearch260.0ms (4%)

Algorithm
binary-search
Steps
TimeLeftRight
18.0ms
1.8530160075359368e+70
2.823610324191786e+70
18.0ms
5.001782469883468e+25
4.1281161425676926e+27
113.0ms
1.690804077753513e-47
3.806352930721228e-42
110.0ms
-1.1915673025757525e-115
-1.4613392001296791e-124
Compiler

Compiled 268 to 191 computations (28.7% saved)

regimes12.0ms (0.2%)

Accuracy

Total 0.0b remaining (0%)

Threshold costs 0.0b (0%)

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

3 calls:

4.0ms
y
3.0ms
z
3.0ms
x
Results
ErrorSegmentsBranch
25.0b1x
25.0b1y
25.0b1z
Compiler

Compiled 17 to 12 computations (29.4% saved)

simplify12.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
047257
155257
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(if (<=.f64 z -1018517988167243/1018517988167243043134222844204689080525734196832968125318070224677190649881668353091698688) (fma.f64 x (/.f64 y z) x) (if (<=.f64 z 3974446316289815/397444631628981487398138749046400654145762820381874332451597321734669043887712482900704872660133498355324859058465554740779924491293392484209737542410542371636340473861337575820867913121689201875267327793591416000228568794576910811136) (+.f64 (/.f64 (*.f64 y x) z) x) (*.f64 (+.f64 1 (/.f64 y z)) x)))
(if (<=.f64 z -1018517988167243/1018517988167243043134222844204689080525734196832968125318070224677190649881668353091698688) (*.f64 (+.f64 1 (/.f64 y z)) x) (if (<=.f64 z 3974446316289815/397444631628981487398138749046400654145762820381874332451597321734669043887712482900704872660133498355324859058465554740779924491293392484209737542410542371636340473861337575820867913121689201875267327793591416000228568794576910811136) (+.f64 (/.f64 (*.f64 y x) z) x) (*.f64 (+.f64 1 (/.f64 y z)) x)))
(+.f64 (/.f64 (*.f64 y x) z) x)
(if (<=.f64 z -8475596558534171/136703170298938245273281389194851335334573089430825777276610662900622062449960995201469573563940864) x (if (<=.f64 z 5394384303847929/49039857307708443467467104868809893875799651909875269632) (/.f64 (*.f64 y x) z) (if (<=.f64 z 50017824698834678412476416) x (if (<=.f64 z 18530160075359368006158937631205854243906515774855473605896693755150336) (/.f64 x (/.f64 z y)) x))))
(if (<=.f64 z -8475596558534171/136703170298938245273281389194851335334573089430825777276610662900622062449960995201469573563940864) x (if (<=.f64 z 5394384303847929/49039857307708443467467104868809893875799651909875269632) (*.f64 y (/.f64 x z)) (if (<=.f64 z 50017824698834678412476416) x (if (<=.f64 z 18530160075359368006158937631205854243906515774855473605896693755150336) (/.f64 x (/.f64 z y)) x))))
(if (<=.f64 z -3572557697657767/23817051317718446589520242536874132581700120107002038199303870846751188192899823151552628349788604516295066307994130118526061826166445047808) x (if (<=.f64 z 5394384303847929/49039857307708443467467104868809893875799651909875269632) (*.f64 (/.f64 y z) x) (if (<=.f64 z 50017824698834678412476416) x (if (<=.f64 z 18530160075359368006158937631205854243906515774855473605896693755150336) (/.f64 x (/.f64 z y)) x))))
(if (<=.f64 z -3572557697657767/23817051317718446589520242536874132581700120107002038199303870846751188192899823151552628349788604516295066307994130118526061826166445047808) x (if (<=.f64 z 3496697184307563/205688069665150755269371147819668813122841983204197482918576128) (/.f64 x (/.f64 z y)) (if (<=.f64 z 50017824698834678412476416) x (if (<=.f64 z 18530160075359368006158937631205854243906515774855473605896693755150336) (/.f64 x (/.f64 z y)) x))))
x
Outputs
(if (<=.f64 z -1018517988167243/1018517988167243043134222844204689080525734196832968125318070224677190649881668353091698688) (fma.f64 x (/.f64 y z) x) (if (<=.f64 z 3974446316289815/397444631628981487398138749046400654145762820381874332451597321734669043887712482900704872660133498355324859058465554740779924491293392484209737542410542371636340473861337575820867913121689201875267327793591416000228568794576910811136) (+.f64 (/.f64 (*.f64 y x) z) x) (*.f64 (+.f64 1 (/.f64 y z)) x)))
(if (<=.f64 z -1018517988167243/1018517988167243043134222844204689080525734196832968125318070224677190649881668353091698688) (fma.f64 x (/.f64 y z) x) (if (<=.f64 z 3974446316289815/397444631628981487398138749046400654145762820381874332451597321734669043887712482900704872660133498355324859058465554740779924491293392484209737542410542371636340473861337575820867913121689201875267327793591416000228568794576910811136) (+.f64 x (/.f64 (*.f64 x y) z)) (*.f64 x (+.f64 (/.f64 y z) 1))))
(if (<=.f64 z -1018517988167243/1018517988167243043134222844204689080525734196832968125318070224677190649881668353091698688) (*.f64 (+.f64 1 (/.f64 y z)) x) (if (<=.f64 z 3974446316289815/397444631628981487398138749046400654145762820381874332451597321734669043887712482900704872660133498355324859058465554740779924491293392484209737542410542371636340473861337575820867913121689201875267327793591416000228568794576910811136) (+.f64 (/.f64 (*.f64 y x) z) x) (*.f64 (+.f64 1 (/.f64 y z)) x)))
(if (<=.f64 z -1018517988167243/1018517988167243043134222844204689080525734196832968125318070224677190649881668353091698688) (*.f64 x (+.f64 (/.f64 y z) 1)) (if (<=.f64 z 3974446316289815/397444631628981487398138749046400654145762820381874332451597321734669043887712482900704872660133498355324859058465554740779924491293392484209737542410542371636340473861337575820867913121689201875267327793591416000228568794576910811136) (+.f64 x (/.f64 (*.f64 x y) z)) (*.f64 x (+.f64 (/.f64 y z) 1))))
(+.f64 (/.f64 (*.f64 y x) z) x)
(+.f64 x (/.f64 (*.f64 x y) z))
(if (<=.f64 z -8475596558534171/136703170298938245273281389194851335334573089430825777276610662900622062449960995201469573563940864) x (if (<=.f64 z 5394384303847929/49039857307708443467467104868809893875799651909875269632) (/.f64 (*.f64 y x) z) (if (<=.f64 z 50017824698834678412476416) x (if (<=.f64 z 18530160075359368006158937631205854243906515774855473605896693755150336) (/.f64 x (/.f64 z y)) x))))
(if (<=.f64 z -8475596558534171/136703170298938245273281389194851335334573089430825777276610662900622062449960995201469573563940864) x (if (<=.f64 z 5394384303847929/49039857307708443467467104868809893875799651909875269632) (/.f64 (*.f64 x y) z) (if (<=.f64 z 50017824698834678412476416) x (if (<=.f64 z 18530160075359368006158937631205854243906515774855473605896693755150336) (/.f64 x (/.f64 z y)) x))))
(if (<=.f64 z -8475596558534171/136703170298938245273281389194851335334573089430825777276610662900622062449960995201469573563940864) x (if (<=.f64 z 5394384303847929/49039857307708443467467104868809893875799651909875269632) (*.f64 y (/.f64 x z)) (if (<=.f64 z 50017824698834678412476416) x (if (<=.f64 z 18530160075359368006158937631205854243906515774855473605896693755150336) (/.f64 x (/.f64 z y)) x))))
(if (<=.f64 z -3572557697657767/23817051317718446589520242536874132581700120107002038199303870846751188192899823151552628349788604516295066307994130118526061826166445047808) x (if (<=.f64 z 5394384303847929/49039857307708443467467104868809893875799651909875269632) (*.f64 (/.f64 y z) x) (if (<=.f64 z 50017824698834678412476416) x (if (<=.f64 z 18530160075359368006158937631205854243906515774855473605896693755150336) (/.f64 x (/.f64 z y)) x))))
(if (<=.f64 z -3572557697657767/23817051317718446589520242536874132581700120107002038199303870846751188192899823151552628349788604516295066307994130118526061826166445047808) x (if (<=.f64 z 5394384303847929/49039857307708443467467104868809893875799651909875269632) (*.f64 x (/.f64 y z)) (if (<=.f64 z 50017824698834678412476416) x (if (<=.f64 z 18530160075359368006158937631205854243906515774855473605896693755150336) (/.f64 x (/.f64 z y)) x))))
(if (<=.f64 z -3572557697657767/23817051317718446589520242536874132581700120107002038199303870846751188192899823151552628349788604516295066307994130118526061826166445047808) x (if (<=.f64 z 3496697184307563/205688069665150755269371147819668813122841983204197482918576128) (/.f64 x (/.f64 z y)) (if (<=.f64 z 50017824698834678412476416) x (if (<=.f64 z 18530160075359368006158937631205854243906515774855473605896693755150336) (/.f64 x (/.f64 z y)) x))))
x
Compiler

Compiled 205 to 119 computations (42% saved)

soundness454.0ms (6.9%)

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)

end109.0ms (1.7%)

Compiler

Compiled 184 to 82 computations (55.4% saved)

Profiling

Loading profile data...