Details

Time bar (total: 5.9s)

analyze1.4s (24.2%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.8%0.2%0
0%99.8%0.2%1
0%99.8%0.2%2
0%99.8%0.2%3
0%99.8%0.2%4
0%99.8%0.2%5
0%99.8%0.2%6
0%99.8%0.2%7
0%99.8%0.2%8
0%99.8%0.2%9
0%99.8%0.2%10
9.4%90.4%0.2%11
15.2%84.6%0.2%12
21.6%77.8%0.5%13
25.2%74.2%0.6%14
Compiler

Compiled 20 to 14 computations (30% saved)

sample1.8s (31.5%)

Results
1.3s8256×body128valid
483.0ms3212×body128invalid

preprocess40.0ms (0.7%)

Algorithm
egg-herbie
Rules
447×distribute-neg-frac_binary64
318×sub-neg_binary64
281×div-sub_binary64
279×fma-def_binary64
225×associate-/l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
043154
1122154
2290154
3609154
41387133
53618133
044
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
1
2
3
Outputs
0
1
2
3
Call 2
Inputs
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
(+.f64 (-.f64 y (/.f64 x (*.f64 z 3))) (/.f64 t (*.f64 (*.f64 z 3) x)))
(+.f64 (-.f64 z (/.f64 y (*.f64 x 3))) (/.f64 t (*.f64 (*.f64 x 3) y)))
(+.f64 (-.f64 t (/.f64 y (*.f64 z 3))) (/.f64 x (*.f64 (*.f64 z 3) y)))
(+.f64 (-.f64 x (/.f64 z (*.f64 y 3))) (/.f64 t (*.f64 (*.f64 y 3) z)))
(+.f64 (-.f64 x (/.f64 t (*.f64 z 3))) (/.f64 y (*.f64 (*.f64 z 3) t)))
(+.f64 (-.f64 x (/.f64 y (*.f64 t 3))) (/.f64 z (*.f64 (*.f64 t 3) y)))
Outputs
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 y (*.f64 z 3))))
(+.f64 (+.f64 x (*.f64 -1/3 (/.f64 y z))) (/.f64 t (*.f64 y (*.f64 z 3))))
(+.f64 x (*.f64 -1/3 (-.f64 (/.f64 y z) (/.f64 t (*.f64 y z)))))
(+.f64 (-.f64 y (/.f64 x (*.f64 z 3))) (/.f64 t (*.f64 (*.f64 z 3) x)))
(+.f64 (-.f64 y (/.f64 x (*.f64 z 3))) (/.f64 t (*.f64 x (*.f64 z 3))))
(+.f64 y (-.f64 (/.f64 t (*.f64 z (*.f64 x 3))) (/.f64 x (*.f64 z 3))))
(+.f64 y (*.f64 -1/3 (-.f64 (/.f64 x z) (/.f64 (/.f64 t x) z))))
(+.f64 (-.f64 z (/.f64 y (*.f64 x 3))) (/.f64 t (*.f64 (*.f64 x 3) y)))
(+.f64 (-.f64 z (/.f64 y (*.f64 x 3))) (/.f64 t (*.f64 x (*.f64 y 3))))
(+.f64 (-.f64 z (/.f64 y (*.f64 x 3))) (/.f64 (/.f64 t y) (*.f64 x 3)))
(+.f64 (-.f64 z (/.f64 y (*.f64 x 3))) (/.f64 (/.f64 t 3) (*.f64 x y)))
(+.f64 z (*.f64 -1/3 (-.f64 (/.f64 y x) (/.f64 t (*.f64 x y)))))
(+.f64 (-.f64 t (/.f64 y (*.f64 z 3))) (/.f64 x (*.f64 (*.f64 z 3) y)))
(+.f64 (-.f64 t (/.f64 y (*.f64 z 3))) (/.f64 x (*.f64 y (*.f64 z 3))))
(+.f64 t (+.f64 (/.f64 x (*.f64 y (*.f64 z 3))) (*.f64 -1/3 (/.f64 y z))))
(+.f64 t (*.f64 -1/3 (-.f64 (/.f64 y z) (/.f64 x (*.f64 y z)))))
(+.f64 (-.f64 x (/.f64 z (*.f64 y 3))) (/.f64 t (*.f64 (*.f64 y 3) z)))
(+.f64 (/.f64 t (*.f64 y (*.f64 z 3))) (-.f64 x (/.f64 z (*.f64 y 3))))
(+.f64 x (*.f64 -1/3 (-.f64 (/.f64 z y) (/.f64 t (*.f64 y z)))))
(+.f64 (-.f64 x (/.f64 t (*.f64 z 3))) (/.f64 y (*.f64 (*.f64 z 3) t)))
(+.f64 (-.f64 x (/.f64 t (*.f64 z 3))) (/.f64 y (*.f64 z (*.f64 3 t))))
(+.f64 (-.f64 x (/.f64 t (*.f64 z 3))) (/.f64 (/.f64 (/.f64 y 3) t) z))
(+.f64 (*.f64 -1/3 (/.f64 t z)) (-.f64 x (*.f64 -1/3 (/.f64 y (*.f64 z t)))))
(+.f64 x (*.f64 -1/3 (-.f64 (/.f64 t z) (/.f64 y (*.f64 z t)))))
(+.f64 (-.f64 x (/.f64 y (*.f64 t 3))) (/.f64 z (*.f64 (*.f64 t 3) y)))
(+.f64 (-.f64 x (/.f64 y (*.f64 3 t))) (/.f64 z (*.f64 y (*.f64 3 t))))
(+.f64 (-.f64 x (/.f64 (/.f64 y 3) t)) (/.f64 z (*.f64 3 (*.f64 t y))))
(+.f64 (-.f64 x (/.f64 (/.f64 y 3) t)) (/.f64 z (*.f64 t (*.f64 y 3))))
(+.f64 (+.f64 x (*.f64 -1/3 (/.f64 y t))) (/.f64 z (*.f64 y (*.f64 3 t))))
(+.f64 x (*.f64 -1/3 (-.f64 (/.f64 y t) (/.f64 z (*.f64 y t)))))
Compiler

Compiled 19 to 13 computations (31.6% saved)

simplify35.0ms (0.6%)

Algorithm
egg-herbie
Rules
587×div-sub_binary64
387×fma-def_binary64
326×fma-neg_binary64
244×distribute-neg-frac_binary64
227×associate-/l*_binary64
Iterations

Useful iterations: 6 (0.0ms)

IterNodesCost
01222
12522
25922
311622
425520
555216
6123814
7348214
8471614
Stop Event
node limit
Counts
1 → 2
Calls
Call 1
Inputs
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
Outputs
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 y (*.f64 z 3))))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 (/.f64 t y) z) 3))
(+.f64 (+.f64 x (*.f64 -1/3 (/.f64 y z))) (/.f64 t (*.f64 y (*.f64 z 3))))
(+.f64 x (fma.f64 -1/3 (/.f64 y z) (/.f64 t (*.f64 y (*.f64 z 3)))))
(+.f64 x (*.f64 (/.f64 -1/3 z) (-.f64 y (/.f64 t y))))
(fma.f64 (/.f64 -1/3 z) (-.f64 y (/.f64 t y)) x)

eval1.0ms (0%)

Compiler

Compiled 29 to 18 computations (37.9% saved)

prune2.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

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

Compiled 66 to 44 computations (33.3% saved)

localize8.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(/.f64 y (*.f64 z 3))
0.4b
(*.f64 (*.f64 z 3) y)
5.3b
(/.f64 t (*.f64 (*.f64 z 3) y))

series21.0ms (0.4%)

Counts
3 → 84
Calls

21 calls:

TimeVariablePointExpression
5.0ms
z
@0
(/.f64 y (*.f64 z 3))
3.0ms
t
@0
(/.f64 t (*.f64 (*.f64 z 3) y))
2.0ms
y
@0
(/.f64 t (*.f64 (*.f64 z 3) y))
1.0ms
t
@inf
(/.f64 t (*.f64 (*.f64 z 3) y))
1.0ms
z
@0
(/.f64 t (*.f64 (*.f64 z 3) y))

rewrite55.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
601×log-prod_binary64
182×expm1-udef_binary64
182×log1p-udef_binary64
158×log-div_binary64
152×log-pow_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0924
119624
2281224
Stop Event
node limit
Counts
3 → 107
Calls
Call 1
Inputs
(/.f64 t (*.f64 (*.f64 z 3) y))
(*.f64 (*.f64 z 3) y)
(/.f64 y (*.f64 z 3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 t (/.f64 (/.f64 1/3 z) y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 t) (/.f64 (/.f64 1/3 z) y))) (cbrt.f64 (pow.f64 (exp.f64 t) (/.f64 (/.f64 1/3 z) y))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 t) (/.f64 (/.f64 1/3 z) y)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 t) (/.f64 (/.f64 1/3 z) y)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 t) (/.f64 (/.f64 1/3 z) y)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 t (/.f64 (/.f64 1/3 z) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 t (/.f64 (/.f64 1/3 z) y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))) (pow.f64 (cbrt.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))) 2) (cbrt.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 t) 2) (*.f64 (cbrt.f64 t) (/.f64 (/.f64 1/3 z) y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))) (sqrt.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 t) (*.f64 (sqrt.f64 t) (/.f64 (/.f64 1/3 z) y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 t) (/.f64 1 (*.f64 y (*.f64 z -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/3 z) (/.f64 t y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (/.f64 1/3 z) y) t)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 t (/.f64 1/3 z)) (/.f64 1 y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 z) (/.f64 t (*.f64 3 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 t) 2) z) (/.f64 (cbrt.f64 t) (*.f64 3 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 t) z) (/.f64 (sqrt.f64 t) (*.f64 3 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 t) 2) (*.f64 z 3)) (/.f64 (cbrt.f64 t) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 t) (*.f64 z 3)) (/.f64 (sqrt.f64 t) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 t) y) (/.f64 (sqrt.f64 t) (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 t) 2) y) (/.f64 (cbrt.f64 t) (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 t) 2) 1) (/.f64 (cbrt.f64 t) (*.f64 z (*.f64 3 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 t) 1) (/.f64 (sqrt.f64 t) (*.f64 z (*.f64 3 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (*.f64 z (*.f64 3 y))) 2)) (/.f64 t (cbrt.f64 (*.f64 z (*.f64 3 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 t) 2) (pow.f64 (cbrt.f64 (*.f64 z (*.f64 3 y))) 2)) (cbrt.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 t) (pow.f64 (cbrt.f64 (*.f64 z (*.f64 3 y))) 2)) (/.f64 (sqrt.f64 t) (cbrt.f64 (*.f64 z (*.f64 3 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (*.f64 z (*.f64 3 y)))) (/.f64 t (sqrt.f64 (*.f64 z (*.f64 3 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 t) 2) (sqrt.f64 (*.f64 z (*.f64 3 y)))) (/.f64 (cbrt.f64 t) (sqrt.f64 (*.f64 z (*.f64 3 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 z (/.f64 t (*.f64 3 y))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 t (*.f64 y (*.f64 z -3))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 t) (/.f64 (/.f64 1/3 z) y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 t 3) (pow.f64 (*.f64 z (*.f64 3 y)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 t (/.f64 (/.f64 1/3 z) y))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 z (*.f64 3 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 z) (*.f64 3 y))) (cbrt.f64 (pow.f64 (exp.f64 z) (*.f64 3 y))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 z) (*.f64 3 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 z) (*.f64 3 y)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 z) (*.f64 3 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 z (*.f64 3 y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 z (*.f64 3 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 z (*.f64 3 y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 z (*.f64 3 y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 z (*.f64 3 y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 z (*.f64 3 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 z) (*.f64 3 y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 z (*.f64 3 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 z (*.f64 3 y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (*.f64 z 3) 3) (pow.f64 y 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 y 3) (pow.f64 (*.f64 z 3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 z (*.f64 3 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 z (*.f64 3 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 z (*.f64 3 y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 z (*.f64 3 y))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 y (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (cbrt.f64 (exp.f64 (/.f64 y z)))) (cbrt.f64 (cbrt.f64 (exp.f64 (/.f64 y z)))))) (log.f64 (cbrt.f64 (cbrt.f64 (exp.f64 (/.f64 y z))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (cbrt.f64 (exp.f64 (/.f64 y z))))) (log.f64 (sqrt.f64 (cbrt.f64 (exp.f64 (/.f64 y z))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 y (/.f64 1/3 z)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 y (/.f64 1/3 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y (/.f64 1/3 z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 y (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 z))) (pow.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 z))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 z))) 2) (cbrt.f64 (*.f64 y (/.f64 1/3 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 y (/.f64 1/3 z))) (sqrt.f64 (*.f64 y (/.f64 1/3 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 y) (/.f64 1 (*.f64 z -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/3 z) y)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 y z) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/3 (/.f64 y z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 z) (/.f64 y 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (*.f64 (*.f64 z z) 9))) (/.f64 y (cbrt.f64 (*.f64 z 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (*.f64 z 3))) (/.f64 y (sqrt.f64 (*.f64 z 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) z) (/.f64 (cbrt.f64 y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) z) (/.f64 (sqrt.f64 y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) 3) (/.f64 (sqrt.f64 y) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) 3) (/.f64 (cbrt.f64 y) z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) 1) (/.f64 (cbrt.f64 y) (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) 1) (/.f64 (sqrt.f64 y) (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 (*.f64 (*.f64 z z) 9))) (cbrt.f64 (*.f64 y (/.f64 1/3 z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) (cbrt.f64 (*.f64 (*.f64 z z) 9))) (/.f64 (sqrt.f64 y) (cbrt.f64 (*.f64 z 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (sqrt.f64 (*.f64 z 3))) (/.f64 (cbrt.f64 y) (sqrt.f64 (*.f64 z 3))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (/.f64 1/3 z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (/.f64 1/3 z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 y (/.f64 1/3 z))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (/.f64 z y)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 y (*.f64 z -3)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (/.f64 1/3 z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (cbrt.f64 (exp.f64 (/.f64 y z))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 y (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (/.f64 1/3 z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 y 3) (pow.f64 (*.f64 z 3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (/.f64 1/3 z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (/.f64 1/3 z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 y (/.f64 1/3 z))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (/.f64 1/3 z))))))))

simplify27.0ms (0.5%)

Algorithm
egg-herbie
Rules
16×associate-/l*_binary64
12×*-commutative_binary64
11×associate-*r/_binary64
associate-/r/_binary64
associate-*l/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
012696
124696
253696
382696
4107696
5109696
Stop Event
saturated
Counts
191 → 111
Calls
Call 1
Inputs
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 3 (*.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
(*.f64 1/3 (/.f64 y z))
Outputs
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 1/3 t) (*.f64 y z))
(/.f64 1/3 (/.f64 y (/.f64 t z)))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 3 (*.f64 y z))
(*.f64 (*.f64 y z) 3)
(*.f64 y (*.f64 z 3))
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)
(*.f64 1/3 (/.f64 y z))
(*.f64 (/.f64 1/3 z) y)

eval45.0ms (0.8%)

Compiler

Compiled 2213 to 1391 computations (37.1% saved)

prune217.0ms (3.7%)

Pruning

11 alts after pruning (11 fresh and 0 done)

PrunedKeptTotal
New10011111
Fresh101
Picked101
Done000
Total10211113
Error
0b
Counts
113 → 11
Alt Table
Click to see full alt table
StatusErrorProgram
7.6b
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 (*.f64 (*.f64 z z) 9))) (cbrt.f64 (*.f64 y (/.f64 1/3 z))))) (/.f64 t (*.f64 (*.f64 z 3) y)))
2.9b
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) z) (/.f64 (cbrt.f64 y) 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
3.4b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 z) (/.f64 t (*.f64 3 y))))
2.5b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 3 (*.f64 y z))))
2.6b
(+.f64 (-.f64 x (*.f64 (/.f64 y z) 1/3)) (/.f64 t (*.f64 (*.f64 z 3) y)))
1.6b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 1/3 (/.f64 y (/.f64 t z))))
3.4b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (pow.f64 (/.f64 z (/.f64 t (*.f64 3 y))) -1))
2.8b
(+.f64 (-.f64 x (pow.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 z))) 3)) (/.f64 t (*.f64 (*.f64 z 3) y)))
33.7b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 (sqrt.f64 t) z) (/.f64 (sqrt.f64 t) (*.f64 3 y))))
2.6b
(+.f64 (-.f64 x (*.f64 (/.f64 1 z) (/.f64 y 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
1.6b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
Compiler

Compiled 486 to 340 computations (30% saved)

localize12.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(/.f64 y (*.f64 z 3))
0.2b
(*.f64 t (/.f64 1/3 z))
0.3b
(/.f64 1/3 z)
4.3b
(*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z)))

series9.0ms (0.1%)

Counts
3 → 60
Calls

18 calls:

TimeVariablePointExpression
2.0ms
t
@inf
(*.f64 t (/.f64 1/3 z))
1.0ms
z
@0
(*.f64 t (/.f64 1/3 z))
1.0ms
t
@0
(*.f64 t (/.f64 1/3 z))
0.0ms
t
@-inf
(*.f64 t (/.f64 1/3 z))
0.0ms
z
@inf
(*.f64 t (/.f64 1/3 z))

rewrite50.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
505×log-prod_binary64
257×pow2_binary64
183×pow1/3_binary64
179×expm1-udef_binary64
179×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01021
120921
2259721
Stop Event
node limit
Counts
3 → 101
Calls
Call 1
Inputs
(*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z)))
(/.f64 1/3 z)
(*.f64 t (/.f64 1/3 z))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 1/3 z) (/.f64 t y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 y (/.f64 (*.f64 t 1/3) z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 t (/.f64 y (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 1/3 z) (/.f64 y t))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 t 1/3) z) y)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 (cbrt.f64 (/.f64 (*.f64 t 1/3) z)) 2) (/.f64 y (cbrt.f64 (/.f64 (*.f64 t 1/3) z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (sqrt.f64 (/.f64 (*.f64 t 1/3) z)) (/.f64 y (sqrt.f64 (/.f64 (*.f64 t 1/3) z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 t 1/3) (*.f64 y z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 t y) (*.f64 z 3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (/.f64 (*.f64 t 1/3) z)) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 -1 (*.f64 t 1/3)) (*.f64 (neg.f64 y) z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 t 1/3) 1) (*.f64 z y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 t 1/3) -1) (*.f64 z (neg.f64 y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (/.f64 (*.f64 t 1/3) z) (sqrt.f64 y)) (sqrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (/.f64 (*.f64 t 1/3) z) 1) y)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (/.f64 (*.f64 t 1/3) z) (cbrt.f64 (*.f64 y y))) (cbrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 -1 (/.f64 (*.f64 t 1/3) z)) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 t 1/3) (/.f64 1 y)) z)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (/.f64 1 y) (*.f64 t 1/3)) z)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (/.f64 (*.f64 t 1/3) z) -1) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (/.f64 t y) 1) (*.f64 z 3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (/.f64 t y) 1/3) z)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (/.f64 t y) -1/3) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (/.f64 (*.f64 t 1/3) z) 3) (pow.f64 y 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (pow.f64 y -2) y) (pow.f64 (/.f64 (*.f64 t 1/3) z) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (/.f64 (*.f64 t 1/3) z) 3) (/.f64 (pow.f64 y -2) y)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 y (/.f64 (*.f64 t 1/3) z)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (/.f64 (*.f64 t 1/3) z) 3) (pow.f64 y 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (/.f64 (pow.f64 y -2) y) (pow.f64 (/.f64 (*.f64 t 1/3) z) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 (*.f64 t 1/3) z) 3) (/.f64 (pow.f64 y -2) y)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 1/3 z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 1/3 z))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 1/3 z)))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 1/3 z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 1/3 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/3 (/.f64 1 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/3 z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 1/3 z)) (cbrt.f64 (/.f64 1/9 (*.f64 z z))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 1/9 (*.f64 z z))) (cbrt.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 1/3 z)) (sqrt.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1/3 (/.f64 1 (neg.f64 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 z) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/3 z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 1/3 z) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 1/3 z)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 1/3 z)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 z 3) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (*.f64 z 3) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (/.f64 1/9 (*.f64 z z)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 1/3 z))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 1/3 z) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 1/3 z)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 1/3 z)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 (*.f64 t 1/3) z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 (*.f64 t 1/3) z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 z (*.f64 t 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 t (*.f64 z 3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 t 1/3) z)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 t 1/3)) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 t 1/3) 1) z)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 t 1/3) (pow.f64 (cbrt.f64 z) 2)) (cbrt.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 t 1/3) (sqrt.f64 z)) (sqrt.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 -1/3 t) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 t -1/3) (neg.f64 z))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (*.f64 t 1/3) z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (*.f64 t 1/3) z) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 (*.f64 t 1/3) z)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 (*.f64 t 1/3) z)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 t 3) (pow.f64 (/.f64 1/3 z) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (/.f64 1/3 z) 3) (pow.f64 t 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 z (*.f64 t 1/3)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (*.f64 t 1/3) z) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 (*.f64 t 1/3) z))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (*.f64 t 1/3) z) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 t 3) (pow.f64 (/.f64 1/3 z) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 1/3 z) 3) (pow.f64 t 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 (*.f64 t 1/3) z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 (*.f64 t 1/3) z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (*.f64 t 1/3) z)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 (*.f64 t 1/3) z)))))))

simplify24.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010528
118528
237528
360528
483528
583528
Stop Event
saturated
Counts
161 → 105
Calls
Call 1
Inputs
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
Outputs
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 (/.f64 t y) (/.f64 1/3 z))
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))
(*.f64 1/3 (/.f64 t z))
(/.f64 (*.f64 1/3 t) z)
(*.f64 t (/.f64 1/3 z))

eval69.0ms (1.2%)

Compiler

Compiled 3013 to 1972 computations (34.6% saved)

prune438.0ms (7.5%)

Pruning

10 alts after pruning (10 fresh and 0 done)

PrunedKeptTotal
New1408148
Fresh8210
Picked101
Done000
Total14910159
Error
0b
Counts
159 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
2.5b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 3 (*.f64 y z))))
3.4b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 t y) (*.f64 z 3)))
1.6b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (pow.f64 (/.f64 y (/.f64 (*.f64 t 1/3) z)) -1))
2.9b
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) z) (/.f64 (cbrt.f64 y) 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
1.6b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 y) (*.f64 1/3 (/.f64 t z))))
1.6b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 y) (*.f64 t (pow.f64 (*.f64 z 3) -1))))
1.6b
(+.f64 (-.f64 x (*.f64 (/.f64 1 z) (/.f64 y 3))) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
1.9b
(+.f64 (-.f64 x (pow.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 z))) 3)) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
7.7b
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 (*.f64 (*.f64 z z) 9))) (cbrt.f64 (*.f64 y (/.f64 1/3 z))))) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
1.6b
(+.f64 (-.f64 x (*.f64 (/.f64 y z) 1/3)) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
Compiler

Compiled 460 to 330 computations (28.3% saved)

localize12.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(/.f64 y (*.f64 z 3))
0.2b
(*.f64 t (pow.f64 (*.f64 z 3) -1))
0.5b
(pow.f64 (*.f64 z 3) -1)
4.3b
(*.f64 (/.f64 1 y) (*.f64 t (pow.f64 (*.f64 z 3) -1)))

series6.0ms (0.1%)

Counts
3 → 72
Calls

18 calls:

TimeVariablePointExpression
1.0ms
z
@0
(pow.f64 (*.f64 z 3) -1)
1.0ms
z
@-inf
(pow.f64 (*.f64 z 3) -1)
1.0ms
z
@inf
(pow.f64 (*.f64 z 3) -1)
0.0ms
y
@0
(*.f64 (/.f64 1 y) (*.f64 t (pow.f64 (*.f64 z 3) -1)))
0.0ms
z
@-inf
(*.f64 (/.f64 1 y) (*.f64 t (pow.f64 (*.f64 z 3) -1)))

rewrite54.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
570×log-prod_binary64
207×pow1/3_binary64
201×expm1-udef_binary64
201×log1p-udef_binary64
187×pow3_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01230
124521
2284921
Stop Event
node limit
Counts
3 → 85
Calls
Call 1
Inputs
(*.f64 (/.f64 1 y) (*.f64 t (pow.f64 (*.f64 z 3) -1)))
(pow.f64 (*.f64 z 3) -1)
(*.f64 t (pow.f64 (*.f64 z 3) -1))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (/.f64 1/3 z) (/.f64 t y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z))) (cbrt.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 y (*.f64 t (/.f64 1/3 z))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 t (/.f64 y (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 1/3 z) (/.f64 y t))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 t (/.f64 1/3 z)) y)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (cbrt.f64 (pow.f64 (*.f64 t (/.f64 1/3 z)) 2)) (/.f64 y (cbrt.f64 (*.f64 t (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (sqrt.f64 (*.f64 t (/.f64 1/3 z))) (/.f64 y (sqrt.f64 (*.f64 t (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 t y) (*.f64 z 3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 t (/.f64 1/3 z))) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 t (/.f64 1/3 z)) (sqrt.f64 y)) (sqrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 t (/.f64 1/3 z)) 1) y)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 t (/.f64 1/3 z)) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 -1 (*.f64 t (/.f64 1/3 z))) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 t (/.f64 1/3 z)) -1) (neg.f64 y))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (/.f64 t y) 1) (*.f64 z 3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 (*.f64 t (/.f64 1/3 z)) 3) (pow.f64 y 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (pow.f64 y -2) y) (pow.f64 (*.f64 t (/.f64 1/3 z)) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (*.f64 t (/.f64 1/3 z)) 3) (/.f64 (pow.f64 y -2) y)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 y (*.f64 t (/.f64 1/3 z))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (/.f64 t y)) (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (*.f64 t (/.f64 1/3 z)) 3) (pow.f64 y 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (/.f64 (pow.f64 y -2) y) (pow.f64 (*.f64 t (/.f64 1/3 z)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (*.f64 t (/.f64 1/3 z)) 3) (/.f64 (pow.f64 y -2) y)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 1/3 z) (/.f64 t y))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 1/3 z))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (/.f64 1/3 z))) (cbrt.f64 (exp.f64 (/.f64 1/3 z))))) (log.f64 (cbrt.f64 (exp.f64 (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 1/3 z)))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 1/3 z))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 1/3 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/3 z) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 1/3 z)) (pow.f64 (cbrt.f64 (/.f64 1/3 z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 1/3 z)) 2) (cbrt.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 z) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/3 (/.f64 1 z))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 1/3 z)) (sqrt.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (*.f64 (*.f64 z z) 9))) (cbrt.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (*.f64 z 3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (*.f64 z 3) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -1 (neg.f64 (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 1 z) 3)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1/3 z)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (sqrt.f64 (/.f64 1/3 z)) (sqrt.f64 (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 1 (cbrt.f64 (*.f64 (*.f64 z z) 9))) (cbrt.f64 (*.f64 z 3)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 1/3 z) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 1/3 z))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 1/3 z) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 1/3 z)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 1/3 z)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 t (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z))) (cbrt.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 t (/.f64 1/3 z)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 t (*.f64 z 3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 t (/.f64 1/3 z)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 t (/.f64 1/3 z)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 t (/.f64 1/3 z))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 t (/.f64 1/3 z))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 t 3) (pow.f64 (/.f64 1/3 z) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (/.f64 1/3 z) 3) (pow.f64 t 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 t (/.f64 1/3 z)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 t) (/.f64 1/3 z)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 t (/.f64 1/3 z)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 t (/.f64 1/3 z)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 t 3) (pow.f64 (/.f64 1/3 z) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (/.f64 1/3 z) 3) (pow.f64 t 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 t (/.f64 1/3 z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 t (/.f64 1/3 z))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 t (/.f64 1/3 z))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 t (/.f64 1/3 z))))))))

simplify24.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
011576
119576
237576
360576
483576
583576
Stop Event
saturated
Counts
157 → 88
Calls
Call 1
Inputs
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
Outputs
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 (/.f64 1/3 z) (/.f64 t y))
(*.f64 t (/.f64 (/.f64 1/3 z) y))
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(/.f64 1/3 z)
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))
(*.f64 1/3 (/.f64 t z))

eval59.0ms (1%)

Compiler

Compiled 2827 to 1892 computations (33.1% saved)

prune368.0ms (6.3%)

Pruning

10 alts after pruning (9 fresh and 1 done)

PrunedKeptTotal
New1292131
Fresh279
Picked011
Done000
Total13110141
Error
0b
Counts
141 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
1.6b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (pow.f64 (/.f64 y (*.f64 t (/.f64 1/3 z))) -1))
1.6b
(+.f64 (-.f64 x (*.f64 (/.f64 1 z) (/.f64 y 3))) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
7.7b
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 (*.f64 (*.f64 z z) 9))) (cbrt.f64 (*.f64 y (/.f64 1/3 z))))) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
3.4b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 t y) (*.f64 z 3)))
1.6b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 y) (*.f64 1/3 (/.f64 t z))))
1.6b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 y) (*.f64 t (pow.f64 (*.f64 z 3) -1))))
2.5b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 3 (*.f64 y z))))
1.9b
(+.f64 (-.f64 x (pow.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 z))) 3)) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
2.9b
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) z) (/.f64 (cbrt.f64 y) 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
1.6b
(+.f64 (-.f64 x (*.f64 (/.f64 y z) 1/3)) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
Compiler

Compiled 437 to 313 computations (28.4% saved)

localize11.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 t (/.f64 1/3 z))
0.2b
(pow.f64 (/.f64 y (*.f64 t (/.f64 1/3 z))) -1)
0.3b
(/.f64 1/3 z)
4.2b
(/.f64 y (*.f64 t (/.f64 1/3 z)))

series17.0ms (0.3%)

Counts
2 → 72
Calls

18 calls:

TimeVariablePointExpression
4.0ms
z
@-inf
(pow.f64 (/.f64 y (*.f64 t (/.f64 1/3 z))) -1)
3.0ms
t
@0
(/.f64 y (*.f64 t (/.f64 1/3 z)))
1.0ms
y
@0
(/.f64 y (*.f64 t (/.f64 1/3 z)))
1.0ms
z
@0
(/.f64 y (*.f64 t (/.f64 1/3 z)))
1.0ms
y
@0
(pow.f64 (/.f64 y (*.f64 t (/.f64 1/3 z))) -1)

rewrite57.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
535×log-prod_binary64
188×expm1-udef_binary64
188×log1p-udef_binary64
174×pow3_binary64
159×log-pow_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify32.0ms (0.5%)

Algorithm
egg-herbie
Rules
26×associate-/l*_binary64
20×*-commutative_binary64
17×associate-/r/_binary64
12×associate-*r/_binary64
10×associate-*r*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
011720
122720
251720
399720
4143720
5157720
Stop Event
saturated
Counts
174 → 106
Calls
Call 1
Inputs
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
Outputs
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 3 (/.f64 (*.f64 y z) t))
(*.f64 3 (/.f64 y (/.f64 t z)))
(/.f64 (*.f64 y 3) (/.f64 t z))
(*.f64 3 (*.f64 z (/.f64 y t)))
(*.f64 z (/.f64 y (/.f64 t 3)))
(*.f64 y (/.f64 z (/.f64 t 3)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))
(*.f64 1/3 (/.f64 t (*.f64 y z)))
(/.f64 (*.f64 (/.f64 t y) 1/3) z)
(/.f64 (*.f64 t 1/3) (*.f64 y z))
(/.f64 (/.f64 (*.f64 t 1/3) y) z)
(*.f64 t (/.f64 1/3 (*.f64 y z)))

eval66.0ms (1.1%)

Compiler

Compiled 3456 to 2258 computations (34.7% saved)

prune519.0ms (8.9%)

Pruning

9 alts after pruning (8 fresh and 1 done)

PrunedKeptTotal
New1631164
Fresh178
Picked101
Done011
Total1659174
Error
0b
Counts
174 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
7.7b
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 (*.f64 (*.f64 z z) 9))) (cbrt.f64 (*.f64 y (/.f64 1/3 z))))) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
3.4b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 t y) (*.f64 z 3)))
1.6b
(+.f64 (-.f64 x (*.f64 (/.f64 1 z) (/.f64 y 3))) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
2.5b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 3 (*.f64 y z))))
1.9b
(+.f64 (-.f64 x (pow.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 z))) 3)) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
2.9b
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) z) (/.f64 (cbrt.f64 y) 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
1.6b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (pow.f64 (*.f64 y (/.f64 z (/.f64 t 3))) -1))
1.6b
(+.f64 (-.f64 x (*.f64 (/.f64 y z) 1/3)) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
1.6b
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 y) (*.f64 t (pow.f64 (*.f64 z 3) -1))))
Compiler

Compiled 209 to 150 computations (28.2% saved)

regimes227.0ms (3.9%)

Accuracy

Total -40.2b remaining (-32127.2%)

Threshold costs -40.2b (-32127.2%)

Counts
24 → 3
Calls
Call 1
Inputs
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (pow.f64 (*.f64 y (/.f64 z (/.f64 t 3))) -1))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (pow.f64 (/.f64 y (*.f64 t (/.f64 1/3 z))) -1))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 t y) (*.f64 z 3)))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 t y) (*.f64 z 3)))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (pow.f64 (/.f64 y (/.f64 (*.f64 t 1/3) z)) -1))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 y) (*.f64 1/3 (/.f64 t z))))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 y) (*.f64 t (pow.f64 (*.f64 z 3) -1))))
(+.f64 (-.f64 x (*.f64 (/.f64 1 z) (/.f64 y 3))) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
(+.f64 (-.f64 x (pow.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 z))) 3)) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 (*.f64 (*.f64 z z) 9))) (cbrt.f64 (*.f64 y (/.f64 1/3 z))))) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
(+.f64 (-.f64 x (*.f64 (/.f64 y z) 1/3)) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 (*.f64 (*.f64 z z) 9))) (cbrt.f64 (*.f64 y (/.f64 1/3 z))))) (/.f64 t (*.f64 (*.f64 z 3) y)))
(+.f64 (-.f64 x (*.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) z) (/.f64 (cbrt.f64 y) 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 z) (/.f64 t (*.f64 3 y))))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 3 (*.f64 y z))))
(+.f64 (-.f64 x (*.f64 (/.f64 y z) 1/3)) (/.f64 t (*.f64 (*.f64 z 3) y)))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 1/3 (/.f64 y (/.f64 t z))))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (pow.f64 (/.f64 z (/.f64 t (*.f64 3 y))) -1))
(+.f64 (-.f64 x (pow.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 z))) 3)) (/.f64 t (*.f64 (*.f64 z 3) y)))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 (sqrt.f64 t) z) (/.f64 (sqrt.f64 t) (*.f64 3 y))))
(+.f64 (-.f64 x (*.f64 (/.f64 1 z) (/.f64 y 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (*.f64 (/.f64 1 y) (*.f64 t (/.f64 1/3 z))))
(fma.f64 (/.f64 -1/3 z) (-.f64 y (/.f64 t y)) x)
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
Outputs
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 3 (*.f64 y z))))
(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 t y) (*.f64 z 3)))
(+.f64 (-.f64 x (*.f64 (/.f64 1 z) (/.f64 y 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
Results
TimeErrorSegmentsBranch
33.0ms0.4b3x
13.0ms1.6b1y
32.0ms0.2b3z
33.0ms0.1b3t
36.0ms0.2b3(+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))
33.0ms0.2b3(*.f64 z 3)
33.0ms0.2b3(*.f64 z 3)
Compiler

Compiled 484 to 312 computations (35.5% saved)

bsearch53.0ms (0.9%)

Algorithm
binary-search
Steps
TimePointRange
27.0ms
1e+32
∈ [
2.651529606518337e+30
,
2.552518540979393e+34
]
25.0ms
-3.368747839604316e-141
∈ [
-3.368747839604316e-141
,
-2.1001694714309165e-142
]
Compiler

Compiled 68 to 49 computations (27.9% saved)

simplify4.0ms (0.1%)

Algorithm
egg-herbie
Rules
10×+-commutative_binary64
10×*-commutative_binary64
sub-neg_binary64
neg-sub0_binary64
neg-mul-1_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
03181
14881
26681
37781
48481
58681
Stop Event
saturated
Calls
Call 1
Inputs
(if (<=.f64 t -5781443071721439/1716199415032652428745475199770348304317358825035826352348615864796385795849414013030639910165363638744324077847870214509280496999929160953143507072778764288) (+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 3 (*.f64 y z)))) (if (<=.f64 t 100000000000000005366162204393472) (+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 t y) (*.f64 z 3))) (+.f64 (-.f64 x (*.f64 (/.f64 1 z) (/.f64 y 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))))
Outputs
(if (<=.f64 t -5781443071721439/1716199415032652428745475199770348304317358825035826352348615864796385795849414013030639910165363638744324077847870214509280496999929160953143507072778764288) (+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 3 (*.f64 y z)))) (if (<=.f64 t 100000000000000005366162204393472) (+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 t y) (*.f64 z 3))) (+.f64 (-.f64 x (*.f64 (/.f64 1 z) (/.f64 y 3))) (/.f64 t (*.f64 (*.f64 z 3) y)))))
(if (<=.f64 t -5781443071721439/1716199415032652428745475199770348304317358825035826352348615864796385795849414013030639910165363638744324077847870214509280496999929160953143507072778764288) (+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 3 (*.f64 y z)))) (if (<=.f64 t 100000000000000005366162204393472) (+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 t y) (*.f64 z 3))) (+.f64 (-.f64 x (*.f64 (/.f64 1 z) (/.f64 y 3))) (/.f64 t (*.f64 y (*.f64 z 3))))))
(if (<=.f64 t -5781443071721439/1716199415032652428745475199770348304317358825035826352348615864796385795849414013030639910165363638744324077847870214509280496999929160953143507072778764288) (+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 t (*.f64 3 (*.f64 y z)))) (if (<=.f64 t 100000000000000005366162204393472) (+.f64 (-.f64 x (/.f64 y (*.f64 z 3))) (/.f64 (/.f64 t y) (*.f64 z 3))) (+.f64 (+.f64 x (*.f64 (/.f64 y 3) (/.f64 -1 z))) (/.f64 t (*.f64 y (*.f64 z 3))))))

end32.0ms (0.6%)

Stop Event
fuel
Compiler

Compiled 118 to 78 computations (33.9% saved)

Profiling

Loading profile data...