Details

Time bar (total: 5.4s)

analyze55.0ms (1%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
25%25%74.9%0.1%0%0%0%5
37.5%37.5%62.4%0.1%0%0%0%6
50%43.7%43.7%0.1%12.5%0%0%7
60.7%53.1%34.3%0.1%12.5%0%0%8
71.2%57.8%23.4%0.1%18.7%0%0%9
77.9%63.2%18%0.1%18.7%0%0%10
84.5%66%12.1%0.1%21.9%0%0%11
88.3%68.9%9.2%0.1%21.9%0%0%12
Compiler

Compiled 10 to 7 computations (30% saved)

sample768.0ms (14.2%)

Results
723.0ms8256×body256valid
29.0ms342×body256infinite
Bogosity

preprocess22.0ms (0.4%)

Algorithm
egg-herbie
Rules
30×associate-*l*_binary64
22×associate-*r*_binary64
11×*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
12420
25220
38620
48620
022
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(*.f64 (*.f64 (*.f64 x 3) y) y)
(*.f64 (*.f64 (*.f64 y 3) x) x)
Outputs
(*.f64 (*.f64 (*.f64 x 3) y) y)
(*.f64 (*.f64 x 3) (*.f64 y y))
(*.f64 x (*.f64 3 (*.f64 y y)))
(*.f64 3 (*.f64 (*.f64 x y) y))
(*.f64 3 (*.f64 y (*.f64 x y)))
(*.f64 (*.f64 (*.f64 y 3) x) x)
(*.f64 x (*.f64 (*.f64 x 3) y))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 3 (*.f64 x (*.f64 x y)))
Compiler

Compiled 11 to 8 computations (27.3% saved)

simplify9.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0710
11410
22910
34610
44610
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(*.f64 (*.f64 (*.f64 x 3) y) y)
Outputs
(*.f64 (*.f64 (*.f64 x 3) y) y)
(*.f64 (*.f64 x 3) (*.f64 y y))
(*.f64 x (*.f64 3 (*.f64 y y)))

eval1.0ms (0%)

Compiler

Compiled 16 to 10 computations (37.5% saved)

prune1.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.1b
Counts
3 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
13.3b
(*.f64 x (*.f64 3 (*.f64 y y)))
0.3b
(*.f64 (*.f64 (*.f64 x 3) y) y)
Compiler

Compiled 18 to 12 computations (33.3% saved)

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.1b
(*.f64 3 (*.f64 y y))
12.9b
(*.f64 x (*.f64 3 (*.f64 y y)))
Compiler

Compiled 20 to 9 computations (55% saved)

series6.0ms (0.1%)

Counts
2 → 36
Calls

9 calls:

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

rewrite70.0ms (1.3%)

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

Useful iterations: 0 (0.0ms)

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

simplify209.0ms (3.9%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
09324
118324
239324
390324
4246324
5825324
61076324
71490324
81590324
91725324
101894324
112137324
122450324
132822324
143282324
153867324
164575324
175435324
185859324
196173324
206481324
216563324
226599324
Stop Event
node limit
Counts
58 → 26
Calls
Call 1
Inputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
Outputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))

localize15.0ms (0.3%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series10.0ms (0.2%)

Counts
2 → 48
Calls

12 calls:

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

rewrite68.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
661×pow1_binary64
608×add-log-exp_binary64
608×log1p-expm1-u_binary64
608×expm1-log1p-u_binary64
596×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify218.0ms (4.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010408
123408
245408
384408
4245408
5820408
61059408
71473408
81573408
91708408
101880408
112125408
122440408
132810408
143269408
153852408
164558408
175420408
185850408
196168408
206472408
216552408
226588408
Stop Event
node limit
Counts
74 → 30
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
Outputs
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 (*.f64 3 y) x)
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 y x) (*.f64 3 y))

eval23.0ms (0.4%)

Compiler

Compiled 526 to 335 computations (36.3% saved)

prune29.0ms (0.5%)

Pruning

10 alts after pruning (8 fresh and 2 done)

PrunedKeptTotal
New48856
Fresh000
Picked011
Done011
Total481058
Error
0.0b
Counts
58 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
29.0b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 y))) 2) y)
33.6b
(cbrt.f64 (pow.f64 (*.f64 x (*.f64 3 (*.f64 y y))) 3))
0.3b
(*.f64 (pow.f64 (*.f64 x (*.f64 3 y)) 1) y)
33.5b
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
0.3b
(*.f64 (*.f64 y x) (*.f64 3 y))
0.3b
(*.f64 (*.f64 (*.f64 x 3) y) y)
13.3b
(*.f64 x (*.f64 3 (*.f64 y y)))
21.0b
(*.f64 (-.f64 (+.f64 1 (*.f64 x (*.f64 3 y))) 1) y)
13.4b
(*.f64 3 (*.f64 (pow.f64 y 2) x))
0.3b
(*.f64 (*.f64 3 (*.f64 y x)) y)
Compiler

Compiled 188 to 138 computations (26.6% saved)

localize14.0ms (0.3%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.3b
(*.f64 (*.f64 y x) (*.f64 3 y))
Compiler

Compiled 18 to 9 computations (50% saved)

series3.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite63.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify194.0ms (3.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08240
117240
237240
383240
4223240
5736240
6997240
71411240
81511240
91646240
101818240
112061240
122374240
132744240
143202240
153791240
164499240
175361240
185787240
196103240
206411240
216489240
226523240
Stop Event
node limit
Counts
37 → 15
Calls
Call 1
Inputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
Outputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))

localize13.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 9 computations (55% saved)

series5.0ms (0.1%)

Counts
2 → 24
Calls

12 calls:

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

rewrite76.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
677×pow1_binary64
623×add-log-exp_binary64
623×log1p-expm1-u_binary64
623×expm1-log1p-u_binary64
610×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify192.0ms (3.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08240
117240
237240
383240
4223240
5736240
6997240
71411240
81511240
91646240
101818240
112061240
122374240
132744240
143202240
153791240
164499240
175361240
185787240
196103240
206411240
216489240
226523240
Stop Event
node limit
Counts
48 → 26
Calls
Call 1
Inputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
Outputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))

localize16.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.2b
(*.f64 3 (*.f64 (pow.f64 y 2) x))
12.9b
(*.f64 (pow.f64 y 2) x)
Compiler

Compiled 21 to 14 computations (33.3% saved)

series7.0ms (0.1%)

Counts
2 → 0
Calls

12 calls:

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

rewrite73.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
679×pow1_binary64
626×add-log-exp_binary64
625×log1p-expm1-u_binary64
625×expm1-log1p-u_binary64
613×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify12.0ms (0.2%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

localize22.0ms (0.4%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f64 (*.f64 x 3))
0.1b
(*.f64 (sqrt.f64 (*.f64 x 3)) y)
0.2b
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
Compiler

Compiled 27 to 19 computations (29.6% saved)

series23.0ms (0.4%)

Counts
3 → 24
Calls

15 calls:

TimeVariablePointExpression
5.0ms
y
@0
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
3.0ms
x
@0
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
3.0ms
x
@-inf
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
2.0ms
x
@inf
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
2.0ms
y
@inf
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)

rewrite86.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
749×pow1_binary64
693×add-log-exp_binary64
692×log1p-expm1-u_binary64
692×expm1-log1p-u_binary64
675×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify193.0ms (3.6%)

Algorithm
egg-herbie
Rules
771×fabs-mul_binary64
763×sqr-pow_binary64
759×cube-prod_binary64
662×pow-sqr_binary64
565×unswap-sqr_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
013312
129252
266252
3188252
4859252
51264252
62162252
72267252
82423252
92605252
102813252
113092252
123458252
133888252
144463252
155200252
166113252
176637252
187099252
197519252
207769252
217809252
Stop Event
node limit
Counts
83 → 63
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
Outputs
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))
(*.f64 (*.f64 y (sqrt.f64 3)) (sqrt.f64 x))
(*.f64 y (*.f64 (sqrt.f64 3) (sqrt.f64 x)))
(*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x)))

localize16.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 y))) 2) y)
0.2b
(*.f64 x (*.f64 3 y))
0.2b
(pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 y))) 2)
7.5b
(sqrt.f64 (*.f64 x (*.f64 3 y)))
Compiler

Compiled 38 to 26 computations (31.6% saved)

series23.0ms (0.4%)

Counts
4 → 48
Calls

24 calls:

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

rewrite104.0ms (1.9%)

Algorithm
batch-egg-rewrite
Rules
798×pow1_binary64
738×add-log-exp_binary64
737×log1p-expm1-u_binary64
737×expm1-log1p-u_binary64
722×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify115.0ms (2.1%)

Algorithm
egg-herbie
Rules
919×fma-def_binary64
548×distribute-lft-neg-in_binary64
531×distribute-rgt-neg-in_binary64
483×associate-*l*_binary64
361×associate-*r*_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
019528
146408
2140408
3432408
41793408
52967408
64319408
76224408
Stop Event
node limit
Counts
136 → 82
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
Outputs
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 x (*.f64 3 y))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 3) 2) x))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))
(*.f64 -1 (*.f64 (pow.f64 y 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(*.f64 (*.f64 y y) (*.f64 x (pow.f64 (sqrt.f64 3) 2)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 x (*.f64 y y)))
(*.f64 y (*.f64 x (*.f64 3 y)))

eval89.0ms (1.7%)

Compiler

Compiled 2395 to 1628 computations (32% saved)

prune48.0ms (0.9%)

Pruning

10 alts after pruning (4 fresh and 6 done)

PrunedKeptTotal
New2064210
Fresh303
Picked011
Done156
Total21010220
Error
0.0b
Counts
220 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
0.3b
(*.f64 (*.f64 y x) (*.f64 3 y))
0.3b
(*.f64 (*.f64 (*.f64 x 3) y) y)
22.4b
(*.f64 3 (-.f64 (+.f64 1 (*.f64 y (*.f64 y x))) 1))
29.0b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 y))) 2) y)
13.3b
(*.f64 x (*.f64 3 (*.f64 y y)))
33.5b
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
0.3b
(*.f64 (*.f64 (*.f64 3 y) x) y)
0.3b
(*.f64 (*.f64 3 (*.f64 y x)) y)
13.4b
(*.f64 (*.f64 y y) (*.f64 x 3))
0.3b
(*.f64 3 (pow.f64 (*.f64 y (*.f64 y x)) 1))
Compiler

Compiled 100 to 71 computations (29% saved)

localize20.0ms (0.4%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(*.f64 3 (-.f64 (+.f64 1 (*.f64 y (*.f64 y x))) 1))
0.2b
(*.f64 y (*.f64 y x))
2.8b
(-.f64 (+.f64 1 (*.f64 y (*.f64 y x))) 1)
Compiler

Compiled 41 to 18 computations (56.1% saved)

series5.0ms (0.1%)

Counts
3 → 72
Calls

18 calls:

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

rewrite81.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
640×prod-diff_binary64
497×fma-def_binary64
456×log-prod_binary64
293×pow-prod-down_binary64
243×pow2_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01042
121524
2288524
Stop Event
node limit
Counts
3 → 197
Calls
Call 1
Inputs
(-.f64 (+.f64 1 (*.f64 y (*.f64 y x))) 1)
(*.f64 y (*.f64 y x))
(*.f64 3 (-.f64 (+.f64 1 (*.f64 y (*.f64 y x))) 1))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (fma.f64 y (*.f64 y x) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (*.f64 (fma.f64 y (*.f64 y x) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 y y)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 y (*.f64 y x) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (fma.f64 y (*.f64 y x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 y (*.f64 y x) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 (*.f64 y y)) x)) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (*.f64 y y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (*.f64 y y)) x))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (*.f64 y y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x (*.f64 y y)))))) (#(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 x (*.f64 y y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y y) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 y x) 2)) (*.f64 (cbrt.f64 (*.f64 y x)) y))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (*.f64 y y))) (cbrt.f64 (pow.f64 (*.f64 y (sqrt.f64 x)) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 y (sqrt.f64 x)) 4)) (cbrt.f64 (*.f64 x (*.f64 y y))))))) (#(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 (sqrt.f64 (*.f64 y x)) (*.f64 (sqrt.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 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1) (/.f64 1 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1) (/.f64 1 (fma.f64 y (*.f64 y x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) 1) (-.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 y y) 1) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y (cbrt.f64 (pow.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 (pow.f64 (*.f64 y (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 1 (/.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2)) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 y (*.f64 y x) 2) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (-.f64 1 (*.f64 (fma.f64 y (*.f64 y x) 1) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1) (fma.f64 y (*.f64 y x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1)) (neg.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1)) (neg.f64 (fma.f64 y (*.f64 y x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1 (pow.f64 (fma.f64 y (*.f64 y x) -1) 3)) (+.f64 1 (-.f64 (pow.f64 (fma.f64 y (*.f64 y x) -1) 2) (fma.f64 y (*.f64 y x) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1 (pow.f64 (fma.f64 y (*.f64 y x) -1) 2)) (-.f64 1 (fma.f64 y (*.f64 y x) -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 y (sqrt.f64 x)) 4) 1/2)))) (#(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 y (sqrt.f64 x)) 6) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2)) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 y (*.f64 y x) 2) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 x) y) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (sqrt.f64 x)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (*.f64 y y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (sqrt.f64 x)) 6))))) (#(struct:change #<rule egg-rr> (2) ((x hypot.f64 (*.f64 y (sqrt.f64 x)) (sqrt.f64 (*.f64 (*.f64 x (*.f64 y y)) (fma.f64 y (*.f64 y x) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (*.f64 (log1p.f64 (*.f64 x (*.f64 y y))) 1))))) (#(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 exp.f64 (*.f64 (log.f64 (*.f64 x (*.f64 y y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x (*.f64 y y)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 y (*.f64 y x) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 y (*.f64 y x) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y (*.f64 y x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 y y) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y x) y 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (*.f64 y y)) 1 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 y (*.f64 y x) 1) 1 -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y y) x 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (*.f64 y x) 2)) (*.f64 (cbrt.f64 (*.f64 y x)) y) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x (*.f64 y y))) (cbrt.f64 (pow.f64 (*.f64 y (sqrt.f64 x)) 4)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (*.f64 y (sqrt.f64 x)) 4)) (cbrt.f64 (*.f64 x (*.f64 y y))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (*.f64 y x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) 2) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) 2) (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) 2) (*.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 y x)) (*.f64 (sqrt.f64 (*.f64 y x)) y) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (sqrt.f64 x)) (*.f64 y (sqrt.f64 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) (*.f64 y x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) (hypot.f64 1 (*.f64 y (sqrt.f64 x))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) (*.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1) (/.f64 1 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 (pow.f64 y 6) (pow.f64 x 3) 1) (/.f64 1 (fma.f64 (*.f64 x (*.f64 y y)) (fma.f64 y (*.f64 y x) -1) 1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1) (/.f64 1 (fma.f64 y (*.f64 y x) 2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (*.f64 y (sqrt.f64 x)) 4)) (/.f64 1 (-.f64 1 (*.f64 x (*.f64 y y)))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) -1)) 2) (cbrt.f64 (fma.f64 y (*.f64 y x) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (fma.f64 y (*.f64 y x) -1)) (sqrt.f64 (fma.f64 y (*.f64 y x) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) 1) (-.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) 1) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 y (sqrt.f64 x) 1) (fma.f64 y (sqrt.f64 x) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 y y) 1) x 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (cbrt.f64 (pow.f64 (*.f64 y x) 2))) (cbrt.f64 (*.f64 y x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (sqrt.f64 (*.f64 y x))) (sqrt.f64 (*.f64 y x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 y x) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 y x) (sqrt.f64 y)) (sqrt.f64 y) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (*.f64 y (cbrt.f64 x)) 2) (cbrt.f64 x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 y y) (sqrt.f64 x)) (sqrt.f64 x) 0)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (fma.f64 y (*.f64 y x) -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (*.f64 (fma.f64 y (*.f64 y x) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 y y)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 y (*.f64 y x) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 -1 (fma.f64 y (*.f64 y x) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 y (*.f64 y x) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 (*.f64 y y)) x)) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (*.f64 y y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (*.f64 y y)) x))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (*.f64 y y)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (fma.f64 y (*.f64 y x) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2))) (/.f64 1 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2)) (/.f64 1 (fma.f64 y (*.f64 y x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2)) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 y (*.f64 y x) 2) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (-.f64 1 (*.f64 (fma.f64 y (*.f64 y x) 1) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1) (fma.f64 y (*.f64 y x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1)) (neg.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1)) (neg.f64 (fma.f64 y (*.f64 y x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1 (pow.f64 (fma.f64 y (*.f64 y x) -1) 3)) (+.f64 1 (-.f64 (pow.f64 (fma.f64 y (*.f64 y x) -1) 2) (fma.f64 y (*.f64 y x) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1 (pow.f64 (fma.f64 y (*.f64 y x) -1) 2)) (-.f64 1 (fma.f64 y (*.f64 y x) -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 y (sqrt.f64 x)) 4) 1/2)))) (#(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 y (sqrt.f64 x)) 6) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2)) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 y (*.f64 y x) 2) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 x) y) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 y (sqrt.f64 x)) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (*.f64 y y)) x))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (*.f64 y y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (sqrt.f64 x)) 6))))) (#(struct:change #<rule egg-rr> (2) ((x hypot.f64 (*.f64 y (sqrt.f64 x)) (sqrt.f64 (*.f64 (*.f64 x (*.f64 y y)) (fma.f64 y (*.f64 y x) -1))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 y y))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (*.f64 (log1p.f64 (*.f64 x (*.f64 y y))) 1))))) (#(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 exp.f64 (*.f64 (log.f64 (*.f64 x (*.f64 y y))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x (*.f64 y y)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 y (*.f64 y x) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 y (*.f64 y x) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y (*.f64 y x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 y y) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y x) y 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (*.f64 y y)) 1 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 y (*.f64 y x) 1) 1 -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y y) x 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (*.f64 y x) 2)) (*.f64 (cbrt.f64 (*.f64 y x)) y) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x (*.f64 y y))) (cbrt.f64 (pow.f64 (*.f64 y (sqrt.f64 x)) 4)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (*.f64 y (sqrt.f64 x)) 4)) (cbrt.f64 (*.f64 x (*.f64 y y))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (*.f64 y x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) 2) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) 2) (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) 2) (*.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) 1)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 y x)) (*.f64 (sqrt.f64 (*.f64 y x)) y) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (sqrt.f64 x)) (*.f64 y (sqrt.f64 x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) (*.f64 y x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) (hypot.f64 1 (*.f64 y (sqrt.f64 x))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) (*.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1) (/.f64 1 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2))) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 (pow.f64 y 6) (pow.f64 x 3) 1) (/.f64 1 (fma.f64 (*.f64 x (*.f64 y y)) (fma.f64 y (*.f64 y x) -1) 1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1) (/.f64 1 (fma.f64 y (*.f64 y x) 2)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (*.f64 y (sqrt.f64 x)) 4)) (/.f64 1 (-.f64 1 (*.f64 x (*.f64 y y)))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 y (*.f64 y x) -1)) 2) (cbrt.f64 (fma.f64 y (*.f64 y x) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (fma.f64 y (*.f64 y x) -1)) (sqrt.f64 (fma.f64 y (*.f64 y x) -1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) 1) (-.f64 (hypot.f64 1 (*.f64 y (sqrt.f64 x))) 1) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 y (sqrt.f64 x) 1) (fma.f64 y (sqrt.f64 x) -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 y y) 1) x 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (cbrt.f64 (pow.f64 (*.f64 y x) 2))) (cbrt.f64 (*.f64 y x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 y (sqrt.f64 (*.f64 y x))) (sqrt.f64 (*.f64 y x)) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 y x) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 y x) (sqrt.f64 y)) (sqrt.f64 y) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (*.f64 y (cbrt.f64 x)) 2) (cbrt.f64 x) 0)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 y y) (sqrt.f64 x)) (sqrt.f64 x) 0)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 3 (*.f64 (fma.f64 y (*.f64 y x) -1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 3 (*.f64 3 (fma.f64 y (*.f64 y x) -1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (*.f64 x (*.f64 y y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (fma.f64 y (*.f64 y x) 1) 3) -3)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 3 (fma.f64 y (*.f64 y x) 1)) -3)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (pow.f64 (exp.f64 y) x) (+.f64 y y))) (*.f64 x (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (pow.f64 (exp.f64 y) x) (*.f64 y 3)))) (log.f64 (sqrt.f64 (pow.f64 (pow.f64 (exp.f64 y) x) (*.f64 y 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (*.f64 x (*.f64 y y)) 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1) 3) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1) 3) (fma.f64 y (*.f64 y x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 3) -1)) (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) (fma.f64 y (*.f64 y x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (+.f64 (pow.f64 (fma.f64 y (*.f64 y x) 1) 2) -1)) (fma.f64 y (*.f64 y x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (*.f64 x (*.f64 y y)) 3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 9 (pow.f64 (*.f64 y (sqrt.f64 x)) 4)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (*.f64 x (*.f64 y y)) 3) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (*.f64 x (*.f64 y y)) 3)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 3) (*.f64 y (sqrt.f64 x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 9 (pow.f64 (*.f64 y (sqrt.f64 x)) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (exp.f64 y) x) (*.f64 y 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (*.f64 x (*.f64 y y)) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (*.f64 x (*.f64 y y)) 3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (*.f64 x (*.f64 y y)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (*.f64 x (*.f64 y y)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (*.f64 x (*.f64 y y)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (*.f64 x (*.f64 y y)) 3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 y (*.f64 y x) 1) 3 -3)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 3 (fma.f64 y (*.f64 y x) 1) -3)))))

simplify204.0ms (3.8%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08576
117576
237576
382576
4223576
5762576
61029576
71443576
81543576
91678576
101850576
112093576
122408576
132780576
143240576
153829576
164541576
175401576
185827576
196143576
206449576
216527576
226561576
Stop Event
node limit
Counts
269 → 128
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 (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 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.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))
(*.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))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))

localize9.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 30 to 12 computations (60% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

TimeVariablePointExpression
0.0ms
y
@0
(*.f64 3 (pow.f64 (*.f64 y (*.f64 y x)) 1))
0.0ms
x
@-inf
(*.f64 3 (pow.f64 (*.f64 y (*.f64 y x)) 1))
0.0ms
y
@inf
(*.f64 3 (pow.f64 (*.f64 y (*.f64 y x)) 1))
0.0ms
x
@inf
(*.f64 3 (pow.f64 (*.f64 y (*.f64 y x)) 1))
0.0ms
y
@-inf
(*.f64 3 (pow.f64 (*.f64 y (*.f64 y x)) 1))

rewrite55.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
694×pow1_binary64
640×add-log-exp_binary64
640×log1p-expm1-u_binary64
640×expm1-log1p-u_binary64
627×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify172.0ms (3.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08240
117240
237240
383240
4223240
5736240
6997240
71411240
81511240
91646240
101818240
112061240
122374240
132744240
143202240
153791240
164499240
175361240
185787240
196103240
206411240
216489240
226523240
Stop Event
node limit
Counts
35 → 13
Calls
Call 1
Inputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
Outputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
13.0b
(*.f64 (*.f64 y y) (*.f64 x 3))
Compiler

Compiled 18 to 9 computations (50% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite55.0ms (1%)

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

Useful iterations: 0 (0.0ms)

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

simplify170.0ms (3.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08240
117240
237240
383240
4223240
5736240
6997240
71411240
81511240
91646240
101818240
112061240
122374240
132744240
143202240
153791240
164499240
175361240
185787240
196103240
206411240
216489240
226523240
Stop Event
node limit
Counts
35 → 13
Calls
Call 1
Inputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
Outputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))

localize8.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series3.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite56.0ms (1%)

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

Useful iterations: 0 (0.0ms)

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

simplify190.0ms (3.5%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010408
123408
245408
384408
4240408
5827408
61074408
71488408
81588408
91723408
101895408
112140408
122453408
132823408
143278408
153867408
164573408
175431408
185859408
196173408
206481408
216561408
226595408
Stop Event
node limit
Counts
74 → 30
Calls
Call 1
Inputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
Outputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 y (*.f64 3 x))

eval48.0ms (0.9%)

Compiler

Compiled 2459 to 1341 computations (45.5% saved)

prune31.0ms (0.6%)

Pruning

9 alts after pruning (3 fresh and 6 done)

PrunedKeptTotal
New1843187
Fresh000
Picked011
Done459
Total1889197
Error
0b
Counts
197 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
0.3b
(*.f64 (*.f64 y x) (*.f64 3 y))
0.3b
(*.f64 (*.f64 (*.f64 x 3) y) y)
1.0b
(*.f64 3 (*.f64 (*.f64 (*.f64 y x) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y)))
0.3b
(*.f64 3 (*.f64 (*.f64 y x) y))
29.0b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 y))) 2) y)
33.5b
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
0.3b
(*.f64 (*.f64 (*.f64 3 y) x) y)
13.3b
(*.f64 x (*.f64 y (*.f64 y 3)))
13.4b
(*.f64 (*.f64 y y) (*.f64 x 3))
Compiler

Compiled 91 to 63 computations (30.8% saved)

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 7 computations (65% saved)

series3.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite60.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
657×pow1_binary64
604×add-log-exp_binary64
604×log1p-expm1-u_binary64
604×expm1-log1p-u_binary64
592×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify259.0ms (4.8%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08408
117408
237408
383408
4223408
5736408
6997408
71411408
81511408
91646408
101818408
112061408
122374408
132744408
143202408
153791408
164499408
175361408
185787408
196103408
206411408
216489408
226523408
Stop Event
node limit
Counts
72 → 28
Calls
Call 1
Inputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.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 (pow.f64 y 2) x)
Outputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 (*.f64 y y) (*.f64 3 x))
(*.f64 y (*.f64 y (*.f64 3 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))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))

localize18.0ms (0.3%)

Local error

Found 4 expressions with local error:

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

Compiled 47 to 21 computations (55.3% saved)

series80.0ms (1.5%)

Counts
4 → 36
Calls

18 calls:

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

rewrite72.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
794×pow1_binary64
732×add-log-exp_binary64
732×log1p-expm1-u_binary64
732×expm1-log1p-u_binary64
714×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0928
118428
2210228
Stop Event
node limit
Counts
4 → 62
Calls
Call 1
Inputs
(cbrt.f64 y)
(pow.f64 (cbrt.f64 y) 2)
(*.f64 (*.f64 y x) (pow.f64 (cbrt.f64 y) 2))
(*.f64 (*.f64 (*.f64 y x) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y))
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 y (*.f64 (pow.f64 (cbrt.f64 y) 2) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (*.f64 (pow.f64 (cbrt.f64 y) 2) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (*.f64 (pow.f64 (cbrt.f64 y) 2) x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (*.f64 (pow.f64 (cbrt.f64 y) 2) x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (cbrt.f64 y) (sqrt.f64 (*.f64 y x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (*.f64 y (cbrt.f64 y)) (pow.f64 (*.f64 y x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (pow.f64 (cbrt.f64 y) 2)) (*.f64 y x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (*.f64 (pow.f64 (cbrt.f64 y) 2) x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (*.f64 y y) (pow.f64 (*.f64 y x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (*.f64 y x) 3) (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (*.f64 (pow.f64 (cbrt.f64 y) 2) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (*.f64 (pow.f64 (cbrt.f64 y) 2) x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (*.f64 (pow.f64 (cbrt.f64 y) 2) 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 (pow.f64 (exp.f64 y) x) y))))) (#(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 y (pow.f64 (*.f64 y (*.f64 (pow.f64 (cbrt.f64 y) 2) 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))))))))

simplify152.0ms (2.8%)

Algorithm
egg-herbie
Rules
1156×sqr-pow_binary64
699×cube-prod_binary64
680×fabs-mul_binary64
601×pow-sqr_binary64
368×unpow3_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
013276
132276
260276
3114276
4259276
5825276
61411276
71596276
81838276
92139276
102553276
113163276
123886276
134781276
145285276
155791276
166225276
176576276
186768276
Stop Event
node limit
Counts
98 → 66
Calls
Call 1
Inputs
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 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 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 (*.f64 1 (pow.f64 y 5)) 1/3) x)
(*.f64 (cbrt.f64 (pow.f64 y 5)) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 x (*.f64 y y))
(*.f64 (*.f64 x y) y)
(*.f64 y (*.f64 y x))

localize48.0ms (0.9%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series2.0ms (0%)

Counts
2 → 36
Calls

9 calls:

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

rewrite58.0ms (1.1%)

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

Useful iterations: 0 (0.0ms)

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

simplify182.0ms (3.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
09324
118324
239324
390324
4246324
5825324
61076324
71490324
81590324
91725324
101894324
112137324
122450324
132822324
143282324
153867324
164575324
175435324
185859324
196173324
206481324
216563324
226599324
Stop Event
node limit
Counts
62 → 30
Calls
Call 1
Inputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (pow.f64 y 2))
Outputs
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (*.f64 y y) x))
(*.f64 3 (*.f64 y (*.f64 y x)))
(*.f64 y (*.f64 3 (*.f64 y x)))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))
(*.f64 3 (pow.f64 y 2))
(*.f64 3 (*.f64 y y))

eval37.0ms (0.7%)

Compiler

Compiled 1861 to 1011 computations (45.7% saved)

prune22.0ms (0.4%)

Pruning

9 alts after pruning (0 fresh and 9 done)

PrunedKeptTotal
New1440144
Fresh000
Picked011
Done088
Total1449153
Error
0b
Counts
153 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
0.3b
(*.f64 (*.f64 y x) (*.f64 3 y))
0.3b
(*.f64 (*.f64 (*.f64 x 3) y) y)
1.0b
(*.f64 3 (*.f64 (*.f64 (*.f64 y x) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y)))
0.3b
(*.f64 3 (*.f64 (*.f64 y x) y))
29.0b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 y))) 2) y)
33.5b
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
0.3b
(*.f64 (*.f64 (*.f64 3 y) x) y)
13.3b
(*.f64 x (*.f64 y (*.f64 y 3)))
13.4b
(*.f64 (*.f64 y y) (*.f64 x 3))
Compiler

Compiled 91 to 63 computations (30.8% saved)

regimes53.0ms (1%)

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

5 calls:

10.0ms
x
10.0ms
y
10.0ms
(*.f64 x 3)
10.0ms
(*.f64 x 3)
9.0ms
(*.f64 (*.f64 (*.f64 x 3) y) y)
Results
ErrorSegmentsBranch
0.3b1x
0.3b1y
0.3b1(*.f64 (*.f64 (*.f64 x 3) y) y)
0.3b1(*.f64 x 3)
0.3b1(*.f64 x 3)
Compiler

Compiled 171 to 105 computations (38.6% saved)

regimes15.0ms (0.3%)

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

3 calls:

5.0ms
y
4.0ms
(*.f64 x 3)
4.0ms
x
Results
ErrorSegmentsBranch
0.3b1x
0.3b1y
0.3b1(*.f64 x 3)
Compiler

Compiled 41 to 26 computations (36.6% saved)

regimes46.0ms (0.8%)

Accuracy

Total -13.2b remaining (-4225.2%)

Threshold costs -13.2b (-4225.2%)

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

2 calls:

41.0ms
y
3.0ms
x
Results
ErrorSegmentsBranch
0.3b1x
0.3b1y
Compiler

Compiled 22 to 14 computations (36.4% saved)

simplify5.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01130
11830
Stop Event
done
saturated
Calls
Call 1
Inputs
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 (*.f64 (*.f64 3 y) x) y)
(*.f64 3 (*.f64 (*.f64 y x) y))
Outputs
(*.f64 (*.f64 y x) (*.f64 3 y))
(*.f64 (*.f64 y x) (*.f64 y 3))
(*.f64 (*.f64 (*.f64 3 y) x) y)
(*.f64 y (*.f64 x (*.f64 y 3)))
(*.f64 3 (*.f64 (*.f64 y x) y))
(*.f64 3 (*.f64 y (*.f64 y x)))
Compiler

Compiled 27 to 18 computations (33.3% saved)

soundness222.0ms (4.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010408
123408
245408
384408
4245408
5820408
61059408
71473408
81573408
91708408
101880408
112125408
122440408
132810408
143269408
153852408
164558408
175420408
185850408
196168408
206472408
216552408
226588408
Stop Event
node limit
Compiler

Compiled 45 to 31 computations (31.1% saved)

end29.0ms (0.5%)

Compiler

Compiled 23 to 13 computations (43.5% saved)

Profiling

Loading profile data...