Details

Time bar (total: 6.0s)

analyze153.0ms (2.5%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
0%99.9%0.1%3
0%99.9%0.1%4
25%74.9%0.1%5
37.5%62.4%0.1%6
43.7%43.7%12.6%7
53.1%34.3%12.6%8
57.8%23.4%18.8%9
63.2%18%18.8%10
66%12.1%22%11
68.9%9.2%22%12
Compiler

Compiled 10 to 7 computations (30% saved)

sample814.0ms (13.6%)

Results
776.0ms8256×body256valid
27.0ms320×body256invalid

preprocess18.0ms (0.3%)

Algorithm
egg-herbie
Rules
22×fma-def_binary64
12×associate-*r*_binary64
12×associate-*l*_binary64
*-commutative_binary64
distribute-lft-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
12816
25016
39316
410116
022
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(*.f64 x (+.f64 1 (*.f64 y y)))
(*.f64 y (+.f64 1 (*.f64 x x)))
Outputs
(*.f64 x (+.f64 1 (*.f64 y y)))
(*.f64 x (fma.f64 y y 1))
(*.f64 y (+.f64 1 (*.f64 x x)))
(*.f64 y (fma.f64 x x 1))
Compiler

Compiled 11 to 8 computations (27.3% saved)

simplify11.0ms (0.2%)

Algorithm
egg-herbie
Rules
13×fma-def_binary64
associate-*r*_binary64
associate-*l*_binary64
*-commutative_binary64
*-lft-identity_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0710
1178
2298
3568
4608
5628
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(*.f64 x (+.f64 1 (*.f64 y y)))
Outputs
(*.f64 x (+.f64 1 (*.f64 y y)))
(*.f64 x (fma.f64 y y 1))

eval1.0ms (0%)

Compiler

Compiled 15 to 9 computations (40% saved)

prune1.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New112
Fresh011
Picked000
Done000
Total123
Error
7.3b
Counts
3 → 1
Alt Table
Click to see full alt table
StatusErrorProgram
7.3b
(*.f64 x (+.f64 1 (*.f64 y y)))
Compiler

Compiled 9 to 6 computations (33.3% saved)

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
6.9b
(*.f64 x (+.f64 1 (*.f64 y y)))
Compiler

Compiled 20 to 9 computations (55% saved)

series4.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite342.0ms (5.7%)

Algorithm
batch-egg-rewrite
Rules
711×pow1_binary64
663×add-log-exp_binary64
662×log1p-expm1-u_binary64
662×expm1-log1p-u_binary64
647×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify158.0ms (2.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010183
122183
240183
375183
4170183
5475183
6697183
71118183
81238183
91371183
101543183
111784183
122101183
132473183
142930183
153519183
164231183
175089183
185517183
195831183
206135183
216211183
226247183
Stop Event
node limit
Counts
50 → 32
Calls
Call 1
Inputs
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
Outputs
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(fma.f64 y (*.f64 y x) x)

eval6.0ms (0.1%)

Compiler

Compiled 329 to 164 computations (50.2% saved)

prune6.0ms (0.1%)

Pruning

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New28432
Fresh000
Picked011
Done000
Total28533
Error
0.1b
Counts
33 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
43.3b
(cbrt.f64 (pow.f64 (*.f64 x (fma.f64 y y 1)) 3))
7.3b
(*.f64 x (+.f64 1 (*.f64 y y)))
7.3b
(+.f64 (*.f64 x (*.f64 y y)) x)
40.2b
(*.f64 y (*.f64 y x))
21.8b
x
Compiler

Compiled 39 to 25 computations (35.9% saved)

localize153.0ms (2.6%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(pow.f64 (*.f64 x (fma.f64 y y 1)) 3)
6.9b
(*.f64 x (fma.f64 y y 1))
40.6b
(cbrt.f64 (pow.f64 (*.f64 x (fma.f64 y y 1)) 3))
Compiler

Compiled 33 to 20 computations (39.4% saved)

series11.0ms (0.2%)

Counts
3 → 72
Calls

18 calls:

TimeVariablePointExpression
2.0ms
x
@-inf
(cbrt.f64 (pow.f64 (*.f64 x (fma.f64 y y 1)) 3))
1.0ms
y
@-inf
(cbrt.f64 (pow.f64 (*.f64 x (fma.f64 y y 1)) 3))
1.0ms
x
@0
(pow.f64 (*.f64 x (fma.f64 y y 1)) 3)
1.0ms
x
@-inf
(pow.f64 (*.f64 x (fma.f64 y y 1)) 3)
1.0ms
x
@0
(cbrt.f64 (pow.f64 (*.f64 x (fma.f64 y y 1)) 3))

rewrite266.0ms (4.4%)

Algorithm
batch-egg-rewrite
Rules
675×pow1_binary64
631×add-log-exp_binary64
630×log1p-expm1-u_binary64
630×expm1-log1p-u_binary64
614×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify95.0ms (1.6%)

Algorithm
egg-herbie
Rules
741×unswap-sqr_binary64
392×distribute-rgt-out_binary64
312×*-commutative_binary64
310×distribute-lft-neg-out_binary64
302×associate-+l+_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
035903
1101847
2340808
31733794
44591793
56044793
66561793
Stop Event
node limit
Counts
141 → 78
Calls
Call 1
Inputs
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 -1 (*.f64 (+.f64 1 (pow.f64 y 2)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (+.f64 1 (pow.f64 y 2)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (+.f64 1 (pow.f64 y 2)) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (+.f64 1 (pow.f64 y 2)) (*.f64 (cbrt.f64 -1) x)))
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(pow.f64 x 3)
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (pow.f64 x 3))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)) (pow.f64 x 3)))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)) (pow.f64 x 3))))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4))))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)) (pow.f64 x 3))))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4))))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)) (pow.f64 x 3))))
Outputs
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 -1 (*.f64 (+.f64 1 (pow.f64 y 2)) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (+.f64 1 (*.f64 y y)) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 x (cbrt.f64 -1)) (neg.f64 (fma.f64 y y 1)))
(*.f64 (fma.f64 y y 1) (*.f64 x (neg.f64 (cbrt.f64 -1))))
(*.f64 -1 (*.f64 (+.f64 1 (pow.f64 y 2)) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (+.f64 1 (*.f64 y y)) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 x (cbrt.f64 -1)) (neg.f64 (fma.f64 y y 1)))
(*.f64 (fma.f64 y y 1) (*.f64 x (neg.f64 (cbrt.f64 -1))))
(*.f64 -1 (*.f64 (+.f64 1 (pow.f64 y 2)) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (+.f64 1 (*.f64 y y)) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 x (cbrt.f64 -1)) (neg.f64 (fma.f64 y y 1)))
(*.f64 (fma.f64 y y 1) (*.f64 x (neg.f64 (cbrt.f64 -1))))
(*.f64 -1 (*.f64 (+.f64 1 (pow.f64 y 2)) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (+.f64 1 (*.f64 y y)) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 x (cbrt.f64 -1)) (neg.f64 (fma.f64 y y 1)))
(*.f64 (fma.f64 y y 1) (*.f64 x (neg.f64 (cbrt.f64 -1))))
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 (fma.f64 y y 1) x)
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (pow.f64 y 2)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (+.f64 1 (*.f64 y y)) 3) (pow.f64 x 3))
(*.f64 (pow.f64 (fma.f64 y y 1) 3) (pow.f64 x 3))
(pow.f64 x 3)
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (pow.f64 x 3))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (*.f64 y y) (pow.f64 x 3))
(fma.f64 (*.f64 y y) (*.f64 3 (pow.f64 x 3)) (pow.f64 x 3))
(*.f64 (+.f64 (*.f64 y (*.f64 y 3)) 1) (pow.f64 x 3))
(*.f64 (pow.f64 x 3) (+.f64 1 (*.f64 (*.f64 y y) 3)))
(*.f64 (pow.f64 x 3) (+.f64 1 (*.f64 y (*.f64 y 3))))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)) (pow.f64 x 3)))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (*.f64 y y) (fma.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 4) (pow.f64 x 3)))
(+.f64 (pow.f64 x 3) (*.f64 (*.f64 3 (pow.f64 x 3)) (+.f64 (*.f64 y y) (pow.f64 y 4))))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (fma.f64 y y (pow.f64 y 4)) (pow.f64 x 3))
(*.f64 (+.f64 (*.f64 3 (fma.f64 y y (pow.f64 y 4))) 1) (pow.f64 x 3))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)) (pow.f64 x 3))))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (*.f64 y y) (fma.f64 (pow.f64 y 6) (pow.f64 x 3) (fma.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 4) (pow.f64 x 3))))
(+.f64 (+.f64 (pow.f64 x 3) (*.f64 (*.f64 3 (pow.f64 x 3)) (+.f64 (*.f64 y y) (pow.f64 y 4)))) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(fma.f64 (pow.f64 x 3) (pow.f64 y 6) (fma.f64 (*.f64 3 (pow.f64 x 3)) (fma.f64 y y (pow.f64 y 4)) (pow.f64 x 3)))
(+.f64 (pow.f64 x 3) (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 6) (*.f64 3 (fma.f64 y y (pow.f64 y 4))))))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 x 3) (pow.f64 y 6))
(+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)))
(fma.f64 (pow.f64 y 6) (pow.f64 x 3) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 4)))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 4) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(*.f64 (pow.f64 x 3) (+.f64 (*.f64 3 (pow.f64 y 4)) (pow.f64 y 6)))
(*.f64 (pow.f64 x 3) (*.f64 (pow.f64 y 4) (+.f64 3 (*.f64 y y))))
(*.f64 (pow.f64 x 3) (*.f64 (pow.f64 y 4) (+.f64 (*.f64 y y) 3)))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4))))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (*.f64 y y) (fma.f64 (pow.f64 y 6) (pow.f64 x 3) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 4))))
(+.f64 (*.f64 (pow.f64 x 3) (pow.f64 y 6)) (*.f64 (*.f64 3 (pow.f64 x 3)) (+.f64 (*.f64 y y) (pow.f64 y 4))))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (fma.f64 y y (pow.f64 y 4)) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 6) (*.f64 3 (fma.f64 y y (pow.f64 y 4)))))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)) (pow.f64 x 3))))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (*.f64 y y) (fma.f64 (pow.f64 y 6) (pow.f64 x 3) (fma.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 4) (pow.f64 x 3))))
(+.f64 (+.f64 (pow.f64 x 3) (*.f64 (*.f64 3 (pow.f64 x 3)) (+.f64 (*.f64 y y) (pow.f64 y 4)))) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(fma.f64 (pow.f64 x 3) (pow.f64 y 6) (fma.f64 (*.f64 3 (pow.f64 x 3)) (fma.f64 y y (pow.f64 y 4)) (pow.f64 x 3)))
(+.f64 (pow.f64 x 3) (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 6) (*.f64 3 (fma.f64 y y (pow.f64 y 4))))))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 x 3) (pow.f64 y 6))
(+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)))
(fma.f64 (pow.f64 y 6) (pow.f64 x 3) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 4)))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 4) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(*.f64 (pow.f64 x 3) (+.f64 (*.f64 3 (pow.f64 y 4)) (pow.f64 y 6)))
(*.f64 (pow.f64 x 3) (*.f64 (pow.f64 y 4) (+.f64 3 (*.f64 y y))))
(*.f64 (pow.f64 x 3) (*.f64 (pow.f64 y 4) (+.f64 (*.f64 y y) 3)))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4))))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (*.f64 y y) (fma.f64 (pow.f64 y 6) (pow.f64 x 3) (*.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 4))))
(+.f64 (*.f64 (pow.f64 x 3) (pow.f64 y 6)) (*.f64 (*.f64 3 (pow.f64 x 3)) (+.f64 (*.f64 y y) (pow.f64 y 4))))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (fma.f64 y y (pow.f64 y 4)) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 6) (*.f64 3 (fma.f64 y y (pow.f64 y 4)))))
(+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 2)) (+.f64 (*.f64 (pow.f64 y 6) (pow.f64 x 3)) (+.f64 (*.f64 (+.f64 (*.f64 2 (pow.f64 x 3)) (pow.f64 x 3)) (pow.f64 y 4)) (pow.f64 x 3))))
(fma.f64 (*.f64 3 (pow.f64 x 3)) (*.f64 y y) (fma.f64 (pow.f64 y 6) (pow.f64 x 3) (fma.f64 (*.f64 3 (pow.f64 x 3)) (pow.f64 y 4) (pow.f64 x 3))))
(+.f64 (+.f64 (pow.f64 x 3) (*.f64 (*.f64 3 (pow.f64 x 3)) (+.f64 (*.f64 y y) (pow.f64 y 4)))) (*.f64 (pow.f64 x 3) (pow.f64 y 6)))
(fma.f64 (pow.f64 x 3) (pow.f64 y 6) (fma.f64 (*.f64 3 (pow.f64 x 3)) (fma.f64 y y (pow.f64 y 4)) (pow.f64 x 3)))
(+.f64 (pow.f64 x 3) (*.f64 (pow.f64 x 3) (+.f64 (pow.f64 y 6) (*.f64 3 (fma.f64 y y (pow.f64 y 4))))))

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 12 to 4 computations (66.7% saved)

series3.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite47.0ms (0.8%)

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

Useful iterations: 0 (0.0ms)

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

simplify190.0ms (3.2%)

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

Useful iterations: 0 (0.0ms)

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

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 19 to 5 computations (73.7% saved)

series3.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite72.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
709×pow1_binary64
660×add-log-exp_binary64
660×log1p-expm1-u_binary64
660×expm1-log1p-u_binary64
643×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify105.0ms (1.8%)

Algorithm
egg-herbie
Rules
1069×fma-neg_binary64
808×fma-def_binary64
503×distribute-rgt-neg-in_binary64
464×unswap-sqr_binary64
441×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
015351
137351
287351
3229351
4623351
51191351
61746351
72622351
84294351
96147351
107614351
Stop Event
node limit
Counts
98 → 57
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (pow.f64 y 2)) 1) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (pow.f64 y 2)) 1) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (pow.f64 y 2)) 1) x))
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (pow.f64 y 2)) 1) x))
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
Outputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (pow.f64 y 2)) 1) x))
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (pow.f64 y 2)) 1) x))
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (pow.f64 y 2)) 1) x))
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 -1 (*.f64 (-.f64 (*.f64 -1 (pow.f64 y 2)) 1) x))
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 y x) x)

eval67.0ms (1.1%)

Compiler

Compiled 1852 to 986 computations (46.8% saved)

prune44.0ms (0.7%)

Pruning

8 alts after pruning (5 fresh and 3 done)

PrunedKeptTotal
New1435148
Fresh101
Picked011
Done123
Total1458153
Error
0.0b
Counts
153 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
7.3b
(*.f64 x (+.f64 1 (*.f64 y y)))
54.7b
(cbrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3))
8.5b
(*.f64 (*.f64 (fma.f64 y y 1) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))
7.3b
(+.f64 (*.f64 x (*.f64 y y)) x)
40.2b
(*.f64 y (*.f64 y x))
40.5b
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)
21.8b
x
36.2b
(*.f64 (*.f64 (fma.f64 y y 1) (sqrt.f64 x)) (sqrt.f64 x))
Compiler

Compiled 74 to 47 computations (36.5% saved)

localize24.0ms (0.4%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(pow.f64 (*.f64 y (*.f64 y x)) 3)
0.2b
(*.f64 y (*.f64 y x))
30.0b
(cbrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3))
Compiler

Compiled 28 to 10 computations (64.3% saved)

series13.0ms (0.2%)

Counts
2 → 48
Calls

12 calls:

TimeVariablePointExpression
4.0ms
y
@0
(pow.f64 (*.f64 y (*.f64 y x)) 3)
1.0ms
x
@-inf
(cbrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3))
1.0ms
x
@0
(pow.f64 (*.f64 y (*.f64 y x)) 3)
1.0ms
x
@-inf
(pow.f64 (*.f64 y (*.f64 y x)) 3)
1.0ms
x
@inf
(pow.f64 (*.f64 y (*.f64 y x)) 3)

rewrite101.0ms (1.7%)

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

Useful iterations: 0 (0.0ms)

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

simplify136.0ms (2.3%)

Algorithm
egg-herbie
Rules
711×unswap-sqr_binary64
470×fma-def_binary64
460×associate-*l*_binary64
441×sqr-pow_binary64
376×associate-*r*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
016436
141436
2119436
3384436
41841436
53477436
64037436
74827436
86146436
97131436
Stop Event
node limit
Counts
110 → 66
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
Outputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (*.f64 y y) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 y y) (neg.f64 (*.f64 x (cbrt.f64 -1))))
(*.f64 y (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -1)))))
(*.f64 y (*.f64 (cbrt.f64 -1) (neg.f64 (*.f64 y x))))
(*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 x (neg.f64 y))))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (*.f64 y y) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 y y) (neg.f64 (*.f64 x (cbrt.f64 -1))))
(*.f64 y (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -1)))))
(*.f64 y (*.f64 (cbrt.f64 -1) (neg.f64 (*.f64 y x))))
(*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 x (neg.f64 y))))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (*.f64 y y) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 y y) (neg.f64 (*.f64 x (cbrt.f64 -1))))
(*.f64 y (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -1)))))
(*.f64 y (*.f64 (cbrt.f64 -1) (neg.f64 (*.f64 y x))))
(*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 x (neg.f64 y))))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (*.f64 y y) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 y y) (neg.f64 (*.f64 x (cbrt.f64 -1))))
(*.f64 y (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -1)))))
(*.f64 y (*.f64 (cbrt.f64 -1) (neg.f64 (*.f64 y x))))
(*.f64 y (*.f64 (cbrt.f64 -1) (*.f64 x (neg.f64 y))))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))
(*.f64 (pow.f64 y 6) (pow.f64 x 3))

localize26.0ms (0.4%)

Local error

Found 2 expressions with local error:

NewErrorProgram
1.3b
(*.f64 (*.f64 (fma.f64 y y 1) (sqrt.f64 x)) (sqrt.f64 x))
3.2b
(*.f64 (fma.f64 y y 1) (sqrt.f64 x))
Compiler

Compiled 28 to 13 computations (53.6% saved)

series12.0ms (0.2%)

Counts
2 → 36
Calls

12 calls:

TimeVariablePointExpression
2.0ms
x
@-inf
(*.f64 (*.f64 (fma.f64 y y 1) (sqrt.f64 x)) (sqrt.f64 x))
2.0ms
x
@0
(*.f64 (fma.f64 y y 1) (sqrt.f64 x))
2.0ms
x
@-inf
(*.f64 (fma.f64 y y 1) (sqrt.f64 x))
1.0ms
y
@0
(*.f64 (fma.f64 y y 1) (sqrt.f64 x))
1.0ms
x
@inf
(*.f64 (fma.f64 y y 1) (sqrt.f64 x))

rewrite88.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
673×pow1_binary64
617×add-log-exp_binary64
617×log1p-expm1-u_binary64
617×expm1-log1p-u_binary64
602×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify74.0ms (1.2%)

Algorithm
egg-herbie
Rules
549×distribute-rgt-in_binary64
531×distribute-lft-in_binary64
502×distribute-neg-in_binary64
452×distribute-rgt-neg-in_binary64
381×distribute-rgt-neg-out_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
018312
144294
2137294
3413294
41463294
54927294
Stop Event
node limit
Counts
65 → 41
Calls
Call 1
Inputs
(sqrt.f64 x)
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 1 (pow.f64 y 2)) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 1 (pow.f64 y 2)) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 1 (pow.f64 y 2)) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 1 (pow.f64 y 2)) x)))
Outputs
(sqrt.f64 x)
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (+.f64 (*.f64 y y) 1) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (fma.f64 y y 1))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (+.f64 (*.f64 y y) 1) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (fma.f64 y y 1))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (+.f64 (*.f64 y y) 1) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (fma.f64 y y 1))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (*.f64 y y))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (+.f64 (*.f64 y y) 1) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (fma.f64 y y 1))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (+.f64 (*.f64 y y) 1) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (fma.f64 y y 1))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (+.f64 (*.f64 y y) 1) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (fma.f64 y y 1))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (*.f64 y y))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (+.f64 (*.f64 y y) 1) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (fma.f64 y y 1))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (+.f64 (*.f64 y y) 1) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (fma.f64 y y 1))
(+.f64 (sqrt.f64 x) (*.f64 (pow.f64 y 2) (sqrt.f64 x)))
(*.f64 (+.f64 (*.f64 y y) 1) (sqrt.f64 x))
(*.f64 (sqrt.f64 x) (fma.f64 y y 1))
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 x y))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 x y))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 1 (pow.f64 y 2)) x)))
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 1 (pow.f64 y 2)) x)))
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 1 (pow.f64 y 2)) x)))
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (+.f64 1 (pow.f64 y 2)) x)))
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 x (*.f64 y y) x)

localize36.0ms (0.6%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.5b
(pow.f64 (cbrt.f64 x) 2)
0.6b
(cbrt.f64 x)
1.9b
(*.f64 (*.f64 (fma.f64 y y 1) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))
5.2b
(*.f64 (fma.f64 y y 1) (pow.f64 (cbrt.f64 x) 2))
Compiler

Compiled 37 to 20 computations (45.9% saved)

series35.0ms (0.6%)

Counts
4 → 36
Calls

18 calls:

TimeVariablePointExpression
8.0ms
x
@-inf
(*.f64 (*.f64 (fma.f64 y y 1) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))
3.0ms
x
@0
(*.f64 (*.f64 (fma.f64 y y 1) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))
3.0ms
x
@inf
(pow.f64 (cbrt.f64 x) 2)
3.0ms
y
@0
(*.f64 (fma.f64 y y 1) (pow.f64 (cbrt.f64 x) 2))
2.0ms
y
@0
(*.f64 (*.f64 (fma.f64 y y 1) (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x))

rewrite107.0ms (1.8%)

Algorithm
batch-egg-rewrite
Rules
789×pow1_binary64
726×add-log-exp_binary64
726×log1p-expm1-u_binary64
726×expm1-log1p-u_binary64
709×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify273.0ms (4.6%)

Algorithm
egg-herbie
Rules
1514×unswap-sqr_binary64
781×sqr-pow_binary64
660×fma-def_binary64
319×cube-prod_binary64
282×fabs-mul_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
017375
145330
288330
3228330
4858330
51882330
62165330
72297330
82456330
92627330
102826330
113058330
123319330
133614330
143935330
154275330
164645330
175035330
185135330
195213330
205269330
217557330
Stop Event
node limit
Counts
100 → 75
Calls
Call 1
Inputs
(pow.f64 (pow.f64 x 2) 1/3)
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (pow.f64 y 2) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
Outputs
(pow.f64 (pow.f64 x 2) 1/3)
(cbrt.f64 (*.f64 x x))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y) (cbrt.f64 (*.f64 x x)))
(*.f64 (fma.f64 y y 1) (cbrt.f64 (*.f64 x x)))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y) (cbrt.f64 (*.f64 x x)))
(*.f64 (fma.f64 y y 1) (cbrt.f64 (*.f64 x x)))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y) (cbrt.f64 (*.f64 x x)))
(*.f64 (fma.f64 y y 1) (cbrt.f64 (*.f64 x x)))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 y y 1))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y) (cbrt.f64 (*.f64 x x)))
(*.f64 (fma.f64 y y 1) (cbrt.f64 (*.f64 x x)))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y) (cbrt.f64 (*.f64 x x)))
(*.f64 (fma.f64 y y 1) (cbrt.f64 (*.f64 x x)))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y) (cbrt.f64 (*.f64 x x)))
(*.f64 (fma.f64 y y 1) (cbrt.f64 (*.f64 x x)))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 y y 1))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y) (cbrt.f64 (*.f64 x x)))
(*.f64 (fma.f64 y y 1) (cbrt.f64 (*.f64 x x)))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y) (cbrt.f64 (*.f64 x x)))
(*.f64 (fma.f64 y y 1) (cbrt.f64 (*.f64 x x)))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2)) (pow.f64 (pow.f64 x 2) 1/3))
(fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y) (cbrt.f64 (*.f64 x x)))
(*.f64 (fma.f64 y y 1) (cbrt.f64 (*.f64 x x)))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 y y 1))
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 x y))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 x y))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(fma.f64 y (*.f64 x y) x)

localize21.0ms (0.4%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(*.f64 y (*.f64 y x))
0.5b
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)
17.9b
(cbrt.f64 (*.f64 y (*.f64 y x)))
Compiler

Compiled 27 to 8 computations (70.4% saved)

series18.0ms (0.3%)

Counts
2 → 0
Calls

12 calls:

TimeVariablePointExpression
4.0ms
x
@0
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)
2.0ms
x
@-inf
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)
2.0ms
y
@0
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)
2.0ms
y
@inf
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)
2.0ms
x
@inf
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)

rewrite157.0ms (2.6%)

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

Useful iterations: 0 (0.0ms)

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

simplify14.0ms (0.2%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

eval194.0ms (3.2%)

Compiler

Compiled 3438 to 1555 computations (54.8% saved)

prune102.0ms (1.7%)

Pruning

14 alts after pruning (9 fresh and 5 done)

PrunedKeptTotal
New2809289
Fresh101
Picked011
Done246
Total28314297
Error
0.0b
Counts
297 → 14
Alt Table
Click to see full alt table
StatusErrorProgram
21.8b
x
51.3b
(*.f64 (*.f64 y (sqrt.f64 (*.f64 y x))) (sqrt.f64 (*.f64 y x)))
40.5b
(*.f64 (cbrt.f64 y) (*.f64 (cbrt.f64 (*.f64 y x)) (pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 2)))
55.7b
(*.f64 (*.f64 (*.f64 y y) (sqrt.f64 x)) (sqrt.f64 x))
40.5b
(*.f64 (pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 2) (cbrt.f64 (*.f64 y (*.f64 y x))))
7.3b
(*.f64 x (+.f64 1 (*.f64 y y)))
54.7b
(cbrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3))
54.8b
(*.f64 (*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y)) (cbrt.f64 x))
40.5b
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)
7.3b
(+.f64 (*.f64 x (*.f64 y y)) x)
40.2b
(*.f64 y (*.f64 y x))
47.4b
(*.f64 (*.f64 y y) x)
54.0b
(*.f64 (*.f64 (*.f64 y x) (sqrt.f64 y)) (sqrt.f64 y))
40.5b
(*.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (*.f64 y x)))
Compiler

Compiled 254 to 145 computations (42.9% saved)

localize25.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (*.f64 y x)))
0.3b
(*.f64 (cbrt.f64 y) (*.f64 y x))
0.5b
(pow.f64 (cbrt.f64 y) 2)
0.6b
(cbrt.f64 y)
Compiler

Compiled 31 to 11 computations (64.5% saved)

series26.0ms (0.4%)

Counts
4 → 36
Calls

18 calls:

TimeVariablePointExpression
5.0ms
x
@0
(*.f64 (cbrt.f64 y) (*.f64 y x))
4.0ms
y
@-inf
(*.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (*.f64 y x)))
1.0ms
y
@-inf
(*.f64 (cbrt.f64 y) (*.f64 y x))
1.0ms
y
@-inf
(pow.f64 (cbrt.f64 y) 2)
1.0ms
x
@inf
(*.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (*.f64 y x)))

rewrite164.0ms (2.7%)

Algorithm
batch-egg-rewrite
Rules
787×pow1_binary64
727×add-log-exp_binary64
727×log1p-expm1-u_binary64
727×expm1-log1p-u_binary64
709×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify188.0ms (3.1%)

Algorithm
egg-herbie
Rules
1253×sqr-pow_binary64
566×cube-prod_binary64
500×pow-sqr_binary64
499×fabs-mul_binary64
408×unswap-sqr_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
013276
130276
258276
3124276
4342276
51122276
61938276
72092276
82302276
92562276
102926276
113415276
124038276
134797276
145269276
155590276
165858276
176034276
186128276
196861276
207973276
Stop Event
node limit
Counts
99 → 67
Calls
Call 1
Inputs
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
Outputs
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 4)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 4)) x)
(*.f64 x (cbrt.f64 (pow.f64 y 4)))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))

localize5.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 12 to 4 computations (66.7% saved)

series3.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite72.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify181.0ms (3%)

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

Useful iterations: 0 (0.0ms)

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

localize8.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
2.7b
(*.f64 (*.f64 (*.f64 y y) (sqrt.f64 x)) (sqrt.f64 x))
4.4b
(*.f64 (*.f64 y y) (sqrt.f64 x))
Compiler

Compiled 24 to 6 computations (75% saved)

series7.0ms (0.1%)

Counts
2 → 36
Calls

12 calls:

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

rewrite84.0ms (1.4%)

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

Useful iterations: 0 (0.0ms)

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

simplify88.0ms (1.5%)

Algorithm
egg-herbie
Rules
1294×fma-def_binary64
363×fma-neg_binary64
340×distribute-rgt-neg-in_binary64
327×associate-*l*_binary64
304×*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
013276
130276
291276
3292276
41466276
53578276
65087276
76137276
86654276
97760276
Stop Event
unsound
Counts
58 → 27
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
Outputs
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) (sqrt.f64 x))
(*.f64 (*.f64 y y) (sqrt.f64 x))
(*.f64 (*.f64 (sqrt.f64 x) y) y)
(*.f64 y (*.f64 y (sqrt.f64 x)))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 -1 (*.f64 (pow.f64 (sqrt.f64 -1) 2) (*.f64 (pow.f64 y 2) x)))
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))

localize13.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.6b
(cbrt.f64 x)
3.8b
(*.f64 (*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y)) (cbrt.f64 x))
8.5b
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
32.9b
(cbrt.f64 (*.f64 x x))
Compiler

Compiled 35 to 8 computations (77.1% saved)

series44.0ms (0.7%)

Counts
3 → 36
Calls

15 calls:

TimeVariablePointExpression
36.0ms
x
@0
(cbrt.f64 (*.f64 x x))
2.0ms
y
@0
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
1.0ms
y
@0
(*.f64 (*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y)) (cbrt.f64 x))
1.0ms
x
@0
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
1.0ms
x
@-inf
(*.f64 (*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y)) (cbrt.f64 x))

rewrite67.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
758×pow1_binary64
698×add-log-exp_binary64
698×log1p-expm1-u_binary64
698×expm1-log1p-u_binary64
675×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify124.0ms (2.1%)

Algorithm
egg-herbie
Rules
915×fma-def_binary64
452×fma-neg_binary64
450×distribute-lft-neg-in_binary64
450×distribute-rgt-neg-in_binary64
388×unswap-sqr_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
017340
143340
2113340
3346340
41520340
52959340
63815340
74926340
86134340
96956340
107907340
Stop Event
node limit
Counts
84 → 54
Calls
Call 1
Inputs
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
Outputs
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 (*.f64 1 (pow.f64 x 2)) 1/3) (pow.f64 y 2))
(*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (*.f64 y y) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 y y) (neg.f64 (*.f64 x (cbrt.f64 -1))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (neg.f64 y))))
(*.f64 x (*.f64 (*.f64 y y) (neg.f64 (cbrt.f64 -1))))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (*.f64 y y) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 y y) (neg.f64 (*.f64 x (cbrt.f64 -1))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (neg.f64 y))))
(*.f64 x (*.f64 (*.f64 y y) (neg.f64 (cbrt.f64 -1))))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (*.f64 y y) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 y y) (neg.f64 (*.f64 x (cbrt.f64 -1))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (neg.f64 y))))
(*.f64 x (*.f64 (*.f64 y y) (neg.f64 (cbrt.f64 -1))))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (cbrt.f64 -1) x)))
(neg.f64 (*.f64 (*.f64 y y) (*.f64 x (cbrt.f64 -1))))
(*.f64 (*.f64 y y) (neg.f64 (*.f64 x (cbrt.f64 -1))))
(*.f64 x (*.f64 (cbrt.f64 -1) (*.f64 y (neg.f64 y))))
(*.f64 x (*.f64 (*.f64 y y) (neg.f64 (cbrt.f64 -1))))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))

localize21.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.4b
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 2)
0.6b
(cbrt.f64 y)
9.9b
(cbrt.f64 (*.f64 y x))
17.9b
(cbrt.f64 (*.f64 y (*.f64 y x)))
Compiler

Compiled 62 to 17 computations (72.6% saved)

series5.0ms (0.1%)

Counts
2 → 0
Calls

12 calls:

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

rewrite65.0ms (1.1%)

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

Useful iterations: 0 (0.0ms)

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

simplify8.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

eval150.0ms (2.5%)

Compiler

Compiled 4077 to 1447 computations (64.5% saved)

prune50.0ms (0.8%)

Pruning

15 alts after pruning (5 fresh and 10 done)

PrunedKeptTotal
New2821283
Fresh044
Picked011
Done099
Total28215297
Error
0b
Counts
297 → 15
Alt Table
Click to see full alt table
StatusErrorProgram
21.8b
x
51.3b
(*.f64 (*.f64 y (sqrt.f64 (*.f64 y x))) (sqrt.f64 (*.f64 y x)))
40.6b
(*.f64 (pow.f64 (cbrt.f64 y) 2) (pow.f64 (cbrt.f64 (*.f64 (cbrt.f64 y) (*.f64 y x))) 3))
40.5b
(*.f64 (cbrt.f64 y) (*.f64 (cbrt.f64 (*.f64 y x)) (pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 2)))
55.7b
(*.f64 (*.f64 (*.f64 y y) (sqrt.f64 x)) (sqrt.f64 x))
40.5b
(*.f64 (pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 2) (cbrt.f64 (*.f64 y (*.f64 y x))))
7.3b
(*.f64 x (+.f64 1 (*.f64 y y)))
54.7b
(cbrt.f64 (pow.f64 (*.f64 y (*.f64 y x)) 3))
54.8b
(*.f64 (*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y)) (cbrt.f64 x))
40.5b
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 y x))) 3)
7.3b
(+.f64 (*.f64 x (*.f64 y y)) x)
40.2b
(*.f64 y (*.f64 y x))
47.4b
(*.f64 (*.f64 y y) x)
54.0b
(*.f64 (*.f64 (*.f64 y x) (sqrt.f64 y)) (sqrt.f64 y))
40.5b
(*.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (*.f64 y x)))
Compiler

Compiled 167 to 99 computations (40.7% saved)

regimes198.0ms (3.3%)

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

7 calls:

57.0ms
x
49.0ms
(*.f64 y y)
34.0ms
y
27.0ms
(*.f64 x (+.f64 1 (*.f64 y y)))
11.0ms
(*.f64 y y)
Results
ErrorSegmentsBranch
6.0b3x
0.1b3y
0.1b3(*.f64 x (+.f64 1 (*.f64 y y)))
0.1b2(+.f64 1 (*.f64 y y))
0.1b2(+.f64 1 (*.f64 y y))
0.1b2(*.f64 y y)
0.1b2(*.f64 y y)
Compiler

Compiled 211 to 92 computations (56.4% saved)

bsearch26.0ms (0.4%)

Algorithm
binary-search
Steps
TimeLeftRight
7.0ms
1.4170329266833038e+62
2.3963549375007396e+63
19.0ms
-50554366478291380.0
-12611482176999740.0
Compiler

Compiled 32 to 21 computations (34.4% saved)

regimes48.0ms (0.8%)

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

4 calls:

19.0ms
x
14.0ms
y
7.0ms
(*.f64 y y)
6.0ms
(*.f64 y y)
Results
ErrorSegmentsBranch
17.1b3x
1.1b3y
1.1b2(*.f64 y y)
1.1b2(*.f64 y y)
Compiler

Compiled 31 to 16 computations (48.4% saved)

bsearch0.0ms (0%)

Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.004941075491279822
1970242.3449673164
Compiler

Compiled 14 to 10 computations (28.6% saved)

regimes34.0ms (0.6%)

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

3 calls:

17.0ms
y
12.0ms
x
5.0ms
(*.f64 y y)
Results
ErrorSegmentsBranch
20.8b3x
8.3b3y
8.3b2(*.f64 y y)
Compiler

Compiled 21 to 11 computations (47.6% saved)

bsearch15.0ms (0.3%)

Algorithm
binary-search
Steps
TimeLeftRight
15.0ms
0.004941075491279822
1970242.3449673164
Compiler

Compiled 14 to 10 computations (28.6% saved)

regimes9.0ms (0.1%)

Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0.0b (-0%)

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

2 calls:

4.0ms
y
4.0ms
x
Results
ErrorSegmentsBranch
21.8b1x
21.8b1y
Compiler

Compiled 11 to 6 computations (45.5% saved)

simplify4.0ms (0.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
02271
12671
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(if (<=.f64 y -50554366478291376) (*.f64 y (*.f64 y x)) (if (<=.f64 y 1000000000000000057857959942726969827393378689175040438172647424) (+.f64 (*.f64 x (*.f64 y y)) x) (*.f64 y (*.f64 y x))))
(if (<=.f64 (*.f64 y y) 92233720368547760/18446744073709551616) x (*.f64 y (*.f64 y x)))
(if (<=.f64 (*.f64 y y) 91146755036517568/18446744073709551616) x (*.f64 (*.f64 y y) x))
x
Outputs
(if (<=.f64 y -50554366478291376) (*.f64 y (*.f64 y x)) (if (<=.f64 y 1000000000000000057857959942726969827393378689175040438172647424) (+.f64 (*.f64 x (*.f64 y y)) x) (*.f64 y (*.f64 y x))))
(if (<=.f64 y -50554366478291376) (*.f64 y (*.f64 y x)) (if (<=.f64 y 1000000000000000057857959942726969827393378689175040438172647424) (+.f64 x (*.f64 x (*.f64 y y))) (*.f64 y (*.f64 y x))))
(if (<=.f64 (*.f64 y y) 92233720368547760/18446744073709551616) x (*.f64 y (*.f64 y x)))
(if (<=.f64 (*.f64 y y) 5764607523034235/1152921504606846976) x (*.f64 y (*.f64 y x)))
(if (<=.f64 (*.f64 y y) 91146755036517568/18446744073709551616) x (*.f64 (*.f64 y y) x))
(if (<=.f64 (*.f64 y y) 1424168047445587/288230376151711744) x (*.f64 x (*.f64 y y)))
x
Compiler

Compiled 58 to 30 computations (48.3% saved)

soundness206.0ms (3.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010183
122183
240183
375183
4170183
5475183
6697183
71118183
81238183
91371183
101543183
111784183
122101183
132473183
142930183
153519183
164231183
175089183
185517183
195831183
206135183
216211183
226247183
Stop Event
node limit
Compiler

Compiled 21 to 13 computations (38.1% saved)

end28.0ms (0.5%)

Compiler

Compiled 52 to 19 computations (63.5% saved)

Profiling

Loading profile data...