Details

Time bar (total: 6.8s)

analyze53.0ms (0.8%)

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

Compiled 10 to 7 computations (30% saved)

sample1.3s (19.8%)

Results
1.3s8256×body256valid
59.0ms200×body256infinite
Bogosity

preprocess69.0ms (1%)

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

Useful iterations: 0 (0.0ms)

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

Compiled 11 to 8 computations (27.3% saved)

simplify19.0ms (0.3%)

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)

prune3.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

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

Compiled 18 to 12 computations (33.3% saved)

localize19.0ms (0.3%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series116.0ms (1.7%)

Counts
2 → 48
Calls

12 calls:

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

rewrite88.0ms (1.3%)

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 x (*.f64 3 y)))
(*.f64 x (*.f64 3 y))
Outputs
((#(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)))))))))
((#(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))))))))

simplify238.0ms (3.5%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
010408
122408
245408
387408
4232408
5823408
61065408
71479408
81579408
91714408
101886408
112127408
122440408
132810408
143267408
153856408
164564408
175424408
185846408
196164408
206472408
216548408
226584408
Stop Event
node limit
Counts
74 → 30
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
(*.f64 3 (*.f64 y x))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 3 y))
(*.f64 y (*.f64 x (*.f64 3 x)))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))
(*.f64 3 (*.f64 y x))
(*.f64 y (*.f64 3 x))

localize19.0ms (0.3%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series8.0ms (0.1%)

Counts
2 → 36
Calls

9 calls:

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

rewrite84.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify221.0ms (3.3%)

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

Useful iterations: 0 (0.0ms)

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

eval28.0ms (0.4%)

Compiler

Compiled 580 to 394 computations (32.1% saved)

prune37.0ms (0.5%)

Pruning

12 alts after pruning (10 fresh and 2 done)

PrunedKeptTotal
New501060
Fresh000
Picked011
Done011
Total501262
Error
0.0b
Counts
62 → 12
Alt Table
Click to see full alt table
StatusErrorProgram
1.0b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (*.f64 x y)))) 3)
27.7b
(*.f64 x (pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 y))) 2))
10.9b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 x (*.f64 x 3))) 2) y)
0.3b
(*.f64 x (*.f64 y (*.f64 3 x)))
10.7b
(*.f64 (*.f64 3 (pow.f64 x 2)) y)
0.3b
(*.f64 x (*.f64 x (*.f64 3 y)))
10.8b
(*.f64 3 (*.f64 y (pow.f64 x 2)))
10.7b
(*.f64 (*.f64 (*.f64 x 3) x) y)
33.8b
(pow.f64 (*.f64 x (sqrt.f64 (*.f64 3 y))) 2)
31.4b
(*.f64 (cbrt.f64 (pow.f64 (*.f64 x (*.f64 x 3)) 3)) y)
1.1b
(*.f64 x (pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 y))) 3))
0.3b
(*.f64 x (*.f64 3 (*.f64 y x)))
Compiler

Compiled 230 to 170 computations (26.1% saved)

localize15.0ms (0.2%)

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)

series7.0ms (0.1%)

Counts
2 → 24
Calls

12 calls:

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

rewrite74.0ms (1.1%)

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

Useful iterations: 0 (0.0ms)

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

simplify201.0ms (3%)

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

Useful iterations: 0 (0.0ms)

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

localize17.0ms (0.3%)

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)

series5.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite76.0ms (1.1%)

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

Useful iterations: 0 (0.0ms)

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

simplify201.0ms (3%)

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

localize8.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

rewrite62.0ms (0.9%)

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

simplify172.0ms (2.5%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08240
117240
237240
379240
4221240
5742240
61007240
71421240
81521240
91656240
101828240
112073240
122386240
132758240
143212240
153801240
164509240
175369240
185793240
196113240
206419240
216499240
226533240
Stop Event
node limit
Counts
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))

localize20.0ms (0.3%)

Local error

Found 4 expressions with local error:

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

Compiled 37 to 25 computations (32.4% saved)

series27.0ms (0.4%)

Counts
3 → 24
Calls

18 calls:

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

rewrite73.0ms (1.1%)

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

Useful iterations: 0 (0.0ms)

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

simplify170.0ms (2.5%)

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

Useful iterations: 0 (0.0ms)

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

localize17.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(pow.f64 (*.f64 x (*.f64 x 3)) 3)
0.2b
(*.f64 x (*.f64 x 3))
10.3b
(*.f64 (cbrt.f64 (pow.f64 (*.f64 x (*.f64 x 3)) 3)) y)
24.3b
(cbrt.f64 (pow.f64 (*.f64 x (*.f64 x 3)) 3))
Compiler

Compiled 38 to 26 computations (31.6% saved)

series5.0ms (0.1%)

Counts
4 → 60
Calls

15 calls:

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

rewrite79.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
760×pow1_binary64
709×add-log-exp_binary64
709×log1p-expm1-u_binary64
709×expm1-log1p-u_binary64
690×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify161.0ms (2.4%)

Algorithm
egg-herbie
Rules
2524×associate-*l*_binary64
898×sqr-pow_binary64
477×pow-sqr_binary64
370×cube-prod_binary64
298×fabs-mul_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
013492
127492
260492
3169492
4681492
51036492
61157492
71334492
81514492
91743492
102034492
112402492
122786492
133264492
143845492
154073492
164251492
174393492
184487492
194561492
Stop Event
node limit
Counts
143 → 77
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
Outputs
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 (*.f64 x x) y))
(*.f64 3 (*.f64 (*.f64 y x) x))
(*.f64 3 (*.f64 x (*.f64 x y)))
(*.f64 x (*.f64 3 (*.f64 x y)))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))
(*.f64 27 (pow.f64 x 6))

eval65.0ms (1%)

Compiler

Compiled 2965 to 1988 computations (33% saved)

prune46.0ms (0.7%)

Pruning

13 alts after pruning (9 fresh and 4 done)

PrunedKeptTotal
New2466252
Fresh235
Picked101
Done246
Total25113264
Error
0.0b
Counts
264 → 13
Alt Table
Click to see full alt table
StatusErrorProgram
21.3b
(-.f64 (+.f64 1 (*.f64 3 (*.f64 (*.f64 y x) x))) 1)
10.7b
(*.f64 (*.f64 (*.f64 x x) 3) y)
33.8b
(pow.f64 (*.f64 x (sqrt.f64 (*.f64 3 y))) 2)
10.9b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 x (*.f64 x 3))) 2) y)
0.3b
(*.f64 x (*.f64 y (*.f64 3 x)))
0.3b
(*.f64 x (*.f64 x (*.f64 3 y)))
27.7b
(*.f64 x (pow.f64 (sqrt.f64 (*.f64 y (*.f64 3 x))) 2))
0.3b
(*.f64 (*.f64 y x) (*.f64 3 x))
11.0b
(*.f64 (pow.f64 (*.f64 x (sqrt.f64 3)) 2) y)
0.3b
(pow.f64 (*.f64 3 (*.f64 (*.f64 y x) x)) 1)
1.0b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (*.f64 x y)))) 3)
1.1b
(*.f64 x (pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 y))) 3))
0.3b
(*.f64 x (*.f64 3 (*.f64 y x)))
Compiler

Compiled 235 to 173 computations (26.4% saved)

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

rewrite51.0ms (0.8%)

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

simplify171.0ms (2.5%)

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

Useful iterations: 0 (0.0ms)

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

localize7.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 9 computations (55% saved)

series3.0ms (0%)

Counts
2 → 36
Calls

9 calls:

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

rewrite79.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
642×pow1_binary64
591×add-log-exp_binary64
591×log1p-expm1-u_binary64
591×expm1-log1p-u_binary64
578×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify219.0ms (3.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
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
58 → 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)))
(*.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))

localize10.0ms (0.1%)

Local error

Found 2 expressions with local error:

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

Compiled 30 to 12 computations (60% saved)

series3.0ms (0%)

Counts
2 → 48
Calls

12 calls:

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

rewrite56.0ms (0.8%)

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

simplify181.0ms (2.7%)

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

Useful iterations: 0 (0.0ms)

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

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

series15.0ms (0.2%)

Counts
3 → 24
Calls

15 calls:

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

rewrite66.0ms (1%)

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

simplify192.0ms (2.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)))

localize16.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 x (*.f64 x 3))
0.3b
(pow.f64 (sqrt.f64 (*.f64 x (*.f64 x 3))) 2)
10.3b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 x (*.f64 x 3))) 2) y)
21.6b
(sqrt.f64 (*.f64 x (*.f64 x 3)))
Compiler

Compiled 38 to 26 computations (31.6% saved)

series6.0ms (0.1%)

Counts
3 → 48
Calls

12 calls:

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

rewrite73.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
786×pow1_binary64
727×add-log-exp_binary64
726×log1p-expm1-u_binary64
726×expm1-log1p-u_binary64
711×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify111.0ms (1.6%)

Algorithm
egg-herbie
Rules
731×fma-def_binary64
617×unswap-sqr_binary64
449×fma-neg_binary64
350×distribute-rgt-neg-in_binary64
287×sqr-pow_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
013584
130404
272404
3197404
4878404
51453404
62649404
73188404
84662404
95141404
105655404
116422404
Stop Event
node limit
Counts
117 → 75
Calls
Call 1
Inputs
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 -1 (*.f64 (sqrt.f64 3) x))
(*.f64 -1 (*.f64 (sqrt.f64 3) x))
(*.f64 -1 (*.f64 (sqrt.f64 3) x))
(*.f64 -1 (*.f64 (sqrt.f64 3) x))
(*.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 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 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
Outputs
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 (sqrt.f64 3) x)
(*.f64 -1 (*.f64 (sqrt.f64 3) x))
(neg.f64 (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (neg.f64 x))
(*.f64 x (neg.f64 (sqrt.f64 3)))
(*.f64 -1 (*.f64 (sqrt.f64 3) x))
(neg.f64 (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (neg.f64 x))
(*.f64 x (neg.f64 (sqrt.f64 3)))
(*.f64 -1 (*.f64 (sqrt.f64 3) x))
(neg.f64 (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (neg.f64 x))
(*.f64 x (neg.f64 (sqrt.f64 3)))
(*.f64 -1 (*.f64 (sqrt.f64 3) x))
(neg.f64 (*.f64 (sqrt.f64 3) x))
(*.f64 (sqrt.f64 3) (neg.f64 x))
(*.f64 x (neg.f64 (sqrt.f64 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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.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 x (*.f64 x 3)))
(*.f64 x (*.f64 x (*.f64 y 3)))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 x (*.f64 x 3))
(*.f64 3 (*.f64 x x))

eval57.0ms (0.8%)

Compiler

Compiled 2311 to 1596 computations (30.9% saved)

prune33.0ms (0.5%)

Pruning

13 alts after pruning (4 fresh and 9 done)

PrunedKeptTotal
New2071208
Fresh134
Picked011
Done088
Total20813221
Error
0.0b
Counts
221 → 13
Alt Table
Click to see full alt table
StatusErrorProgram
0.3b
(*.f64 x (*.f64 x (*.f64 3 y)))
11.0b
(*.f64 (pow.f64 (*.f64 (sqrt.f64 3) x) 2) y)
21.3b
(-.f64 (+.f64 1 (*.f64 3 (*.f64 (*.f64 y x) x))) 1)
10.7b
(*.f64 (*.f64 (*.f64 x x) 3) y)
33.8b
(pow.f64 (*.f64 x (sqrt.f64 (*.f64 3 y))) 2)
10.9b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 x (*.f64 x 3))) 2) y)
0.3b
(*.f64 x (*.f64 y (*.f64 3 x)))
27.7b
(*.f64 x (pow.f64 (sqrt.f64 (*.f64 y (*.f64 3 x))) 2))
0.3b
(*.f64 (*.f64 y x) (*.f64 3 x))
0.3b
(pow.f64 (*.f64 3 (*.f64 (*.f64 y x) x)) 1)
1.0b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (*.f64 x y)))) 3)
1.1b
(*.f64 x (pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 y))) 3))
0.3b
(*.f64 x (*.f64 3 (*.f64 y x)))
Compiler

Compiled 137 to 100 computations (27% saved)

localize15.0ms (0.2%)

Local error

Found 4 expressions with local error:

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

Compiled 38 to 26 computations (31.6% saved)

series17.0ms (0.3%)

Counts
3 → 24
Calls

18 calls:

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

rewrite68.0ms (1%)

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

Useful iterations: 0 (0.0ms)

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

simplify80.0ms (1.2%)

Algorithm
egg-herbie
Rules
953×fma-def_binary64
624×distribute-lft-neg-in_binary64
601×distribute-rgt-neg-in_binary64
534×associate-*l*_binary64
421×associate-*r*_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
017360
140240
2121240
3467240
42178240
53616240
65220240
77338240
Stop Event
node limit
Counts
98 → 77
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 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 -1 (*.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 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
Outputs
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 -1 (*.f64 y (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 3 (*.f64 y (*.f64 x x)))

localize11.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.3b
(pow.f64 (*.f64 (sqrt.f64 3) x) 2)
0.4b
(*.f64 (sqrt.f64 3) x)
10.3b
(*.f64 (pow.f64 (*.f64 (sqrt.f64 3) x) 2) y)
Compiler

Compiled 26 to 20 computations (23.1% saved)

series4.0ms (0.1%)

Counts
3 → 36
Calls

12 calls:

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

rewrite66.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
742×pow1_binary64
685×add-log-exp_binary64
684×log1p-expm1-u_binary64
684×expm1-log1p-u_binary64
668×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify188.0ms (2.8%)

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

Useful iterations: 1 (0.0ms)

IterNodesCost
010504
122324
255324
3163324
4698324
51113324
62071324
72176324
82332324
92511324
102717324
112994324
123347324
133776324
144355324
155096324
166013324
176541324
187001324
197427324
207679324
217727324
Stop Event
node limit
Counts
86 → 53
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 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 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
Outputs
(*.f64 y (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 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 (*.f64 y (pow.f64 (sqrt.f64 3) 2)) (*.f64 x x))
(*.f64 y (*.f64 (*.f64 3 x) x))
(*.f64 y (*.f64 3 (*.f64 x x)))
(*.f64 (*.f64 x x) (*.f64 y 3))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 x 2))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 x x))
(*.f64 (*.f64 3 x) x)
(*.f64 3 (*.f64 x x))

localize13.0ms (0.2%)

Local error

Found 3 expressions with local error:

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

Compiled 41 to 18 computations (56.1% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite68.0ms (1%)

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

Useful iterations: 1 (0.0ms)

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

simplify175.0ms (2.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
118 → 96
Calls
Call 1
Inputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
Outputs
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 3 (*.f64 y (pow.f64 x 2)))
(*.f64 3 (*.f64 y (*.f64 x x)))
(*.f64 y (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 y x)))
(*.f64 (*.f64 y x) (*.f64 3 x))

localize16.0ms (0.2%)

Local error

Found 4 expressions with local error:

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

Compiled 38 to 19 computations (50% saved)

series10.0ms (0.1%)

Counts
4 → 48
Calls

24 calls:

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

rewrite81.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
774×pow1_binary64
722×add-log-exp_binary64
722×log1p-expm1-u_binary64
722×expm1-log1p-u_binary64
705×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify190.0ms (2.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
138 → 85
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)))

eval96.0ms (1.4%)

Compiler

Compiled 4748 to 2986 computations (37.1% saved)

prune56.0ms (0.8%)

Pruning

12 alts after pruning (3 fresh and 9 done)

PrunedKeptTotal
New3513354
Fresh000
Picked011
Done4812
Total35512367
Error
0b
Counts
367 → 12
Alt Table
Click to see full alt table
StatusErrorProgram
0.3b
(*.f64 x (*.f64 x (*.f64 3 y)))
11.0b
(*.f64 (pow.f64 (*.f64 (sqrt.f64 3) x) 2) y)
26.3b
(+.f64 (fma.f64 3 (*.f64 y (*.f64 x x)) -1) 1)
33.3b
(*.f64 (+.f64 (pow.f64 (fma.f64 y (*.f64 (*.f64 x x) 3) 1) 2) -1) (/.f64 1 (fma.f64 y (*.f64 (*.f64 x x) 3) 2)))
10.7b
(*.f64 (*.f64 (*.f64 x x) 3) y)
33.8b
(pow.f64 (*.f64 x (sqrt.f64 (*.f64 3 y))) 2)
0.3b
(*.f64 (*.f64 x (*.f64 x y)) 3)
27.7b
(*.f64 x (pow.f64 (sqrt.f64 (*.f64 y (*.f64 3 x))) 2))
0.3b
(*.f64 (*.f64 y x) (*.f64 3 x))
1.0b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (*.f64 x y)))) 3)
1.1b
(*.f64 x (pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 y))) 3))
0.3b
(*.f64 x (*.f64 y (*.f64 3 x)))
Compiler

Compiled 138 to 100 computations (27.5% saved)

regimes84.0ms (1.2%)

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

4 calls:

23.0ms
y
22.0ms
x
16.0ms
(*.f64 (*.f64 (*.f64 x 3) x) y)
15.0ms
(*.f64 (*.f64 x 3) x)
Results
ErrorSegmentsBranch
0.3b1x
0.3b1y
0.3b1(*.f64 (*.f64 (*.f64 x 3) x) y)
0.3b1(*.f64 (*.f64 x 3) x)
Compiler

Compiled 224 to 145 computations (35.3% saved)

regimes17.0ms (0.3%)

Accuracy

Total -10.6b remaining (-3624.1%)

Threshold costs -10.6b (-3624.1%)

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

2 calls:

8.0ms
x
7.0ms
y
Results
ErrorSegmentsBranch
0.3b1x
0.3b1y
Compiler

Compiled 22 to 14 computations (36.4% saved)

simplify7.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01020
11520
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 (*.f64 x (*.f64 x y)) 3)
Outputs
(*.f64 (*.f64 y x) (*.f64 3 x))
(*.f64 (*.f64 x 3) (*.f64 y x))
(*.f64 (*.f64 x (*.f64 x y)) 3)
(*.f64 3 (*.f64 x (*.f64 y x)))
Compiler

Compiled 18 to 12 computations (33.3% saved)

soundness253.0ms (3.7%)

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

Useful iterations: 0 (0.0ms)

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

Compiled 90 to 61 computations (32.2% saved)

end32.0ms (0.5%)

Compiler

Compiled 16 to 9 computations (43.8% saved)

Profiling

Loading profile data...