Details

Time bar (total: 2.2s)

analyze159.0ms (7.2%)

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
70.3%6.1%23.5%13
71.9%4.6%23.5%14
Compiler

Compiled 10 to 7 computations (30% saved)

sample1.2s (53.8%)

Results
1.1s8256×body128valid
24.0ms178×body128invalid
Compiler

Compiled 20 to 14 computations (30% saved)

preprocess14.0ms (0.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
12816
25016
38716
49516
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 9 to 6 computations (33.3% saved)

simplify9.0ms (0.4%)

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
3558
4598
5618
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))
(fma.f64 x (*.f64 y y) x)

prune2.0ms (0.1%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
5.8b
Counts
3 → 1
Alt Table
StatusErrorProgram
5.8b
(fma.f64 x (*.f64 y y) x)
Compiler

Compiled 31 to 15 computations (51.6% saved)

localize3.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
5.4b
(fma.f64 x (*.f64 y y) x)

series4.0ms (0.2%)

Counts
1 → 24
Calls

6 calls:

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

rewrite33.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
455×pow1_binary64
418×add-log-exp_binary64
418×log1p-expm1-u_binary64
418×expm1-log1p-u_binary64
406×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
058
1998
211718
Stop Event
node limit
Counts
1 → 21
Calls
Call 1
Inputs
(fma.f64 x (*.f64 y y) x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 x (*.f64 x (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 y y)) x)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x (*.f64 y y)) 1) x)))) (#(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 (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 (*.f64 (*.f64 x (*.f64 y y)) (*.f64 x (*.f64 y y))) (-.f64 (*.f64 x x) (*.f64 (*.f64 x (*.f64 y y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 x (*.f64 y y)) (*.f64 x (*.f64 y y))) (*.f64 x x)) (-.f64 (*.f64 x (*.f64 y y)) x))))) (#(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 exp.f64 (log.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 expm1.f64 (log1p.f64 (fma.f64 x (*.f64 y y) x)))))))

simplify65.0ms (3%)

Algorithm
egg-herbie
Rules
775×sqr-pow_binary64
412×fabs-mul_binary64
390×cube-prod_binary64
381×pow-sqr_binary64
242×unswap-sqr_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
010183
122183
240183
374183
4167183
5462183
6687183
71108183
81228183
91363183
101535183
111778183
122093183
132465183
142922183
153509183
164219183
Stop Event
node limit
Counts
45 → 27
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)

prune14.0ms (0.6%)

Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New24327
Fresh000
Picked011
Done000
Total24428
Error
0.0b
Counts
28 → 4
Alt Table
StatusErrorProgram
7.0b
(*.f64 (cbrt.f64 (fma.f64 x (*.f64 y y) x)) (pow.f64 (cbrt.f64 (fma.f64 x (*.f64 y y) x)) 2))
5.8b
(fma.f64 x (*.f64 y y) x)
36.2b
(pow.f64 (sqrt.f64 (fma.f64 x (*.f64 y y) x)) 2)
0.1b
(fma.f64 y (*.f64 y x) x)
Compiler

Compiled 359 to 122 computations (66% saved)

localize7.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 y (*.f64 y x) x)

series4.0ms (0.2%)

Counts
1 → 24
Calls

6 calls:

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

rewrite49.0ms (2.2%)

Algorithm
batch-egg-rewrite
Rules
484×pow1_binary64
443×add-log-exp_binary64
443×log1p-expm1-u_binary64
443×expm1-log1p-u_binary64
432×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify76.0ms (3.4%)

Algorithm
egg-herbie
Rules
775×sqr-pow_binary64
405×fabs-mul_binary64
390×cube-prod_binary64
381×pow-sqr_binary64
242×unswap-sqr_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
010183
122183
240183
374183
4167183
5454183
6675183
71096183
81216183
91349183
101521183
111764183
122077183
132449183
142908183
153483183
164195183
Stop Event
node limit
Counts
45 → 27
Calls
Call 1
Inputs
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
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.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))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 y (*.f64 y x))
(*.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))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))
(*.f64 (+.f64 1 (pow.f64 y 2)) x)
(fma.f64 (*.f64 y y) x x)
(*.f64 x (fma.f64 y y 1))

prune13.0ms (0.6%)

Pruning

4 alts after pruning (2 fresh and 2 done)

PrunedKeptTotal
New25227
Fresh202
Picked011
Done011
Total27431
Error
0.0b
Counts
31 → 4
Alt Table
StatusErrorProgram
5.8b
(fma.f64 x (*.f64 y y) x)
0.1b
(fma.f64 y (*.f64 y x) x)
1.4b
(pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) 3)
33.8b
(*.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) (cbrt.f64 (pow.f64 (fma.f64 y (*.f64 y x) x) 2)))
Compiler

Compiled 349 to 125 computations (64.2% saved)

localize9.0ms (0.4%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 y (*.f64 y x) x)
0.6b
(cbrt.f64 (fma.f64 y (*.f64 y x) x))
0.7b
(pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) 3)

series30.0ms (1.4%)

Counts
2 → 8
Calls

12 calls:

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

rewrite43.0ms (1.9%)

Algorithm
batch-egg-rewrite
Rules
654×pow1_binary64
611×add-log-exp_binary64
611×log1p-expm1-u_binary64
611×expm1-log1p-u_binary64
72×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify36.0ms (1.6%)

Algorithm
egg-herbie
Rules
841×unswap-sqr_binary64
767×fma-def_binary64
610×fma-neg_binary64
272×cancel-sign-sub-inv_binary64
239×*-commutative_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
026115
177113
224297
3103890
4361190
Stop Event
node limit
Counts
54 → 57
Calls
Call 1
Inputs
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)
(pow.f64 x 1/3)
(+.f64 (*.f64 1/3 (*.f64 (pow.f64 y 2) (pow.f64 x 1/3))) (pow.f64 x 1/3))
(-.f64 (+.f64 (*.f64 1/3 (*.f64 (pow.f64 y 2) (pow.f64 x 1/3))) (pow.f64 x 1/3)) (*.f64 1/9 (*.f64 (pow.f64 y 4) (pow.f64 x 1/3))))
(-.f64 (+.f64 (*.f64 1/3 (*.f64 (pow.f64 y 2) (pow.f64 x 1/3))) (+.f64 (pow.f64 x 1/3) (*.f64 5/81 (*.f64 (pow.f64 y 6) (pow.f64 x 1/3))))) (*.f64 1/9 (*.f64 (pow.f64 y 4) (pow.f64 x 1/3))))
Outputs
x
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(fma.f64 x (*.f64 y y) x)
(*.f64 x (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(fma.f64 x (*.f64 y y) x)
(*.f64 x (fma.f64 y y 1))
(+.f64 (*.f64 (pow.f64 y 2) x) x)
(fma.f64 (*.f64 y y) x x)
(fma.f64 x (*.f64 y y) x)
(*.f64 x (fma.f64 y y 1))
(pow.f64 x 1/3)
(cbrt.f64 x)
(+.f64 (*.f64 1/3 (*.f64 (pow.f64 y 2) (pow.f64 x 1/3))) (pow.f64 x 1/3))
(fma.f64 1/3 (*.f64 (*.f64 y y) (cbrt.f64 x)) (cbrt.f64 x))
(fma.f64 1/3 (*.f64 y (*.f64 y (cbrt.f64 x))) (cbrt.f64 x))
(*.f64 (cbrt.f64 x) (fma.f64 (*.f64 y y) 1/3 1))
(*.f64 (cbrt.f64 x) (fma.f64 y (*.f64 y 1/3) 1))
(-.f64 (+.f64 (*.f64 1/3 (*.f64 (pow.f64 y 2) (pow.f64 x 1/3))) (pow.f64 x 1/3)) (*.f64 1/9 (*.f64 (pow.f64 y 4) (pow.f64 x 1/3))))
(+.f64 (fma.f64 1/3 (*.f64 (*.f64 y y) (cbrt.f64 x)) (cbrt.f64 x)) (*.f64 -1/9 (*.f64 (cbrt.f64 x) (pow.f64 y 4))))
(+.f64 (fma.f64 1/3 (*.f64 y (*.f64 y (cbrt.f64 x))) (cbrt.f64 x)) (*.f64 (*.f64 (cbrt.f64 x) (pow.f64 y 4)) -1/9))
(*.f64 (cbrt.f64 x) (-.f64 (fma.f64 (*.f64 y y) 1/3 1) (*.f64 1/9 (pow.f64 y 4))))
(*.f64 (cbrt.f64 x) (fma.f64 (pow.f64 y 4) -1/9 (fma.f64 y (*.f64 y 1/3) 1)))
(-.f64 (+.f64 (*.f64 1/3 (*.f64 (pow.f64 y 2) (pow.f64 x 1/3))) (+.f64 (pow.f64 x 1/3) (*.f64 5/81 (*.f64 (pow.f64 y 6) (pow.f64 x 1/3))))) (*.f64 1/9 (*.f64 (pow.f64 y 4) (pow.f64 x 1/3))))
(+.f64 (+.f64 (fma.f64 1/3 (*.f64 (*.f64 y y) (cbrt.f64 x)) (cbrt.f64 x)) (*.f64 5/81 (*.f64 (cbrt.f64 x) (pow.f64 y 6)))) (*.f64 -1/9 (*.f64 (cbrt.f64 x) (pow.f64 y 4))))
(-.f64 (fma.f64 1/3 (*.f64 y (*.f64 y (cbrt.f64 x))) (fma.f64 5/81 (*.f64 (cbrt.f64 x) (pow.f64 y 6)) (cbrt.f64 x))) (*.f64 1/9 (*.f64 (cbrt.f64 x) (pow.f64 y 4))))
(fma.f64 (*.f64 (cbrt.f64 x) (pow.f64 y 4)) -1/9 (*.f64 (cbrt.f64 x) (+.f64 (*.f64 y (*.f64 y 1/3)) (fma.f64 5/81 (pow.f64 y 6) 1))))
(*.f64 (cbrt.f64 x) (-.f64 (fma.f64 y (*.f64 y 1/3) (fma.f64 5/81 (pow.f64 y 6) 1)) (*.f64 1/9 (pow.f64 y 4))))
(*.f64 (cbrt.f64 x) (+.f64 (fma.f64 y (*.f64 y 1/3) (fma.f64 5/81 (pow.f64 y 6) 1)) (*.f64 (pow.f64 y 4) -1/9)))

prune39.0ms (1.8%)

Pruning

6 alts after pruning (3 fresh and 3 done)

PrunedKeptTotal
New82284
Fresh011
Picked011
Done022
Total82688
Error
0.0b
Counts
88 → 6
Alt Table
StatusErrorProgram
1.3b
(*.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) 2))
5.8b
(fma.f64 x (*.f64 y y) x)
0.1b
(fma.f64 y (*.f64 y x) x)
1.4b
(pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) 3)
33.8b
(*.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) (cbrt.f64 (pow.f64 (fma.f64 y (*.f64 y x) x) 2)))
1.8b
(*.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x))) 2) (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x))) (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) 2)))
Compiler

Compiled 1346 to 530 computations (60.6% saved)

localize7.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 y (*.f64 y x) x)
0.3b
(*.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) 2))
0.5b
(pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) 2)
0.6b
(cbrt.f64 (fma.f64 y (*.f64 y x) x))

series5.0ms (0.2%)

Counts
2 → 28
Calls

12 calls:

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

rewrite87.0ms (3.9%)

Algorithm
batch-egg-rewrite
Rules
686×pow1_binary64
633×add-log-exp_binary64
633×log1p-expm1-u_binary64
633×expm1-log1p-u_binary64
78×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify36.0ms (1.6%)

Algorithm
egg-herbie
Rules
716×fma-def_binary64
627×cancel-sign-sub-inv_binary64
609×fma-neg_binary64
339×distribute-rgt-neg-in_binary64
245×*-commutative_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
031301
189291
2259270
31075260
43606260
Stop Event
node limit
Counts
63 → 49
Calls
Call 1
Inputs
(pow.f64 (pow.f64 x 2) 1/3)
(+.f64 (*.f64 2/3 (*.f64 (pow.f64 y 2) (pow.f64 (pow.f64 x 2) 1/3))) (pow.f64 (pow.f64 x 2) 1/3))
(-.f64 (+.f64 (*.f64 2/3 (*.f64 (pow.f64 y 2) (pow.f64 (pow.f64 x 2) 1/3))) (pow.f64 (pow.f64 x 2) 1/3)) (*.f64 1/9 (*.f64 (pow.f64 y 4) (pow.f64 (pow.f64 x 2) 1/3))))
(-.f64 (+.f64 (*.f64 2/3 (*.f64 (pow.f64 y 2) (pow.f64 (pow.f64 x 2) 1/3))) (+.f64 (*.f64 4/81 (*.f64 (pow.f64 y 6) (pow.f64 (pow.f64 x 2) 1/3))) (pow.f64 (pow.f64 x 2) 1/3))) (*.f64 1/9 (*.f64 (pow.f64 y 4) (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 2/3 (*.f64 (pow.f64 y 2) (pow.f64 (pow.f64 x 2) 1/3))) (pow.f64 (pow.f64 x 2) 1/3))
(fma.f64 2/3 (*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y)) (cbrt.f64 (*.f64 x x)))
(*.f64 (+.f64 (*.f64 2/3 (*.f64 y y)) 1) (cbrt.f64 (*.f64 x x)))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 2/3 (*.f64 y y) 1))
(-.f64 (+.f64 (*.f64 2/3 (*.f64 (pow.f64 y 2) (pow.f64 (pow.f64 x 2) 1/3))) (pow.f64 (pow.f64 x 2) 1/3)) (*.f64 1/9 (*.f64 (pow.f64 y 4) (pow.f64 (pow.f64 x 2) 1/3))))
(+.f64 (fma.f64 2/3 (*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y)) (cbrt.f64 (*.f64 x x))) (*.f64 -1/9 (*.f64 (cbrt.f64 (*.f64 x x)) (pow.f64 y 4))))
(+.f64 (*.f64 (+.f64 (*.f64 2/3 (*.f64 y y)) 1) (cbrt.f64 (*.f64 x x))) (*.f64 (*.f64 (cbrt.f64 (*.f64 x x)) (pow.f64 y 4)) -1/9))
(*.f64 (cbrt.f64 (*.f64 x x)) (-.f64 (fma.f64 2/3 (*.f64 y y) 1) (*.f64 1/9 (pow.f64 y 4))))
(*.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 (pow.f64 y 4) -1/9 (fma.f64 2/3 (*.f64 y y) 1)))
(-.f64 (+.f64 (*.f64 2/3 (*.f64 (pow.f64 y 2) (pow.f64 (pow.f64 x 2) 1/3))) (+.f64 (*.f64 4/81 (*.f64 (pow.f64 y 6) (pow.f64 (pow.f64 x 2) 1/3))) (pow.f64 (pow.f64 x 2) 1/3))) (*.f64 1/9 (*.f64 (pow.f64 y 4) (pow.f64 (pow.f64 x 2) 1/3))))
(+.f64 (fma.f64 2/3 (*.f64 (cbrt.f64 (*.f64 x x)) (*.f64 y y)) (fma.f64 4/81 (*.f64 (cbrt.f64 (*.f64 x x)) (pow.f64 y 6)) (cbrt.f64 (*.f64 x x)))) (*.f64 -1/9 (*.f64 (cbrt.f64 (*.f64 x x)) (pow.f64 y 4))))
(+.f64 (+.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 (*.f64 x x)) (+.f64 (*.f64 2/3 (*.f64 y y)) (*.f64 4/81 (pow.f64 y 6))))) (*.f64 (*.f64 (cbrt.f64 (*.f64 x x)) (pow.f64 y 4)) -1/9))
(fma.f64 (cbrt.f64 (*.f64 x x)) (fma.f64 2/3 (*.f64 y y) (*.f64 4/81 (pow.f64 y 6))) (*.f64 (+.f64 (*.f64 (pow.f64 y 4) -1/9) 1) (cbrt.f64 (*.f64 x x))))
(*.f64 (cbrt.f64 (*.f64 x x)) (+.f64 (fma.f64 (pow.f64 y 4) -1/9 1) (fma.f64 2/3 (*.f64 y y) (*.f64 4/81 (pow.f64 y 6)))))
(*.f64 (cbrt.f64 (*.f64 x x)) (+.f64 (*.f64 y (fma.f64 2/3 y (*.f64 (pow.f64 y 3) -1/9))) (fma.f64 4/81 (pow.f64 y 6) 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 (*.f64 x y) 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 (*.f64 x y) 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 (+.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)

prune71.0ms (3.2%)

Pruning

7 alts after pruning (3 fresh and 4 done)

PrunedKeptTotal
New1581159
Fresh022
Picked011
Done033
Total1587165
Error
0.0b
Counts
165 → 7
Alt Table
StatusErrorProgram
1.3b
(*.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) 2))
5.8b
(fma.f64 x (*.f64 y y) x)
2.3b
(*.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x))) 3) 2))
0.1b
(fma.f64 y (*.f64 y x) x)
1.4b
(pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) 3)
33.8b
(*.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) (cbrt.f64 (pow.f64 (fma.f64 y (*.f64 y x) x) 2)))
1.8b
(*.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x))) 2) (*.f64 (cbrt.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x))) (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) x)) 2)))
Compiler

Compiled 3367 to 1102 computations (67.3% saved)

regimes99.0ms (4.5%)

Accuracy

Total 0.1b remaining (71.1%)

Threshold costs 0.1b (71.1%)

Counts
27 → 1
Compiler

Compiled 351 to 116 computations (67% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
058
168
Stop Event
saturated
Calls
Call 1
Inputs
(fma.f64 y (*.f64 y x) x)
Outputs
(fma.f64 y (*.f64 y x) x)

end104.0ms (4.7%)

Stop Event
fuel
Compiler

Compiled 134 to 63 computations (53% saved)

Profiling

Loading profile data...