Details

Time bar (total: 5.2s)

analyze103.0ms (2%)

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

Compiled 10 to 7 computations (30% saved)

sample1.2s (23.6%)

Results
1.2s8256×body256valid
15.0ms177×body256invalid

preprocess19.0ms (0.4%)

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)

prune6.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

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

Compiled 18 to 12 computations (33.3% saved)

localize8.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)

series10.0ms (0.2%)

Counts
2 → 48
Calls

12 calls:

TimeVariablePointExpression
2.0ms
y
@0
(*.f64 x (*.f64 x (*.f64 3 y)))
2.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)))

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
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)))))))))

simplify194.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.1b
(*.f64 (*.f64 x 3) x)
10.0b
(*.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 x 3) x)
0.0ms
x
@0
(*.f64 (*.f64 (*.f64 x 3) x) y)
0.0ms
x
@inf
(*.f64 (*.f64 (*.f64 x 3) x) y)
0.0ms
y
@0
(*.f64 (*.f64 (*.f64 x 3) x) y)

rewrite63.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))))))))

simplify188.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
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)

prune14.0ms (0.3%)

Pruning

8 alts after pruning (6 fresh and 2 done)

PrunedKeptTotal
New54660
Fresh000
Picked011
Done011
Total54862
Error
0.0b
Counts
62 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
10.5b
(*.f64 (*.f64 3 (pow.f64 x 2)) y)
0.2b
(*.f64 x (*.f64 3 (*.f64 y x)))
29.8b
(pow.f64 (*.f64 x (sqrt.f64 (*.f64 3 y))) 2)
0.9b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 x (*.f64 3 y)))) 3)
0.2b
(*.f64 x (*.f64 y (*.f64 3 x)))
10.5b
(*.f64 3 (*.f64 y (pow.f64 x 2)))
10.5b
(*.f64 (*.f64 (*.f64 x 3) x) y)
0.3b
(*.f64 x (*.f64 x (*.f64 3 y)))
Compiler

Compiled 134 to 98 computations (26.9% saved)

localize9.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.2b
(*.f64 y (*.f64 3 x))
0.2b
(*.f64 x (*.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
x
@0
(*.f64 x (*.f64 y (*.f64 3 x)))
0.0ms
x
@inf
(*.f64 x (*.f64 y (*.f64 3 x)))
0.0ms
x
@-inf
(*.f64 x (*.f64 y (*.f64 3 x)))
0.0ms
y
@0
(*.f64 x (*.f64 y (*.f64 3 x)))
0.0ms
y
@inf
(*.f64 x (*.f64 y (*.f64 3 x)))

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

simplify198.0ms (3.8%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010408
122408
245408
387408
4232408
5823408
61065408
71479408
81579408
91714408
101886408
112127408
122440408
132810408
143267408
153856408
164564408
175424408
185846408
196164408
206472408
216548408
226584408
Stop Event
node limit
Counts
74 → 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 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x 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 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))

localize8.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.2b
(*.f64 x (*.f64 3 (*.f64 y x)))
0.3b
(*.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
@inf
(*.f64 3 (*.f64 y x))
0.0ms
y
@0
(*.f64 3 (*.f64 y x))
0.0ms
y
@-inf
(*.f64 3 (*.f64 y x))
0.0ms
x
@-inf
(*.f64 x (*.f64 3 (*.f64 y x)))
0.0ms
x
@-inf
(*.f64 3 (*.f64 y x))

rewrite58.0ms (1.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))))))))

simplify173.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))

localize10.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 21 to 14 computations (33.3% saved)

series3.0ms (0.1%)

Counts
2 → 0
Calls

12 calls:

TimeVariablePointExpression
0.0ms
y
@-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))
0.0ms
x
@-inf
(*.f64 y (pow.f64 x 2))
0.0ms
y
@inf
(*.f64 3 (*.f64 y (pow.f64 x 2)))

rewrite56.0ms (1.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))))))))

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

localize10.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 21 to 15 computations (28.6% saved)

series2.0ms (0%)

Counts
2 → 24
Calls

9 calls:

TimeVariablePointExpression
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)
0.0ms
y
@0
(*.f64 (*.f64 3 (pow.f64 x 2)) y)

rewrite55.0ms (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.4%)

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))

localize15.0ms (0.3%)

Local error

Found 3 expressions with local error:

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

Compiled 27 to 19 computations (29.6% saved)

series13.0ms (0.2%)

Counts
3 → 24
Calls

15 calls:

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

rewrite76.0ms (1.4%)

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

Useful iterations: 1 (0.0ms)

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

simplify195.0ms (3.7%)

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

Useful iterations: 1 (0.0ms)

IterNodesCost
013312
129252
266252
3182252
4820252
51251252
62209252
72314252
82470252
92649252
102859252
113136252
123493252
133924252
144495252
155236252
166151252
176675252
187137252
197561252
207813252
217859252
Stop Event
node limit
Counts
83 → 63
Calls
Call 1
Inputs
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
Outputs
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))
(*.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (*.f64 x (sqrt.f64 y)))
(*.f64 x (*.f64 (sqrt.f64 3) (sqrt.f64 y)))

eval42.0ms (0.8%)

Compiler

Compiled 1762 to 1153 computations (34.6% saved)

prune36.0ms (0.7%)

Pruning

10 alts after pruning (5 fresh and 5 done)

PrunedKeptTotal
New1645169
Fresh101
Picked101
Done156
Total16710177
Error
0b
Counts
177 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 (*.f64 y x) (*.f64 3 x))
0.2b
(*.f64 x (*.f64 3 (*.f64 y x)))
0.3b
(pow.f64 (*.f64 3 (*.f64 (*.f64 y x) x)) 1)
10.5b
(*.f64 (*.f64 x x) (*.f64 y 3))
16.9b
(-.f64 (+.f64 1 (*.f64 3 (*.f64 (*.f64 y x) x))) 1)
10.5b
(*.f64 (*.f64 (*.f64 x 3) x) y)
0.9b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 x (*.f64 y 3)))) 3)
0.2b
(*.f64 x (*.f64 y (*.f64 3 x)))
10.5b
(*.f64 3 (*.f64 y (pow.f64 x 2)))
0.3b
(*.f64 x (*.f64 x (*.f64 3 y)))
Compiler

Compiled 153 to 109 computations (28.8% saved)

localize9.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.2b
(*.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
0.0ms
y
@0
(*.f64 (*.f64 y x) (*.f64 3 x))
0.0ms
y
@inf
(*.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
x
@-inf
(*.f64 (*.f64 y x) (*.f64 3 x))

rewrite67.0ms (1.3%)

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)))))))))

simplify182.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
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))

localize10.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
10.1b
(*.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
x
@inf
(*.f64 (*.f64 x x) (*.f64 y 3))
0.0ms
x
@-inf
(*.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))

rewrite57.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))))))))

simplify176.0ms (3.4%)

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))

localize16.0ms (0.3%)

Local error

Found 3 expressions with local error:

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

Compiled 41 to 18 computations (56.1% saved)

series5.0ms (0.1%)

Counts
3 → 72
Calls

18 calls:

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

rewrite82.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
664×prod-diff_binary64
509×fma-def_binary64
479×log-prod_binary64
304×pow-prod-down_binary64
246×pow2_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify213.0ms (4.1%)

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
08648
117648
237648
379648
4221648
5742648
61007648
71421648
81521648
91656648
101828648
112073648
122386648
132758648
143212648
153801648
164509648
175369648
185793648
196113648
206419648
216499648
226533648
Stop Event
node limit
Counts
258 → 119
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)))
(*.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 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))

localize10.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 30 to 12 computations (60% saved)

localize22.0ms (0.4%)

Local error

Found 4 expressions with local error:

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

Compiled 38 to 24 computations (36.8% saved)

series16.0ms (0.3%)

Counts
4 → 48
Calls

24 calls:

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

rewrite82.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
770×pow1_binary64
718×add-log-exp_binary64
718×log1p-expm1-u_binary64
718×expm1-log1p-u_binary64
700×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify195.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
140 → 87
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)))

eval70.0ms (1.3%)

Compiler

Compiled 3650 to 2261 computations (38.1% saved)

prune39.0ms (0.7%)

Pruning

8 alts after pruning (2 fresh and 6 done)

PrunedKeptTotal
New2552257
Fresh000
Picked011
Done459
Total2598267
Error
0b
Counts
267 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 (*.f64 y x) (*.f64 3 x))
0.2b
(*.f64 x (*.f64 3 (*.f64 y x)))
0.3b
(*.f64 (*.f64 x (*.f64 x y)) 3)
0.9b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 x (*.f64 y 3)))) 3)
10.5b
(*.f64 (*.f64 (*.f64 x x) y) 3)
10.5b
(*.f64 (*.f64 x x) (*.f64 y 3))
10.5b
(*.f64 (*.f64 (*.f64 x 3) x) y)
0.3b
(*.f64 x (*.f64 x (*.f64 3 y)))
Compiler

Compiled 75 to 51 computations (32% saved)

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 7 computations (65% saved)

series3.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite51.0ms (1%)

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

Useful iterations: 0 (0.0ms)

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

simplify183.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
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))

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 7 computations (65% saved)

series3.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite53.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
646×pow1_binary64
595×add-log-exp_binary64
595×log1p-expm1-u_binary64
595×expm1-log1p-u_binary64
581×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify184.0ms (3.5%)

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
70 → 26
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))

eval11.0ms (0.2%)

Compiler

Compiled 503 to 292 computations (41.9% saved)

prune11.0ms (0.2%)

Pruning

8 alts after pruning (0 fresh and 8 done)

PrunedKeptTotal
New54054
Fresh000
Picked011
Done077
Total54862
Error
0b
Counts
62 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 (*.f64 y x) (*.f64 3 x))
0.2b
(*.f64 x (*.f64 3 (*.f64 y x)))
0.3b
(*.f64 (*.f64 x (*.f64 x y)) 3)
0.9b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 x (*.f64 y 3)))) 3)
10.5b
(*.f64 (*.f64 (*.f64 x x) y) 3)
10.5b
(*.f64 (*.f64 x x) (*.f64 y 3))
10.5b
(*.f64 (*.f64 (*.f64 x 3) x) y)
0.3b
(*.f64 x (*.f64 x (*.f64 3 y)))
Compiler

Compiled 75 to 51 computations (32% saved)

regimes35.0ms (0.7%)

Counts
15 → 1
Calls
Call 1
Inputs
(*.f64 (*.f64 x (*.f64 x y)) 3)
(*.f64 (*.f64 (*.f64 x x) y) 3)
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.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 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 x (sqrt.f64 (*.f64 3 y))) 2)
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 x (*.f64 y 3)))) 3)
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 x (*.f64 3 y)))) 3)
Outputs
(*.f64 x (*.f64 y (*.f64 3 x)))
Calls

4 calls:

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

Compiled 142 to 88 computations (38% saved)

regimes11.0ms (0.2%)

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

2 calls:

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

Compiled 43 to 24 computations (44.2% saved)

regimes10.0ms (0.2%)

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

2 calls:

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

Compiled 36 to 21 computations (41.7% saved)

regimes7.0ms (0.1%)

Accuracy

Total -10.3b remaining (-4073.1%)

Threshold costs -10.3b (-4073.1%)

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

2 calls:

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

Compiled 22 to 14 computations (36.4% saved)

simplify6.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

Compiled 36 to 24 computations (33.3% saved)

soundness218.0ms (4.2%)

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
0710
11310
22710
34510
44810
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
saturated
Compiler

Compiled 64 to 44 computations (31.3% saved)

end27.0ms (0.5%)

Compiler

Compiled 30 to 16 computations (46.7% saved)

Profiling

Loading profile data...