Details

Time bar (total: 5.3s)

analyze100.0ms (1.9%)

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
28.6%25%62.4%0.1%12.5%0%0%6
50%43.7%43.7%0.1%12.5%0%0%7
57.7%46.8%34.3%0.1%18.7%0%0%8
71.2%57.8%23.4%0.1%18.7%0%0%9
77%60.1%18%0.1%21.9%0%0%10
84.5%66%12.1%0.1%21.9%0%0%11
88%67.3%9.2%0.1%23.4%0%0%12
Compiler

Compiled 10 to 7 computations (30% saved)

sample1.0s (19.4%)

Results
1.0s8256×body256valid
18.0ms174×body256infinite
Bogosity

preprocess55.0ms (1%)

Algorithm
egg-herbie
Rules
25×associate-*l*_binary64
18×associate-*r*_binary64
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
12220
25020
37020
47120
022
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(*.f64 (*.f64 (*.f64 x 3) x) y)
(*.f64 (*.f64 (*.f64 y 3) y) x)
Outputs
(*.f64 (*.f64 (*.f64 x 3) x) y)
(*.f64 (*.f64 x 3) (*.f64 x y))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 (*.f64 (*.f64 y 3) y) x)
(*.f64 x (*.f64 y (*.f64 3 y)))
(*.f64 x (*.f64 3 (*.f64 y y)))
Compiler

Compiled 11 to 8 computations (27.3% saved)

simplify9.0ms (0.2%)

Algorithm
egg-herbie
Rules
15×associate-*l*_binary64
13×associate-*r*_binary64
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0710
11310
22710
34510
44810
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(*.f64 (*.f64 (*.f64 x 3) x) y)
Outputs
(*.f64 (*.f64 (*.f64 x 3) x) y)
(*.f64 (*.f64 x 3) (*.f64 x y))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 x (*.f64 x (*.f64 3 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
9.9b
(*.f64 (*.f64 (*.f64 x 3) x) y)
0.2b
(*.f64 x (*.f64 x (*.f64 3 y)))
Compiler

Compiled 18 to 12 computations (33.3% saved)

localize9.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series8.0ms (0.2%)

Counts
2 → 48
Calls

12 calls:

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

rewrite62.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify198.0ms (3.7%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010408
122408
245408
387408
4237408
5817408
61059408
71473408
81573408
91706408
101878408
112123408
122436408
132806408
143263408
153854408
164564408
175424408
185846408
196160408
206464408
216540408
226574408
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 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))

localize9.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series3.0ms (0.1%)

Counts
2 → 36
Calls

9 calls:

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

rewrite62.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify186.0ms (3.5%)

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
09324
119324
241324
391324
4255324
5825324
61049324
71463324
81563324
91696324
101868324
112109324
122426324
132798324
143253324
153840324
164550324
175410324
185836324
196154324
206462324
216542324
226578324
Stop Event
node limit
Counts
62 → 30
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))

eval15.0ms (0.3%)

Compiler

Compiled 580 to 394 computations (32.1% saved)

prune15.0ms (0.3%)

Pruning

9 alts after pruning (7 fresh and 2 done)

PrunedKeptTotal
New53760
Fresh000
Picked011
Done011
Total53962
Error
0.0b
Counts
62 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
10.0b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 x (*.f64 x 3))) 2) y)
9.9b
(*.f64 (*.f64 3 (pow.f64 x 2)) y)
22.5b
(pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 (*.f64 x y)))) 2)
0.2b
(*.f64 x (*.f64 x (*.f64 3 y)))
0.3b
(*.f64 x (*.f64 3 (*.f64 y x)))
1.0b
(*.f64 x (pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 y))) 3))
9.9b
(*.f64 (*.f64 (*.f64 x 3) x) y)
9.9b
(*.f64 3 (*.f64 y (pow.f64 x 2)))
0.2b
(*.f64 x (*.f64 y (*.f64 3 x)))
Compiler

Compiled 162 to 118 computations (27.2% saved)

localize8.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series3.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite59.0ms (1.1%)

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

Useful iterations: 0 (0.0ms)

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

simplify193.0ms (3.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010408
122408
245408
387408
4237408
5817408
61059408
71473408
81573408
91706408
101878408
112123408
122436408
132806408
143263408
153854408
164564408
175424408
185846408
196160408
206464408
216540408
226574408
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 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 9 computations (55% saved)

series3.0ms (0.1%)

Counts
2 → 24
Calls

12 calls:

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

rewrite56.0ms (1%)

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

Useful iterations: 0 (0.0ms)

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

simplify174.0ms (3.3%)

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
379240
4221240
5742240
61007240
71421240
81521240
91656240
101828240
112073240
122386240
132758240
143212240
153801240
164509240
175369240
185793240
196113240
206419240
216499240
226533240
Stop Event
node limit
Counts
48 → 26
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))

localize9.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 21 to 14 computations (33.3% saved)

series4.0ms (0.1%)

Counts
2 → 0
Calls

12 calls:

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

rewrite56.0ms (1%)

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 y (pow.f64 x 2))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 y (*.f64 x x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (*.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (*.f64 x x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (*.f64 x x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (sqrt.f64 y)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 x 4) (*.f64 y y)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (exp.f64 x) x) y))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (*.f64 x x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 y 3) (pow.f64 (*.f64 x x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (*.f64 x x) 3) (pow.f64 y 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (*.f64 x x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 y (*.f64 (*.f64 x x) 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (*.f64 (*.f64 x x) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (*.f64 (*.f64 x x) 3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (*.f64 (*.f64 x x) 3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 (*.f64 y 3)) x) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (*.f64 (pow.f64 x 4) (*.f64 y y)) 9))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (pow.f64 (exp.f64 x) x) y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (*.f64 (*.f64 x x) 3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (*.f64 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (*.f64 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (*.f64 (*.f64 x x) 3))))))))

simplify9.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

localize9.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 21 to 15 computations (28.6% saved)

series3.0ms (0%)

Counts
2 → 24
Calls

9 calls:

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

rewrite56.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
681×pow1_binary64
628×add-log-exp_binary64
627×log1p-expm1-u_binary64
627×expm1-log1p-u_binary64
614×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify176.0ms (3.3%)

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
379240
4221240
5742240
61007240
71421240
81521240
91656240
101828240
112073240
122386240
132758240
143212240
153801240
164509240
175369240
185793240
196113240
206419240
216499240
226533240
Stop Event
node limit
Counts
48 → 26
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))

localize19.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 x (pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 y))) 3))
0.3b
(*.f64 x (*.f64 3 y))
0.6b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 y))) 3)
9.8b
(cbrt.f64 (*.f64 x (*.f64 3 y)))
Compiler

Compiled 37 to 25 computations (32.4% saved)

series30.0ms (0.6%)

Counts
3 → 24
Calls

18 calls:

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

rewrite87.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
764×pow1_binary64
712×add-log-exp_binary64
712×log1p-expm1-u_binary64
712×expm1-log1p-u_binary64
695×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify176.0ms (3.3%)

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
379240
4221240
5742240
61007240
71421240
81521240
91656240
101828240
112073240
122386240
132758240
143212240
153801240
164509240
175369240
185793240
196113240
206419240
216499240
226533240
Stop Event
node limit
Counts
100 → 78
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))

eval56.0ms (1.1%)

Compiler

Compiled 2234 to 1460 computations (34.6% saved)

prune38.0ms (0.7%)

Pruning

12 alts after pruning (8 fresh and 4 done)

PrunedKeptTotal
New1918199
Fresh202
Picked101
Done246
Total19612208
Error
0b
Counts
208 → 12
Alt Table
Click to see full alt table
StatusErrorProgram
9.9b
(*.f64 3 (*.f64 y (pow.f64 x 2)))
0.3b
(*.f64 (*.f64 y x) (*.f64 3 x))
0.2b
(*.f64 x (*.f64 x (*.f64 3 y)))
0.3b
(*.f64 x (*.f64 3 (*.f64 y x)))
0.3b
(pow.f64 (*.f64 3 (*.f64 (*.f64 y x) x)) 1)
9.9b
(pow.f64 (*.f64 (*.f64 3 y) (*.f64 x x)) 1)
10.4b
(*.f64 3 (pow.f64 (cbrt.f64 (*.f64 y (*.f64 x x))) 3))
20.6b
(-.f64 (+.f64 1 (*.f64 3 (*.f64 (*.f64 y x) x))) 1)
24.1b
(-.f64 (+.f64 1 (*.f64 (*.f64 3 y) (*.f64 x x))) 1)
9.9b
(*.f64 (*.f64 (*.f64 x 3) x) y)
24.8b
(*.f64 (sqrt.f64 (*.f64 (pow.f64 x 4) 9)) y)
23.9b
(*.f64 (-.f64 (+.f64 1 (*.f64 3 (*.f64 x x))) 1) y)
Compiler

Compiled 220 to 163 computations (25.9% saved)

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 18 to 9 computations (50% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite56.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
678×pow1_binary64
624×add-log-exp_binary64
624×log1p-expm1-u_binary64
624×expm1-log1p-u_binary64
611×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify173.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
379240
4221240
5742240
61007240
71421240
81521240
91656240
101828240
112073240
122386240
132758240
143212240
153801240
164509240
175369240
185793240
196113240
206419240
216499240
226533240
Stop Event
node limit
Counts
37 → 15
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))

localize15.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(*.f64 3 (*.f64 x x))
1.9b
(-.f64 (+.f64 1 (*.f64 3 (*.f64 x x))) 1)
3.3b
(*.f64 (-.f64 (+.f64 1 (*.f64 3 (*.f64 x x))) 1) y)
Compiler

Compiled 41 to 24 computations (41.5% saved)

series4.0ms (0.1%)

Counts
3 → 48
Calls

12 calls:

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

rewrite90.0ms (1.7%)

Algorithm
batch-egg-rewrite
Rules
526×prod-diff_binary64
482×fma-def_binary64
432×log-prod_binary64
283×pow-prod-down_binary64
240×pow2_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify196.0ms (3.7%)

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
09408
119408
241408
391408
4255408
5825408
61049408
71463408
81563408
91696408
101868408
112109408
122426408
132798408
143253408
153840408
164550408
175410408
185836408
196154408
206462408
216542408
226578408
Stop Event
node limit
Counts
244 → 131
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 3 x))

localize15.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
2.0b
(-.f64 (+.f64 1 (*.f64 (*.f64 3 y) (*.f64 x x))) 1)
9.6b
(*.f64 (*.f64 3 y) (*.f64 x x))
Compiler

Compiled 39 to 22 computations (43.6% saved)

series4.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite84.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
815×prod-diff_binary64
587×fma-def_binary64
456×log-prod_binary64
299×pow-prod-down_binary64
245×pow2_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify195.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
08480
117480
237480
379480
4221480
5742480
61007480
71421480
81521480
91656480
101828480
112073480
122386480
132758480
143212480
153801480
164509480
175369480
185793480
196113480
206419480
216499480
226533480
Stop Event
node limit
Counts
222 → 103
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))

localize12.0ms (0.2%)

Local error

Found 1 expressions with local error:

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

Compiled 28 to 15 computations (46.4% saved)

localize14.0ms (0.3%)

Local error

Found 4 expressions with local error:

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

Compiled 37 to 12 computations (67.6% saved)

series21.0ms (0.4%)

Counts
4 → 48
Calls

24 calls:

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

rewrite77.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
733×pow1_binary64
684×add-log-exp_binary64
684×log1p-expm1-u_binary64
684×expm1-log1p-u_binary64
665×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify193.0ms (3.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08408
117408
237408
379408
4217408
5746408
61016408
71430408
81530408
91665408
101837408
112082408
122397408
132769408
143226408
153809408
164521408
175379408
185807408
196123408
206429408
216509408
226543408
Stop Event
node limit
Counts
132 → 78
Calls
Call 1
Inputs
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 y (*.f64 x x)) 3)
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 (*.f64 x x) (*.f64 y 3))

eval131.0ms (2.4%)

Compiler

Compiled 6399 to 3898 computations (39.1% saved)

prune61.0ms (1.1%)

Pruning

8 alts after pruning (3 fresh and 5 done)

PrunedKeptTotal
New4023405
Fresh303
Picked011
Done448
Total4098417
Error
0b
Counts
417 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 x (*.f64 x (*.f64 3 y)))
0.3b
(*.f64 x (*.f64 3 (*.f64 y x)))
10.4b
(*.f64 3 (pow.f64 (cbrt.f64 (*.f64 y (*.f64 x x))) 3))
9.9b
(*.f64 (*.f64 x x) (*.f64 y 3))
9.9b
(*.f64 (*.f64 (*.f64 x 3) x) y)
23.9b
(*.f64 (+.f64 (fma.f64 3 (*.f64 x x) 1) -1) y)
0.3b
(*.f64 (*.f64 y x) (*.f64 3 x))
0.3b
(*.f64 (*.f64 (*.f64 y x) x) 3)
Compiler

Compiled 78 to 54 computations (30.8% saved)

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 18 to 9 computations (50% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite56.0ms (1.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 x x) (*.f64 y 3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (*.f64 (*.f64 x y) 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 (*.f64 x y) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (*.f64 (*.f64 x y) 3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (*.f64 (*.f64 x y) 3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (sqrt.f64 (*.f64 y 3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (*.f64 9 (*.f64 y y)) (pow.f64 x 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (exp.f64 3) y) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (*.f64 (*.f64 x y) 3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 (*.f64 x y) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 (*.f64 x y) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (*.f64 (*.f64 x y) 3))))))))

simplify175.0ms (3.3%)

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
379240
4221240
5742240
61007240
71421240
81521240
91656240
101828240
112073240
122386240
132758240
143212240
153801240
164509240
175369240
185793240
196113240
206419240
216499240
226533240
Stop Event
node limit
Counts
35 → 13
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 7 computations (65% saved)

series4.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite59.0ms (1.1%)

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

Useful iterations: 0 (0.0ms)

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

simplify190.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
08408
117408
237408
379408
4221408
5742408
61007408
71421408
81521408
91656408
101828408
112073408
122386408
132758408
143212408
153801408
164509408
175369408
185793408
196113408
206419408
216499408
226533408
Stop Event
node limit
Counts
72 → 28
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
(*.f64 y (pow.f64 x 2))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))
(*.f64 y (pow.f64 x 2))
(*.f64 y (*.f64 x x))

localize14.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(fma.f64 3 (*.f64 x x) 1)
1.9b
(+.f64 (fma.f64 3 (*.f64 x x) 1) -1)
3.3b
(*.f64 (+.f64 (fma.f64 3 (*.f64 x x) 1) -1) y)
Compiler

Compiled 34 to 20 computations (41.2% saved)

series5.0ms (0.1%)

Counts
3 → 48
Calls

12 calls:

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

rewrite80.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
915×pow1_binary64
846×add-log-exp_binary64
844×log1p-expm1-u_binary64
844×expm1-log1p-u_binary64
830×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify193.0ms (3.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
011411
124411
245411
397411
4262411
5847411
61086411
71500411
81600411
91735411
101907411
112148411
122461411
132831411
143285411
153874411
164584411
175444411
185872411
196188411
206494411
216568411
226602411
Stop Event
node limit
Counts
121 → 80
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
1
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 (*.f64 3 y) (*.f64 x x))
(*.f64 y (*.f64 x (*.f64 x 3)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
1
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(fma.f64 3 (*.f64 x x) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(fma.f64 3 (*.f64 x x) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(fma.f64 3 (*.f64 x x) 1)
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(fma.f64 3 (*.f64 x x) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(fma.f64 3 (*.f64 x x) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(fma.f64 3 (*.f64 x x) 1)
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 x (*.f64 3 x))
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(fma.f64 3 (*.f64 x x) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(fma.f64 3 (*.f64 x x) 1)
(+.f64 (*.f64 3 (pow.f64 x 2)) 1)
(fma.f64 3 (*.f64 x x) 1)

eval34.0ms (0.6%)

Compiler

Compiled 1650 to 1066 computations (35.4% saved)

prune20.0ms (0.4%)

Pruning

9 alts after pruning (1 fresh and 8 done)

PrunedKeptTotal
New1201121
Fresh000
Picked011
Done077
Total1209129
Error
0b
Counts
129 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 x (*.f64 x (*.f64 3 y)))
0.3b
(*.f64 x (*.f64 3 (*.f64 y x)))
10.4b
(*.f64 3 (pow.f64 (cbrt.f64 (*.f64 y (*.f64 x x))) 3))
9.9b
(*.f64 (*.f64 x x) (*.f64 y 3))
9.9b
(*.f64 (*.f64 (*.f64 x 3) x) y)
23.9b
(*.f64 (+.f64 (fma.f64 3 (*.f64 x x) 1) -1) y)
42.0b
(*.f64 (+.f64 1 -1) y)
0.3b
(*.f64 (*.f64 y x) (*.f64 3 x))
0.3b
(*.f64 (*.f64 (*.f64 y x) x) 3)
Compiler

Compiled 85 to 60 computations (29.4% saved)

regimes47.0ms (0.9%)

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

5 calls:

11.0ms
y
10.0ms
x
8.0ms
(*.f64 (*.f64 (*.f64 x 3) x) y)
6.0ms
(*.f64 (*.f64 x 3) x)
6.0ms
(*.f64 (*.f64 x 3) x)
Results
ErrorSegmentsBranch
0.2b1x
0.2b1y
0.2b1(*.f64 (*.f64 (*.f64 x 3) x) y)
0.2b1(*.f64 (*.f64 x 3) x)
0.2b1(*.f64 (*.f64 x 3) x)
Compiler

Compiled 208 to 130 computations (37.5% saved)

regimes13.0ms (0.2%)

Counts
6 → 1
Calls
Call 1
Inputs
(*.f64 (+.f64 1 -1) y)
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 (*.f64 (*.f64 y x) x) 3)
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 x (*.f64 y (*.f64 3 x)))
Outputs
(*.f64 x (*.f64 y (*.f64 3 x)))
Calls

2 calls:

6.0ms
y
5.0ms
x
Results
ErrorSegmentsBranch
0.2b1x
0.2b1y
Compiler

Compiled 48 to 28 computations (41.7% saved)

regimes11.0ms (0.2%)

Counts
5 → 1
Calls
Call 1
Inputs
(*.f64 (+.f64 1 -1) y)
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 (*.f64 (*.f64 y x) x) 3)
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 3 (*.f64 y x)))
Outputs
(*.f64 (*.f64 y x) (*.f64 3 x))
Calls

2 calls:

5.0ms
y
4.0ms
x
Results
ErrorSegmentsBranch
0.3b1x
0.3b1y
Compiler

Compiled 41 to 24 computations (41.5% saved)

regimes10.0ms (0.2%)

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

2 calls:

5.0ms
y
4.0ms
x
Results
ErrorSegmentsBranch
0.3b1x
0.3b1y
Compiler

Compiled 27 to 18 computations (33.3% saved)

regimes8.0ms (0.2%)

Accuracy

Total -32.1b remaining (-324.3%)

Threshold costs -32.1b (-324.3%)

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

2 calls:

4.0ms
x
3.0ms
y
Results
ErrorSegmentsBranch
9.9b1x
9.9b1y
Compiler

Compiled 20 to 14 computations (30% saved)

simplify7.0ms (0.1%)

Algorithm
egg-herbie
Rules
12×*-commutative_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02254
13554
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 (*.f64 (*.f64 y x) x) 3)
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 (+.f64 1 -1) y)
Outputs
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 x (*.f64 y (*.f64 x 3)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 (*.f64 x 3) (*.f64 x y))
(*.f64 (*.f64 (*.f64 y x) x) 3)
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 (+.f64 1 -1) y)
(*.f64 y 0)
Compiler

Compiled 50 to 34 computations (32% saved)

soundness9.0ms (0.2%)

Algorithm
egg-herbie
Rules
15×associate-*l*_binary64
13×associate-*r*_binary64
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0710
11310
22710
34510
44810
Stop Event
saturated
Compiler

Compiled 36 to 24 computations (33.3% saved)

end36.0ms (0.7%)

Compiler

Compiled 40 to 23 computations (42.5% saved)

Profiling

Loading profile data...