Details

Time bar (total: 4.6s)

analyze86.0ms (1.9%)

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

Compiled 10 to 7 computations (30% saved)

sample715.0ms (15.7%)

Results
677.0ms8256×body256valid
26.0ms322×body256invalid

preprocess19.0ms (0.4%)

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

Useful iterations: 0 (0.0ms)

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

Compiled 11 to 8 computations (27.3% saved)

simplify7.0ms (0.2%)

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

Useful iterations: 0 (0.0ms)

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

eval2.0ms (0%)

Compiler

Compiled 16 to 10 computations (37.5% saved)

prune1.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

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

Compiled 18 to 12 computations (33.3% saved)

localize7.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 9 computations (55% saved)

series6.0ms (0.1%)

Counts
2 → 36
Calls

9 calls:

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

rewrite58.0ms (1.3%)

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

Useful iterations: 0 (0.0ms)

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

simplify184.0ms (4%)

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

Useful iterations: 0 (0.0ms)

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

localize10.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series7.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite56.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify260.0ms (5.7%)

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

Useful iterations: 0 (0.0ms)

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

eval14.0ms (0.3%)

Compiler

Compiled 526 to 335 computations (36.3% saved)

prune91.0ms (2%)

Pruning

7 alts after pruning (5 fresh and 2 done)

PrunedKeptTotal
New51556
Fresh000
Picked011
Done011
Total51758
Error
0.0b
Counts
58 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 (*.f64 3 (*.f64 y x)) y)
0.3b
(*.f64 (*.f64 (*.f64 x 3) y) y)
9.9b
(*.f64 x (*.f64 3 (*.f64 y y)))
0.2b
(*.f64 (*.f64 y x) (*.f64 3 y))
9.9b
(*.f64 3 (*.f64 (pow.f64 y 2) x))
30.5b
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
10.4b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (*.f64 y y)))) 3)
Compiler

Compiled 116 to 84 computations (27.6% saved)

localize9.0ms (0.2%)

Local error

Found 1 expressions with local error:

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

Compiled 18 to 9 computations (50% saved)

series3.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite67.0ms (1.5%)

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

Useful iterations: 0 (0.0ms)

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

simplify225.0ms (4.9%)

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

Useful iterations: 0 (0.0ms)

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

localize14.0ms (0.3%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 9 computations (55% saved)

series5.0ms (0.1%)

Counts
2 → 24
Calls

12 calls:

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

rewrite123.0ms (2.7%)

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

Useful iterations: 0 (0.0ms)

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

simplify202.0ms (4.4%)

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

Useful iterations: 0 (0.0ms)

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

localize20.0ms (0.4%)

Local error

Found 2 expressions with local error:

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

Compiled 21 to 14 computations (33.3% saved)

series7.0ms (0.2%)

Counts
2 → 0
Calls

12 calls:

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

rewrite101.0ms (2.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify14.0ms (0.3%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

localize27.0ms (0.6%)

Local error

Found 3 expressions with local error:

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

Compiled 27 to 19 computations (29.6% saved)

series25.0ms (0.5%)

Counts
3 → 24
Calls

15 calls:

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

rewrite98.0ms (2.2%)

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

Useful iterations: 1 (0.0ms)

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

simplify220.0ms (4.8%)

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

Useful iterations: 1 (0.0ms)

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

localize31.0ms (0.7%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 3 (*.f64 y y))
0.5b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (*.f64 y y)))) 3)
9.4b
(*.f64 x (*.f64 3 (*.f64 y y)))
17.8b
(cbrt.f64 (*.f64 x (*.f64 3 (*.f64 y y))))
Compiler

Compiled 38 to 19 computations (50% saved)

series20.0ms (0.4%)

Counts
2 → 0
Calls

12 calls:

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

rewrite70.0ms (1.5%)

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

Useful iterations: 0 (0.0ms)

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

simplify9.0ms (0.2%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

eval176.0ms (3.9%)

Compiler

Compiled 2583 to 1704 computations (34% saved)

prune34.0ms (0.7%)

Pruning

8 alts after pruning (2 fresh and 6 done)

PrunedKeptTotal
New2172219
Fresh000
Picked011
Done156
Total2188226
Error
0b
Counts
226 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
0.2b
(*.f64 (*.f64 3 (*.f64 y x)) y)
0.3b
(*.f64 (*.f64 (*.f64 x 3) y) y)
19.2b
(*.f64 3 (-.f64 (+.f64 1 (*.f64 y (*.f64 y x))) 1))
10.4b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (*.f64 y y)))) 3)
9.9b
(*.f64 x (*.f64 3 (*.f64 y y)))
0.2b
(*.f64 (*.f64 y x) (*.f64 3 y))
9.9b
(*.f64 (*.f64 x (*.f64 y y)) 3)
30.5b
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
Compiler

Compiled 80 to 57 computations (28.8% saved)

localize14.0ms (0.3%)

Local error

Found 3 expressions with local error:

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

Compiled 41 to 18 computations (56.1% saved)

series5.0ms (0.1%)

Counts
3 → 72
Calls

18 calls:

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

rewrite102.0ms (2.2%)

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

Useful iterations: 1 (0.0ms)

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

simplify203.0ms (4.5%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08576
117576
237576
382576
4223576
5762576
61029576
71443576
81543576
91678576
101850576
112093576
122408576
132780576
143240576
153829576
164541576
175401576
185827576
196143576
206449576
216527576
226561576
Stop Event
node limit
Counts
269 → 128
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
Outputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))

localize29.0ms (0.6%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 7 computations (65% saved)

series3.0ms (0.1%)

Counts
2 → 48
Calls

12 calls:

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

rewrite54.0ms (1.2%)

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

Useful iterations: 0 (0.0ms)

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

simplify187.0ms (4.1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08408
117408
237408
382408
4223408
5762408
61029408
71443408
81543408
91678408
101850408
112093408
122408408
132780408
143240408
153829408
164541408
175401408
185827408
196143408
206449408
216527408
226561408
Stop Event
node limit
Counts
70 → 26
Calls
Call 1
Inputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 (pow.f64 y 2) x)
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
Outputs
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 (pow.f64 y 2) x)
(*.f64 (*.f64 y y) x)
(*.f64 y (*.f64 y x))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))
(*.f64 3 (*.f64 (pow.f64 y 2) x))
(*.f64 (*.f64 3 (*.f64 y y)) x)
(*.f64 (*.f64 y y) (*.f64 x 3))
(*.f64 x (*.f64 y (*.f64 y 3)))

eval84.0ms (1.8%)

Compiler

Compiled 2083 to 1113 computations (46.6% saved)

prune28.0ms (0.6%)

Pruning

7 alts after pruning (2 fresh and 5 done)

PrunedKeptTotal
New1522154
Fresh000
Picked011
Done347
Total1557162
Error
0b
Counts
162 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
9.8b
(*.f64 x (*.f64 y (*.f64 y 3)))
9.9b
(*.f64 (*.f64 x (*.f64 y y)) 3)
9.9b
(*.f64 x (*.f64 3 (*.f64 y y)))
0.2b
(*.f64 (*.f64 y x) (*.f64 3 y))
0.2b
(*.f64 (*.f64 3 (*.f64 y x)) y)
0.2b
(*.f64 (*.f64 y (*.f64 y x)) 3)
30.5b
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
Compiler

Compiled 64 to 44 computations (31.3% saved)

localize9.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 12 computations (40% saved)

series2.0ms (0.1%)

Counts
2 → 36
Calls

9 calls:

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

rewrite57.0ms (1.3%)

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

Useful iterations: 0 (0.0ms)

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

simplify203.0ms (4.5%)

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

Useful iterations: 0 (0.0ms)

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

localize10.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 7 computations (65% saved)

series2.0ms (0%)

Counts
1 → 24
Calls

6 calls:

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

rewrite60.0ms (1.3%)

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

Useful iterations: 0 (0.0ms)

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

simplify180.0ms (3.9%)

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

Useful iterations: 0 (0.0ms)

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

eval11.0ms (0.2%)

Compiler

Compiled 489 to 325 computations (33.5% saved)

prune11.0ms (0.2%)

Pruning

7 alts after pruning (0 fresh and 7 done)

PrunedKeptTotal
New46046
Fresh000
Picked011
Done066
Total46753
Error
0b
Counts
53 → 7
Alt Table
Click to see full alt table
StatusErrorProgram
9.8b
(*.f64 x (*.f64 y (*.f64 y 3)))
9.9b
(*.f64 (*.f64 x (*.f64 y y)) 3)
9.9b
(*.f64 x (*.f64 3 (*.f64 y y)))
0.2b
(*.f64 (*.f64 y x) (*.f64 3 y))
0.2b
(*.f64 (*.f64 3 (*.f64 y x)) y)
0.2b
(*.f64 (*.f64 y (*.f64 y x)) 3)
30.5b
(pow.f64 (*.f64 (sqrt.f64 (*.f64 x 3)) y) 2)
Compiler

Compiled 64 to 44 computations (31.3% saved)

regimes40.0ms (0.9%)

Accuracy

Total -44.4b remaining (-21228.5%)

Threshold costs -44.4b (-21228.5%)

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

5 calls:

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

Compiled 112 to 68 computations (39.3% saved)

simplify5.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

Compiled 18 to 12 computations (33.3% saved)

soundness224.0ms (4.9%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0710
11410
22910
34610
44610
08408
117408
237408
382408
4223408
5762408
61029408
71443408
81543408
91678408
101850408
112093408
122408408
132780408
143240408
153829408
164541408
175401408
185827408
196143408
206449408
216527408
226561408
Stop Event
node limit
saturated
Compiler

Compiled 48 to 31 computations (35.4% saved)

end18.0ms (0.4%)

Compiler

Compiled 16 to 10 computations (37.5% saved)

Profiling

Loading profile data...