Details

Time bar (total: 4.7s)

analyze57.0ms (1.2%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
25%25%74.9%0.1%0%0%0%5
28.6%25%62.4%0.1%12.5%0%0%6
50%43.7%43.7%0.1%12.5%0%0%7
57.7%46.8%34.3%0.1%18.7%0%0%8
71.2%57.8%23.4%0.1%18.7%0%0%9
77%60.1%18%0.1%21.9%0%0%10
84.5%66%12.1%0.1%21.9%0%0%11
88%67.3%9.2%0.1%23.4%0%0%12
Compiler

Compiled 10 to 7 computations (30% saved)

sample844.0ms (17.8%)

Results
815.0ms8256×body256valid
17.0ms169×body256infinite
Bogosity

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)

prune1.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

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

Compiled 18 to 12 computations (33.3% saved)

localize7.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series9.0ms (0.2%)

Counts
2 → 48
Calls

12 calls:

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

rewrite58.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify185.0ms (3.9%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010408
122408
245408
387408
4237408
5817408
61059408
71473408
81573408
91706408
101878408
112123408
122436408
132806408
143263408
153854408
164564408
175424408
185846408
196160408
206464408
216540408
226574408
Stop Event
node limit
Counts
74 → 30
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 x 3))
(*.f64 x (*.f64 3 y))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x 3)) x)
(*.f64 x (*.f64 x (*.f64 3 y)))
(*.f64 y (*.f64 x (*.f64 3 x)))

localize7.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

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

simplify178.0ms (3.8%)

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

Useful iterations: 0 (0.0ms)

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

eval14.0ms (0.3%)

Compiler

Compiled 580 to 394 computations (32.1% saved)

prune15.0ms (0.3%)

Pruning

9 alts after pruning (7 fresh and 2 done)

PrunedKeptTotal
New53760
Fresh000
Picked011
Done011
Total53962
Error
0.0b
Counts
62 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
10.6b
(*.f64 (*.f64 3 (pow.f64 x 2)) y)
0.2b
(*.f64 x (*.f64 3 (*.f64 y x)))
0.5b
(*.f64 x (*.f64 x (*.f64 3 y)))
10.5b
(*.f64 (*.f64 (*.f64 x 3) x) y)
29.8b
(pow.f64 (*.f64 x (sqrt.f64 (*.f64 3 y))) 2)
1.2b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 x (*.f64 3 y)))) 3)
10.6b
(*.f64 3 (*.f64 y (pow.f64 x 2)))
0.2b
(*.f64 x (*.f64 y (*.f64 3 x)))
17.4b
(*.f64 x (cbrt.f64 (pow.f64 (*.f64 x (*.f64 3 y)) 3)))
Compiler

Compiled 158 to 116 computations (26.6% saved)

localize7.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series4.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite55.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify274.0ms (5.8%)

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

localize6.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 9 computations (55% saved)

series3.0ms (0.1%)

Counts
2 → 24
Calls

12 calls:

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

rewrite74.0ms (1.6%)

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

simplify180.0ms (3.8%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08240
117240
237240
379240
4221240
5742240
61007240
71421240
81521240
91656240
101828240
112073240
122386240
132758240
143212240
153801240
164509240
175369240
185793240
196113240
206419240
216499240
226533240
Stop Event
node limit
Counts
48 → 26
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))

localize9.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

rewrite56.0ms (1.2%)

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

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

localize20.0ms (0.4%)

Local error

Found 2 expressions with local error:

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

rewrite70.0ms (1.5%)

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

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

localize59.0ms (1.2%)

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)

series21.0ms (0.5%)

Counts
3 → 24
Calls

15 calls:

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

rewrite87.0ms (1.8%)

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

simplify229.0ms (4.8%)

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

eval78.0ms (1.7%)

Compiler

Compiled 1762 to 1152 computations (34.6% saved)

prune74.0ms (1.6%)

Pruning

9 alts after pruning (4 fresh and 5 done)

PrunedKeptTotal
New1654169
Fresh202
Picked011
Done246
Total1699178
Error
0.0b
Counts
178 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
10.6b
(*.f64 (*.f64 x x) (*.f64 y 3))
0.3b
(pow.f64 (*.f64 3 (*.f64 (*.f64 y x) x)) 1)
0.2b
(*.f64 x (*.f64 3 (*.f64 y x)))
0.5b
(*.f64 x (*.f64 x (*.f64 3 y)))
10.5b
(*.f64 (*.f64 (*.f64 x 3) x) y)
29.8b
(pow.f64 (*.f64 x (sqrt.f64 (*.f64 3 y))) 2)
0.2b
(*.f64 x (*.f64 y (*.f64 3 x)))
17.4b
(*.f64 x (cbrt.f64 (pow.f64 (*.f64 y (*.f64 3 x)) 3)))
0.3b
(*.f64 (*.f64 y x) (*.f64 3 x))
Compiler

Compiled 87 to 61 computations (29.9% saved)

localize56.0ms (1.2%)

Local error

Found 4 expressions with local error:

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

Compiled 38 to 26 computations (31.6% saved)

series17.0ms (0.4%)

Counts
3 → 72
Calls

18 calls:

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

rewrite76.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
773×pow1_binary64
721×add-log-exp_binary64
721×log1p-expm1-u_binary64
721×expm1-log1p-u_binary64
702×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify140.0ms (3%)

Algorithm
egg-herbie
Rules
944×unswap-sqr_binary64
512×distribute-rgt-neg-in_binary64
329×neg-sub0_binary64
329×fma-def_binary64
329×fma-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
027784
173784
2213784
3658784
41001784
51659784
62031784
72350784
82944784
93251784
103568784
115268784
126485784
Stop Event
node limit
Counts
149 → 86
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 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) 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 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
Outputs
(*.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 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) x))
(*.f64 (*.f64 x (cbrt.f64 -27)) (neg.f64 y))
(*.f64 x (*.f64 (cbrt.f64 -27) (neg.f64 y)))
(*.f64 x (*.f64 y (neg.f64 (cbrt.f64 -27))))
(*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) x))
(*.f64 (*.f64 x (cbrt.f64 -27)) (neg.f64 y))
(*.f64 x (*.f64 (cbrt.f64 -27) (neg.f64 y)))
(*.f64 x (*.f64 y (neg.f64 (cbrt.f64 -27))))
(*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) x))
(*.f64 (*.f64 x (cbrt.f64 -27)) (neg.f64 y))
(*.f64 x (*.f64 (cbrt.f64 -27) (neg.f64 y)))
(*.f64 x (*.f64 y (neg.f64 (cbrt.f64 -27))))
(*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) x))
(*.f64 (*.f64 x (cbrt.f64 -27)) (neg.f64 y))
(*.f64 x (*.f64 (cbrt.f64 -27) (neg.f64 y)))
(*.f64 x (*.f64 y (neg.f64 (cbrt.f64 -27))))
(*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))
(*.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 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) x))
(*.f64 (*.f64 x (cbrt.f64 -27)) (neg.f64 y))
(*.f64 x (*.f64 (cbrt.f64 -27) (neg.f64 y)))
(*.f64 x (*.f64 y (neg.f64 (cbrt.f64 -27))))
(*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) x))
(*.f64 (*.f64 x (cbrt.f64 -27)) (neg.f64 y))
(*.f64 x (*.f64 (cbrt.f64 -27) (neg.f64 y)))
(*.f64 x (*.f64 y (neg.f64 (cbrt.f64 -27))))
(*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) x))
(*.f64 (*.f64 x (cbrt.f64 -27)) (neg.f64 y))
(*.f64 x (*.f64 (cbrt.f64 -27) (neg.f64 y)))
(*.f64 x (*.f64 y (neg.f64 (cbrt.f64 -27))))
(*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) x))
(*.f64 (*.f64 x (cbrt.f64 -27)) (neg.f64 y))
(*.f64 x (*.f64 (cbrt.f64 -27) (neg.f64 y)))
(*.f64 x (*.f64 y (neg.f64 (cbrt.f64 -27))))
(*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 27 (*.f64 (pow.f64 y 3) (pow.f64 x 3)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x x)) (neg.f64 (cbrt.f64 -27)))
(*.f64 y (*.f64 x (*.f64 x (neg.f64 (cbrt.f64 -27)))))
(*.f64 y (*.f64 (*.f64 x x) (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x x)) (neg.f64 (cbrt.f64 -27)))
(*.f64 y (*.f64 x (*.f64 x (neg.f64 (cbrt.f64 -27)))))
(*.f64 y (*.f64 (*.f64 x x) (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x x)) (neg.f64 (cbrt.f64 -27)))
(*.f64 y (*.f64 x (*.f64 x (neg.f64 (cbrt.f64 -27)))))
(*.f64 y (*.f64 (*.f64 x x) (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x x)) (neg.f64 (cbrt.f64 -27)))
(*.f64 y (*.f64 x (*.f64 x (neg.f64 (cbrt.f64 -27)))))
(*.f64 y (*.f64 (*.f64 x x) (neg.f64 (cbrt.f64 -27))))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 x (*.f64 y (*.f64 3 x)))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x x)) (neg.f64 (cbrt.f64 -27)))
(*.f64 y (*.f64 x (*.f64 x (neg.f64 (cbrt.f64 -27)))))
(*.f64 y (*.f64 (*.f64 x x) (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x x)) (neg.f64 (cbrt.f64 -27)))
(*.f64 y (*.f64 x (*.f64 x (neg.f64 (cbrt.f64 -27)))))
(*.f64 y (*.f64 (*.f64 x x) (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x x)) (neg.f64 (cbrt.f64 -27)))
(*.f64 y (*.f64 x (*.f64 x (neg.f64 (cbrt.f64 -27)))))
(*.f64 y (*.f64 (*.f64 x x) (neg.f64 (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (cbrt.f64 -27)) (*.f64 x x)))
(*.f64 (*.f64 y (*.f64 x x)) (neg.f64 (cbrt.f64 -27)))
(*.f64 y (*.f64 x (*.f64 x (neg.f64 (cbrt.f64 -27)))))
(*.f64 y (*.f64 (*.f64 x x) (neg.f64 (cbrt.f64 -27))))

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
10.3b
(*.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
y
@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))

rewrite63.0ms (1.3%)

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

simplify172.0ms (3.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08240
117240
237240
379240
4221240
5742240
61007240
71421240
81521240
91656240
101828240
112073240
122386240
132758240
143212240
153801240
164509240
175369240
185793240
196113240
206419240
216499240
226533240
Stop Event
node limit
Counts
35 → 13
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))

localize7.0ms (0.1%)

Local error

Found 1 expressions with local error:

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

Compiled 18 to 9 computations (50% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite52.0ms (1.1%)

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

Useful iterations: 0 (0.0ms)

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

simplify169.0ms (3.6%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08240
117240
237240
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 2 expressions with local error:

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

Compiled 30 to 12 computations (60% saved)

series7.0ms (0.2%)

Counts
2 → 48
Calls

12 calls:

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

rewrite58.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify183.0ms (3.9%)

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
72 → 28
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))

eval42.0ms (0.9%)

Compiler

Compiled 1847 to 1248 computations (32.4% saved)

prune29.0ms (0.6%)

Pruning

10 alts after pruning (1 fresh and 9 done)

PrunedKeptTotal
New1561157
Fresh000
Picked011
Done088
Total15610166
Error
0b
Counts
166 → 10
Alt Table
Click to see full alt table
StatusErrorProgram
10.6b
(*.f64 (*.f64 x x) (*.f64 y 3))
0.3b
(pow.f64 (*.f64 3 (*.f64 (*.f64 y x) x)) 1)
0.2b
(*.f64 x (*.f64 3 (*.f64 y x)))
0.5b
(*.f64 x (*.f64 x (*.f64 3 y)))
0.6b
(*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))))
10.5b
(*.f64 (*.f64 (*.f64 x 3) x) y)
29.8b
(pow.f64 (*.f64 x (sqrt.f64 (*.f64 3 y))) 2)
0.2b
(*.f64 x (*.f64 y (*.f64 3 x)))
17.4b
(*.f64 x (cbrt.f64 (pow.f64 (*.f64 y (*.f64 3 x)) 3)))
0.3b
(*.f64 (*.f64 y x) (*.f64 3 x))
Compiler

Compiled 98 to 69 computations (29.6% saved)

localize17.0ms (0.4%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))))
0.2b
(*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))
1.0b
(cbrt.f64 -27)
Compiler

Compiled 31 to 23 computations (25.8% saved)

series8.0ms (0.2%)

Counts
3 → 48
Calls

12 calls:

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

rewrite176.0ms (3.7%)

Algorithm
egg-rewrite-iter-limit
egg-rewrite
batch-egg-rewrite
Rules
569×fma-def_binary64
368×expm1-udef_binary64
367×log1p-udef_binary64
312×fma-neg_binary64
229×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0928
118628
2235628
033
1593
25983
359353
0811
116411
2201811
0811
0914
118614
2235614
0914
Stop Event
iter limit
unsound
iter limit
unsound
node limit
unsound
Counts
3 → 57
Calls
Call 1
Inputs
(cbrt.f64 -27)
(*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))
(*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (cbrt.f64 -27) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (cbrt.f64 -27))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (cbrt.f64 -27))) 2)) (log.f64 (cbrt.f64 (exp.f64 (cbrt.f64 -27)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (cbrt.f64 -27)))) (log.f64 (sqrt.f64 (exp.f64 (cbrt.f64 -27)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 (cbrt.f64 -27) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 -27) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cbrt.f64 -27))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 -27)) (cbrt.f64 (cbrt.f64 729)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 729)) (cbrt.f64 (cbrt.f64 -27)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 -27 1/6) (pow.f64 -27 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (cbrt.f64 729))) (*.f64 (cbrt.f64 (cbrt.f64 (cbrt.f64 -27))) (cbrt.f64 (cbrt.f64 729))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (cbrt.f64 531441))) (*.f64 (cbrt.f64 (cbrt.f64 (cbrt.f64 729))) (cbrt.f64 (cbrt.f64 -27))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 -27) 1/6) (*.f64 (pow.f64 (cbrt.f64 -27) 1/6) (cbrt.f64 (cbrt.f64 729))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 -27 1/12) (pow.f64 -27 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 -27 1/12) (*.f64 (pow.f64 -27 1/12) (pow.f64 -27 1/6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 -27 1/4) (pow.f64 -27 1/12))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (cbrt.f64 -27)) 5)) (pow.f64 (cbrt.f64 -27) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 -27 1/6) (cbrt.f64 (cbrt.f64 -27))) (pow.f64 (cbrt.f64 -27) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (cbrt.f64 -27)) (cbrt.f64 (cbrt.f64 (cbrt.f64 531441)))) (cbrt.f64 (cbrt.f64 (cbrt.f64 729))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (cbrt.f64 729)) (cbrt.f64 (cbrt.f64 (cbrt.f64 729)))) (cbrt.f64 (cbrt.f64 (cbrt.f64 -27))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (cbrt.f64 729)) (pow.f64 (cbrt.f64 -27) 1/6)) (pow.f64 (cbrt.f64 -27) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 (cbrt.f64 -27) 1) 3) 1) (fma.f64 (+.f64 (cbrt.f64 -27) 1) (+.f64 (cbrt.f64 -27) 1) (+.f64 1 (+.f64 (cbrt.f64 -27) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 (+.f64 (cbrt.f64 -27) 1) (+.f64 (cbrt.f64 -27) 1) -1) (+.f64 (+.f64 (cbrt.f64 -27) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 -27 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 -27) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 729 1/6)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 729) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cbrt.f64 -27)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 -27 1/6) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1/3) (log.f64 -27))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (cbrt.f64 -27)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (cbrt.f64 -27)))) (sqrt.f64 (log.f64 (cbrt.f64 -27))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (cbrt.f64 -27))) 2)) (cbrt.f64 (log.f64 (cbrt.f64 -27))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (cbrt.f64 729))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (cbrt.f64 -27))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cbrt.f64 -27)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cbrt.f64 -27)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cbrt.f64 -27)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cbrt.f64 -27)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (cbrt.f64 -27))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 1/6 (log.f64 -27)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 (cbrt.f64 -27) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (cbrt.f64 -27) 1) 1 -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cbrt.f64 (+.f64 (cbrt.f64 -27) 1)) (cbrt.f64 (+.f64 (cbrt.f64 -27) 1))) (cbrt.f64 (+.f64 (cbrt.f64 -27) 1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (hypot.f64 1 (pow.f64 -27 1/6)) (hypot.f64 1 (pow.f64 -27 1/6)) -1)))))
((#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (*.f64 (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))) (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))) (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))))))))
((#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (*.f64 (*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27))))) (*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))))) (*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (*.f64 y (*.f64 x (neg.f64 (cbrt.f64 -27)))))))))))

simplify89.0ms (1.9%)

Algorithm
egg-herbie
Rules
834×fma-def_binary64
806×distribute-lft-neg-in_binary64
793×distribute-rgt-neg-in_binary64
684×unswap-sqr_binary64
598×fma-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
017600
140600
2114600
3261600
4693600
51174600
61841600
72657600
83920600
95461600
Stop Event
node limit
Counts
105 → 62
Calls
Call 1
Inputs
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
Outputs
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(neg.f64 (*.f64 y (*.f64 (cbrt.f64 -27) x)))
(*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 x)))
(*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x)))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (cbrt.f64 -27) (pow.f64 x 2))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(neg.f64 (*.f64 (*.f64 y (*.f64 x x)) (cbrt.f64 -27)))
(*.f64 y (neg.f64 (*.f64 (cbrt.f64 -27) (*.f64 x x))))
(*.f64 x (*.f64 (*.f64 (cbrt.f64 -27) x) (neg.f64 y)))
(*.f64 y (*.f64 (cbrt.f64 -27) (*.f64 x (neg.f64 x))))
(*.f64 y (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 x x))))

eval21.0ms (0.4%)

Compiler

Compiled 903 to 709 computations (21.5% saved)

prune13.0ms (0.3%)

Pruning

9 alts after pruning (1 fresh and 8 done)

PrunedKeptTotal
New61162
Fresh000
Picked101
Done189
Total63972
Error
0b
Counts
72 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
10.6b
(*.f64 (*.f64 x x) (*.f64 y 3))
0.3b
(pow.f64 (*.f64 3 (*.f64 (*.f64 y x) x)) 1)
0.2b
(*.f64 x (*.f64 3 (*.f64 y x)))
0.5b
(*.f64 x (*.f64 x (*.f64 3 y)))
10.5b
(*.f64 (*.f64 (*.f64 x 3) x) y)
29.8b
(pow.f64 (*.f64 x (sqrt.f64 (*.f64 3 y))) 2)
0.2b
(*.f64 x (*.f64 y (*.f64 3 x)))
0.3b
(*.f64 (*.f64 y x) (*.f64 3 x))
0.6b
(*.f64 x (*.f64 (cbrt.f64 -27) (neg.f64 (*.f64 y x))))
Compiler

Compiled 86 to 60 computations (30.2% saved)

regimes35.0ms (0.7%)

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

4 calls:

9.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 145 to 93 computations (35.9% saved)

regimes9.0ms (0.2%)

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

2 calls:

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

Compiled 29 to 17 computations (41.4% saved)

regimes8.0ms (0.2%)

Accuracy

Total -10.4b remaining (-4129%)

Threshold costs -10.4b (-4129%)

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

2 calls:

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

Compiled 22 to 14 computations (36.4% saved)

simplify5.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01440
12340
Stop Event
fuel
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 x) (*.f64 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 x) (*.f64 y 3))
Compiler

Compiled 36 to 24 computations (33.3% saved)

soundness219.0ms (4.6%)

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

Useful iterations: 0 (0.0ms)

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

end71.0ms (1.5%)

Compiler

Compiled 30 to 17 computations (43.3% saved)

Profiling

Loading profile data...