Details

Time bar (total: 10.1s)

analyze10.0ms (0.1%)

Algorithm
search
Search
TrueOtherFalseIter
0%100%0%0
0%100%0%1
0%100%0%2
50%50%0%3
50%25%25%4
62.5%12.5%25%5
68.7%6.2%25%6
71.8%3.1%25%7
73.4%1.6%25%8
74.2%0.8%25%9
74.6%0.4%25%10
74.8%0.2%25%11
74.9%0.1%25%12
Compiler

Compiled 11 to 9 computations (18.2% saved)

sample2.1s (20.9%)

Results
1.8s7544×body256valid
195.0ms464×body1024valid
75.0ms248×body512valid
1.0msbody256invalid

preprocess73.0ms (0.7%)

Algorithm
egg-herbie
Rules
927×fma-def_binary64
395×fma-neg_binary64
127×cancel-sign-sub-inv_binary64
83×distribute-rgt-in_binary64
66×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0813
11813
24310
31018
42278
53618
65458
78168
813698
915118
1018278
1122458
1223548
1323588
1423588
011
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
Outputs
0
Call 2
Inputs
(*.f64 (*.f64 3 (-.f64 2 (*.f64 x 3))) x)
Outputs
(*.f64 (*.f64 3 (-.f64 2 (*.f64 x 3))) x)
(*.f64 3 (*.f64 (-.f64 2 (*.f64 3 x)) x))
(*.f64 3 (*.f64 x (+.f64 2 (*.f64 x -3))))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
Compiler

Compiled 11 to 9 computations (18.2% saved)

simplify58.0ms (0.6%)

Algorithm
egg-herbie
Rules
927×fma-def_binary64
395×fma-neg_binary64
127×cancel-sign-sub-inv_binary64
83×distribute-rgt-in_binary64
66×associate-*l*_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0813
11813
24310
31018
42278
53618
65458
78168
813698
915118
1018278
1122458
1223548
1323588
1423588
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(*.f64 (*.f64 3 (-.f64 2 (*.f64 x 3))) x)
Outputs
(*.f64 (*.f64 3 (-.f64 2 (*.f64 x 3))) x)
(*.f64 3 (*.f64 (-.f64 2 (*.f64 3 x)) x))
(*.f64 3 (*.f64 x (+.f64 2 (*.f64 x -3))))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))

eval1.0ms (0%)

Compiler

Compiled 16 to 12 computations (25% saved)

prune2.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

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

Compiled 17 to 13 computations (23.5% saved)

localize10.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 x -9 6)
0.1b
(*.f64 x (fma.f64 x -9 6))
Compiler

Compiled 14 to 10 computations (28.6% saved)

series4.0ms (0%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
1.0ms
x
@-inf
(*.f64 x (fma.f64 x -9 6))
1.0ms
x
@0
(*.f64 x (fma.f64 x -9 6))
1.0ms
x
@inf
(*.f64 x (fma.f64 x -9 6))
0.0ms
x
@-inf
(fma.f64 x -9 6)
0.0ms
x
@0
(fma.f64 x -9 6)

rewrite76.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
541×pow1_binary64
530×add-sqr-sqrt_binary64
506×add-log-exp_binary64
506×log1p-expm1-u_binary64
506×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0613
112213
2133813
Stop Event
node limit
Counts
2 → 34
Calls
Call 1
Inputs
(*.f64 x (fma.f64 x -9 6))
(fma.f64 x -9 6)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x -9) x) (*.f64 6 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 x -9)) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (fma.f64 x -9 6))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (fma.f64 x -9 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (fma.f64 x -9 6)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (fma.f64 x -9 6))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (fma.f64 x -9 6))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (fma.f64 x -9 6)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (fma.f64 x -9 6)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (fma.f64 x -9 6))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 6 (*.f64 x -9))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x -9) 6)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x -9) 1) 6)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 x -9 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x -9 6) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x -9 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x -9 6)) (pow.f64 (cbrt.f64 (fma.f64 x -9 6)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x -9 6)) 2) (cbrt.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x -9 6)) (sqrt.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x -9) 3) 216) (+.f64 (*.f64 (*.f64 x -9) (*.f64 x -9)) (-.f64 36 (*.f64 (*.f64 x -9) 6))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 x -9) (*.f64 x -9)) 36) (-.f64 (*.f64 x -9) 6))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x -9 6) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -9 6) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x -9 6)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x -9 6)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x -9 6) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x -9 6) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x -9 6)))))))

simplify212.0ms (2.1%)

Algorithm
egg-herbie
Rules
778×sqr-pow_binary64
565×cube-prod_binary64
558×fabs-mul_binary64
535×associate-*l*_binary64
434×unswap-sqr_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
012171
123171
236144
362144
4156144
5471144
61719144
72966144
83170144
93383144
103603144
113914144
124314144
134829144
145395144
156085144
166918144
177310144
187600144
197878144
207954144
217990144
Stop Event
node limit
Counts
58 → 45
Calls
Call 1
Inputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
6
(+.f64 (*.f64 -9 x) 6)
(+.f64 (*.f64 -9 x) 6)
(+.f64 (*.f64 -9 x) 6)
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
Outputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
6
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)

localize20.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(-.f64 2 (*.f64 x 3))
0.1b
(*.f64 3 (-.f64 2 (*.f64 x 3)))
0.1b
(*.f64 (*.f64 3 (-.f64 2 (*.f64 x 3))) x)
Compiler

Compiled 28 to 22 computations (21.4% saved)

series12.0ms (0.1%)

Counts
3 → 36
Calls

9 calls:

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

rewrite117.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
887×pow1_binary64
827×add-log-exp_binary64
826×log1p-expm1-u_binary64
826×expm1-log1p-u_binary64
813×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0830
117730
2222730
Stop Event
node limit
Counts
3 → 58
Calls
Call 1
Inputs
(*.f64 (*.f64 3 (-.f64 2 (*.f64 x 3))) x)
(*.f64 3 (-.f64 2 (*.f64 x 3)))
(-.f64 2 (*.f64 x 3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 3) (*.f64 x (-.f64 2 (*.f64 3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (*.f64 3 (-.f64 2 (*.f64 3 x))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (*.f64 3 (-.f64 2 (*.f64 3 x))) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 6 (*.f64 (*.f64 x -3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 6 (*.f64 3 (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 3 (-.f64 2 (*.f64 3 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 8 (*.f64 27 (pow.f64 x 3))) 3) (+.f64 4 (+.f64 (*.f64 9 (*.f64 x x)) (*.f64 6 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (-.f64 8 (*.f64 27 (pow.f64 x 3)))) (+.f64 4 (+.f64 (*.f64 9 (*.f64 x x)) (*.f64 6 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (-.f64 4 (*.f64 9 (*.f64 x x)))) (+.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (-.f64 2 (*.f64 3 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 3 (-.f64 2 (*.f64 3 x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 3 (-.f64 2 (*.f64 3 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 3 (-.f64 2 (*.f64 3 x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 9 (pow.f64 (-.f64 2 (*.f64 3 x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 3) (-.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 3 (-.f64 2 (*.f64 3 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 3 (-.f64 2 (*.f64 3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 3 (-.f64 2 (*.f64 3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 3 (-.f64 2 (*.f64 3 x)))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 2 (*.f64 x -3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 2 (*.f64 (*.f64 x -3) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x -3) 2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 2 (*.f64 3 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (-.f64 2 (*.f64 3 x))) (pow.f64 (cbrt.f64 (-.f64 2 (*.f64 3 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (-.f64 2 (*.f64 3 x))) 2) (cbrt.f64 (-.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (-.f64 2 (*.f64 3 x))) (sqrt.f64 (-.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 8 (*.f64 27 (pow.f64 x 3))) (/.f64 1 (+.f64 4 (+.f64 (*.f64 9 (*.f64 x x)) (*.f64 6 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) (/.f64 1 (+.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 4 (+.f64 (*.f64 9 (*.f64 x x)) (*.f64 6 x))) (-.f64 8 (*.f64 27 (pow.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 2 (*.f64 3 x)) (-.f64 4 (*.f64 9 (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 8 (*.f64 27 (pow.f64 x 3))) (+.f64 4 (+.f64 (*.f64 9 (*.f64 x x)) (*.f64 6 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) (+.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 8 (*.f64 27 (pow.f64 x 3)))) (neg.f64 (+.f64 4 (+.f64 (*.f64 9 (*.f64 x x)) (*.f64 6 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 4 (*.f64 9 (*.f64 x x)))) (neg.f64 (+.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 8 (pow.f64 (*.f64 x -3) 3)) (+.f64 4 (-.f64 (*.f64 (*.f64 x -3) (*.f64 x -3)) (*.f64 2 (*.f64 x -3)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 4 (*.f64 (*.f64 x -3) (*.f64 x -3))) (-.f64 2 (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 2 (*.f64 3 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (-.f64 2 (*.f64 3 x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (-.f64 2 (*.f64 3 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (-.f64 2 (*.f64 3 x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (-.f64 2 (*.f64 3 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (-.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (-.f64 2 (*.f64 3 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (-.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (-.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (-.f64 2 (*.f64 3 x))))))))

simplify187.0ms (1.8%)

Algorithm
egg-herbie
Rules
778×sqr-pow_binary64
597×associate-*l*_binary64
540×cube-prod_binary64
531×fabs-mul_binary64
434×unswap-sqr_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
016225
129225
243198
373198
4180198
5540198
61899198
73170198
83374198
93588198
103808198
114120198
124520198
135033198
145601198
156283198
167120198
177516198
187802198
Stop Event
node limit
Counts
94 → 75
Calls
Call 1
Inputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
6
(+.f64 (*.f64 -9 x) 6)
(+.f64 (*.f64 -9 x) 6)
(+.f64 (*.f64 -9 x) 6)
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
2
(+.f64 (*.f64 -3 x) 2)
(+.f64 (*.f64 -3 x) 2)
(+.f64 (*.f64 -3 x) 2)
(*.f64 -3 x)
(+.f64 2 (*.f64 -3 x))
(+.f64 2 (*.f64 -3 x))
(+.f64 2 (*.f64 -3 x))
(*.f64 -3 x)
(+.f64 2 (*.f64 -3 x))
(+.f64 2 (*.f64 -3 x))
(+.f64 2 (*.f64 -3 x))
Outputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
6
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
2
(+.f64 (*.f64 -3 x) 2)
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 (*.f64 -3 x) 2)
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 (*.f64 -3 x) 2)
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(*.f64 -3 x)
(*.f64 x -3)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(*.f64 -3 x)
(*.f64 x -3)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)

eval68.0ms (0.7%)

Compiler

Compiled 1326 to 1034 computations (22% saved)

prune101.0ms (1%)

Pruning

16 alts after pruning (16 fresh and 0 done)

PrunedKeptTotal
New10416120
Fresh000
Picked101
Done101
Total10616122
Error
0.0b
Counts
122 → 16
Alt Table
Click to see full alt table
StatusErrorProgram
8.5b
(*.f64 (cbrt.f64 (pow.f64 (*.f64 3 (-.f64 2 (*.f64 3 x))) 3)) x)
0.2b
(+.f64 (*.f64 (*.f64 x -9) x) (*.f64 6 x))
1.7b
(*.f64 (*.f64 3 (*.f64 (pow.f64 (cbrt.f64 (-.f64 2 (*.f64 3 x))) 2) (cbrt.f64 (-.f64 2 (*.f64 3 x))))) x)
8.8b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 3 (-.f64 2 (*.f64 3 x)))) 2) x)
43.0b
(cbrt.f64 (*.f64 (pow.f64 (*.f64 3 (-.f64 2 (*.f64 3 x))) 3) (pow.f64 x 3)))
42.9b
(cbrt.f64 (pow.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))) 3))
19.0b
(*.f64 x 6)
42.7b
(pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 2)
0.5b
(*.f64 x (/.f64 (-.f64 (*.f64 (*.f64 x -9) (*.f64 x -9)) 36) (-.f64 (*.f64 x -9) 6)))
1.4b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 3)
0.2b
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
0.3b
(*.f64 (/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x))) x)
43.8b
(*.f64 -9 (pow.f64 x 2))
43.8b
(*.f64 (*.f64 x -9) x)
0.2b
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
8.0b
(*.f64 (/.f64 (*.f64 (-.f64 8 (*.f64 27 (pow.f64 x 3))) 3) (+.f64 4 (+.f64 (*.f64 9 (*.f64 x x)) (*.f64 6 x)))) x)
Compiler

Compiled 408 to 330 computations (19.1% saved)

localize16.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 -9 x) 6)
0.1b
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
Compiler

Compiled 19 to 14 computations (26.3% saved)

series3.0ms (0%)

Counts
2 → 21
Calls

6 calls:

TimeVariablePointExpression
1.0ms
x
@0
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
1.0ms
x
@inf
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
1.0ms
x
@-inf
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
0.0ms
x
@inf
(+.f64 (*.f64 -9 x) 6)
0.0ms
x
@-inf
(+.f64 (*.f64 -9 x) 6)

rewrite143.0ms (1.4%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0713
115313
2186013
Stop Event
node limit
Counts
2 → 53
Calls
Call 1
Inputs
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
(+.f64 (*.f64 -9 x) 6)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 -9 x) x) (*.f64 6 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 6 x) (*.f64 (*.f64 -9 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 -9 x)) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x 6) (*.f64 x (*.f64 -9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (fma.f64 -9 x 6))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 216 (*.f64 (pow.f64 x 3) -729)) x) (+.f64 (pow.f64 (*.f64 -9 x) 2) (-.f64 36 (*.f64 x -54))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (pow.f64 (*.f64 -9 x) 2) -36) x) (fma.f64 -9 x -6))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 216 (*.f64 (pow.f64 x 3) -729))) (+.f64 (pow.f64 (*.f64 -9 x) 2) (-.f64 36 (*.f64 x -54))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 (pow.f64 (*.f64 -9 x) 2) -36)) (fma.f64 -9 x -6))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (fma.f64 -9 x 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (fma.f64 -9 x 6)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (fma.f64 -9 x 6))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (fma.f64 -9 x 6))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (fma.f64 -9 x 6)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (fma.f64 -9 x 6)) x))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (fma.f64 -9 x 6)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (fma.f64 -9 x 6) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 -9 x 6) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (fma.f64 -9 x 6))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (fma.f64 -9 x 6))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (fma.f64 -9 x 6))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 -9 x 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 (*.f64 -9 x) 2) (fma.f64 -9 x -6)) (/.f64 36 (fma.f64 -9 x -6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 -9 x 6) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 -9 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 -9 x 6)) (pow.f64 (cbrt.f64 (fma.f64 -9 x 6)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 -9 x 6)) 2) (cbrt.f64 (fma.f64 -9 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 -9 x 6)) (sqrt.f64 (fma.f64 -9 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 216 (*.f64 (pow.f64 x 3) -729)) (/.f64 1 (+.f64 (pow.f64 (*.f64 -9 x) 2) (-.f64 36 (*.f64 x -54)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 (*.f64 -9 x) 2) -36) (/.f64 1 (fma.f64 -9 x -6)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (*.f64 -9 x) 2) (-.f64 36 (*.f64 x -54))) (+.f64 216 (*.f64 (pow.f64 x 3) -729))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 -9 x -6) (+.f64 (pow.f64 (*.f64 -9 x) 2) -36)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 216 (*.f64 (pow.f64 x 3) -729)) (+.f64 (pow.f64 (*.f64 -9 x) 2) (-.f64 36 (*.f64 x -54))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 216 (*.f64 (pow.f64 x 3) -729)) (+.f64 36 (-.f64 (pow.f64 (*.f64 -9 x) 2) (*.f64 x -54))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 -9 x) 2) -36) (fma.f64 -9 x -6))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 216 (*.f64 (pow.f64 x 3) -729))) (neg.f64 (+.f64 (pow.f64 (*.f64 -9 x) 2) (-.f64 36 (*.f64 x -54)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 -9 x) 2) -36)) (neg.f64 (fma.f64 -9 x -6)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 36 (pow.f64 (*.f64 -9 x) 2)) (-.f64 6 (*.f64 -9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 -9 x 6) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 -9 x 6) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 -9 x 6)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 -9 x 6)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 -9 x 6) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 -9 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 -9 x 6) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 -9 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 -9 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 -9 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -9 x 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x -9 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 -9 x) 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 -9 x)) 2) (cbrt.f64 (*.f64 -9 x)) 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 -9 x)) (sqrt.f64 (*.f64 -9 x)) 6)))))

simplify212.0ms (2.1%)

Algorithm
egg-herbie
Rules
778×sqr-pow_binary64
565×cube-prod_binary64
559×fabs-mul_binary64
535×associate-*l*_binary64
434×unswap-sqr_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
011168
122156
236129
362129
4156129
5471129
61719129
72966129
83170129
93383129
103603129
113914129
124314129
134829129
145395129
156083129
166916129
177310129
187602129
197880129
207956129
217992129
Stop Event
node limit
Counts
74 → 62
Calls
Call 1
Inputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
6
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
Outputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (fma.f64 x -9 6))
6
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 x -9))
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 x -9))
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 x -9))
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 x -9))
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 x -9))
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 x -9))
(fma.f64 x -9 6)

localize4.0ms (0%)

Compiler

Compiled 6 to 4 computations (33.3% saved)

localize70.0ms (0.7%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3)
0.1b
(*.f64 (/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x))) x)
0.2b
(/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x)))
0.2b
(*.f64 9 (*.f64 x x))
Compiler

Compiled 70 to 47 computations (32.9% saved)

series13.0ms (0.1%)

Counts
4 → 48
Calls

12 calls:

TimeVariablePointExpression
6.0ms
x
@-inf
(*.f64 (/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x))) x)
1.0ms
x
@0
(*.f64 (/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x))) x)
1.0ms
x
@inf
(*.f64 9 (*.f64 x x))
1.0ms
x
@inf
(/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x)))
1.0ms
x
@inf
(*.f64 (/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x))) x)

rewrite158.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
740×log-prod_binary64
440×prod-diff_binary64
266×fma-def_binary64
254×expm1-udef_binary64
254×log1p-udef_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01467
131543
2421841
Stop Event
node limit
Counts
4 → 117
Calls
Call 1
Inputs
(*.f64 9 (*.f64 x x))
(/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x)))
(*.f64 (/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x))) x)
(*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 9) (*.f64 x x))) (cbrt.f64 (pow.f64 (exp.f64 9) (*.f64 x x))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 9) (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 9) (*.f64 x x)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 9) (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 9 (*.f64 x x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 9 (*.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 3) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cbrt.f64 (*.f64 x 3)) 2) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 729 (pow.f64 (*.f64 x x) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 81 (pow.f64 x 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 9) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 9 (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 729 (pow.f64 (*.f64 x x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 9 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 9 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 9 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 9 (*.f64 x x))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 3 (+.f64 2 (*.f64 -3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))))) (cbrt.f64 (exp.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))))))) (log.f64 (cbrt.f64 (exp.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))) (log.f64 (sqrt.f64 (exp.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 4 (*.f64 (fma.f64 x 3 2) 1/3)) (/.f64 (*.f64 9 (*.f64 x x)) (*.f64 (fma.f64 x 3 2) 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (*.f64 x x) -9 4) (/.f64 1 (*.f64 (fma.f64 x 3 2) 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (*.f64 x x) -9 4) (*.f64 3 (/.f64 1 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (+.f64 2 (*.f64 -3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 (fma.f64 (*.f64 x x) -9 4) (/.f64 1 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) (/.f64 1 (fma.f64 x 3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 3 (+.f64 2 (*.f64 -3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 9 (pow.f64 (fma.f64 (*.f64 x x) -9 4) 2))) (*.f64 (cbrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (/.f64 1 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))) (pow.f64 (cbrt.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))) 2) (cbrt.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (*.f64 (sqrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (/.f64 1 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))) (sqrt.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) -3) (/.f64 1 (neg.f64 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 x 3 2)) (*.f64 (fma.f64 (*.f64 x x) -9 4) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 2 (*.f64 -3 x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 (*.f64 x x) -9 4) 1) (/.f64 3 (fma.f64 x 3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 9 (pow.f64 (fma.f64 (*.f64 x x) -9 4) 2))) 1) (/.f64 (cbrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (fma.f64 x 3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) 1) (/.f64 (sqrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (fma.f64 x 3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 (*.f64 x x) -9 4) (cbrt.f64 (pow.f64 (fma.f64 x 3 2) 2))) (/.f64 3 (cbrt.f64 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 3 (cbrt.f64 (pow.f64 (fma.f64 x 3 2) 2))) (/.f64 (fma.f64 (*.f64 x x) -9 4) (cbrt.f64 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (pow.f64 (fma.f64 x 3 2) 2))) (/.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) (cbrt.f64 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 9 (pow.f64 (fma.f64 (*.f64 x x) -9 4) 2))) (cbrt.f64 (pow.f64 (fma.f64 x 3 2) 2))) (cbrt.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (cbrt.f64 (pow.f64 (fma.f64 x 3 2) 2))) (/.f64 (sqrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (cbrt.f64 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 (*.f64 x x) -9 4) (sqrt.f64 (fma.f64 x 3 2))) (/.f64 3 (sqrt.f64 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 3 (sqrt.f64 (fma.f64 x 3 2))) (/.f64 (fma.f64 (*.f64 x x) -9 4) (sqrt.f64 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (fma.f64 x 3 2))) (/.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) (sqrt.f64 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 9 (pow.f64 (fma.f64 (*.f64 x x) -9 4) 2))) (sqrt.f64 (fma.f64 x 3 2))) (/.f64 (cbrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (sqrt.f64 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) (fma.f64 27 (pow.f64 x 3) 8)) (fma.f64 (*.f64 x 3) (fma.f64 x 3 -2) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) (fma.f64 (*.f64 x x) -9 4)) (+.f64 2 (*.f64 -3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (*.f64 3 (+.f64 2 (*.f64 -3 x)))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) (neg.f64 (fma.f64 x 3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) 3) (pow.f64 (fma.f64 x 3 2) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x)))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (*.f64 3 (+.f64 2 (*.f64 -3 x))))) (cbrt.f64 (pow.f64 (exp.f64 x) (*.f64 3 (+.f64 2 (*.f64 -3 x))))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (*.f64 3 (+.f64 2 (*.f64 -3 x)))))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x)))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 x (/.f64 1 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) (/.f64 (fma.f64 x 3 2) x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 x 3 2) (*.f64 x (*.f64 (fma.f64 (*.f64 x x) -9 4) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (fma.f64 x 3 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (*.f64 x (*.f64 (fma.f64 (*.f64 x x) -9 4) 3))) (neg.f64 (fma.f64 x 3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 x (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) 1) (fma.f64 x 3 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 x (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (cbrt.f64 (pow.f64 (fma.f64 x 3 2) 2))) (cbrt.f64 (fma.f64 x 3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (*.f64 x (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) (sqrt.f64 (fma.f64 x 3 2))) (sqrt.f64 (fma.f64 x 3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) x) (*.f64 (fma.f64 x 3 2) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) -3) x) (neg.f64 (fma.f64 x 3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (fma.f64 (*.f64 x x) -9 4)) (*.f64 (fma.f64 x 3 2) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (*.f64 (fma.f64 (*.f64 x x) -9 4) -3)) (neg.f64 (fma.f64 x 3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x)))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x))))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (*.f64 3 (+.f64 2 (*.f64 -3 x))) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x (*.f64 3 (+.f64 2 (*.f64 -3 x))))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 12 (*.f64 (*.f64 (*.f64 x x) -9) 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 12 (*.f64 3 (*.f64 (*.f64 x x) -9)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 3) (fma.f64 (*.f64 x x) -9 4))) (cbrt.f64 (pow.f64 (exp.f64 3) (fma.f64 (*.f64 x x) -9 4))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 3) (fma.f64 (*.f64 x x) -9 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 3) (fma.f64 (*.f64 x x) -9 4)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 3) (fma.f64 (*.f64 x x) -9 4)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 64 (*.f64 729 (pow.f64 (*.f64 x x) 3))) 3) (+.f64 16 (fma.f64 81 (pow.f64 x 4) (*.f64 36 (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 16 (*.f64 81 (pow.f64 x 4))) 3) (fma.f64 9 (*.f64 x x) 4))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (-.f64 64 (*.f64 729 (pow.f64 (*.f64 x x) 3)))) (+.f64 16 (fma.f64 81 (pow.f64 x 4) (*.f64 36 (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (-.f64 16 (*.f64 81 (pow.f64 x 4)))) (fma.f64 9 (*.f64 x x) 4))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 9 (pow.f64 (fma.f64 (*.f64 x x) -9 4) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 3) (fma.f64 (*.f64 x x) -9 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (fma.f64 (*.f64 x x) -9 4) 3)) 1))))))

simplify225.0ms (2.2%)

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

Useful iterations: 2 (0.0ms)

IterNodesCost
018360
132342
255315
3105315
4277315
5867315
61203315
71642315
81745315
91879315
102048315
112289315
122604315
132976315
143432315
154015315
164725315
175581315
186005315
196321315
206629315
216709315
226743315
Stop Event
node limit
Counts
165 → 136
Calls
Call 1
Inputs
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (pow.f64 x 2))
6
(+.f64 (*.f64 -9 x) 6)
(+.f64 (*.f64 -9 x) 6)
(+.f64 (*.f64 -9 x) 6)
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
12
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(*.f64 -27 (pow.f64 x 2))
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(*.f64 -27 (pow.f64 x 2))
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
Outputs
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
6
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 6 x)
(*.f64 x 6)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 (*.f64 x x) -9))
(fma.f64 x 6 (*.f64 (*.f64 x x) -9))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 (*.f64 x x) -9))
(fma.f64 x 6 (*.f64 (*.f64 x x) -9))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 (*.f64 x x) -9))
(fma.f64 x 6 (*.f64 (*.f64 x x) -9))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 (*.f64 x x) -9)
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 (*.f64 x x) -9))
(fma.f64 x 6 (*.f64 (*.f64 x x) -9))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 (*.f64 x x) -9))
(fma.f64 x 6 (*.f64 (*.f64 x x) -9))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 (*.f64 x x) -9))
(fma.f64 x 6 (*.f64 (*.f64 x x) -9))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 (*.f64 x x) -9)
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 (*.f64 x x) -9))
(fma.f64 x 6 (*.f64 (*.f64 x x) -9))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 (*.f64 x x) -9))
(fma.f64 x 6 (*.f64 (*.f64 x x) -9))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 (*.f64 x x) -9))
(fma.f64 x 6 (*.f64 (*.f64 x x) -9))
(*.f64 x (fma.f64 x -9 6))
12
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 (*.f64 x x) -27))
(fma.f64 (*.f64 x x) -27 12)
(fma.f64 x (*.f64 x -27) 12)
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 (*.f64 x x) -27))
(fma.f64 (*.f64 x x) -27 12)
(fma.f64 x (*.f64 x -27) 12)
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 (*.f64 x x) -27))
(fma.f64 (*.f64 x x) -27 12)
(fma.f64 x (*.f64 x -27) 12)
(*.f64 -27 (pow.f64 x 2))
(*.f64 (*.f64 x x) -27)
(*.f64 x (*.f64 x -27))
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 (*.f64 x x) -27))
(fma.f64 (*.f64 x x) -27 12)
(fma.f64 x (*.f64 x -27) 12)
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 (*.f64 x x) -27))
(fma.f64 (*.f64 x x) -27 12)
(fma.f64 x (*.f64 x -27) 12)
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 (*.f64 x x) -27))
(fma.f64 (*.f64 x x) -27 12)
(fma.f64 x (*.f64 x -27) 12)
(*.f64 -27 (pow.f64 x 2))
(*.f64 (*.f64 x x) -27)
(*.f64 x (*.f64 x -27))
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 (*.f64 x x) -27))
(fma.f64 (*.f64 x x) -27 12)
(fma.f64 x (*.f64 x -27) 12)
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 (*.f64 x x) -27))
(fma.f64 (*.f64 x x) -27 12)
(fma.f64 x (*.f64 x -27) 12)
(+.f64 12 (*.f64 -27 (pow.f64 x 2)))
(+.f64 12 (*.f64 (*.f64 x x) -27))
(fma.f64 (*.f64 x x) -27 12)
(fma.f64 x (*.f64 x -27) 12)

localize71.0ms (0.7%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 3 (-.f64 2 (*.f64 3 x)))
0.1b
(*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))
0.2b
(pow.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))) 3)
42.0b
(cbrt.f64 (pow.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))) 3))
Compiler

Compiled 51 to 41 computations (19.6% saved)

series14.0ms (0.1%)

Counts
4 → 48
Calls

12 calls:

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

rewrite205.0ms (2%)

Algorithm
batch-egg-rewrite
Rules
980×pow1_binary64
921×add-log-exp_binary64
920×log1p-expm1-u_binary64
920×expm1-log1p-u_binary64
101×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01052
122752
2259152
Stop Event
node limit
Counts
4 → 106
Calls
Call 1
Inputs
(cbrt.f64 (pow.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))) 3))
(pow.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))) 3)
(*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))
(*.f64 3 (-.f64 2 (*.f64 3 x)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 6 x) (*.f64 (*.f64 x -3) (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 6 x) (*.f64 (*.f64 x 3) (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 x (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 3) (+.f64 2 (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 2 (*.f64 x -3)) (*.f64 x 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (pow.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)) (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (*.f64 x x) 9)) (*.f64 (cbrt.f64 (*.f64 x 3)) (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) 2) (*.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x 3)) (*.f64 (sqrt.f64 (*.f64 x 3)) (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) (*.f64 (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2) 1/3) (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3/2) 1/3) (pow.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3/2) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (+.f64 2 (*.f64 x -3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (pow.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) 2)) (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)))) (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 x 3) (pow.f64 (cbrt.f64 (+.f64 2 (*.f64 x -3))) 2)) (cbrt.f64 (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 x 3) (sqrt.f64 (+.f64 2 (*.f64 x -3)))) (sqrt.f64 (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) (cbrt.f64 (*.f64 x x))) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x 3) (-.f64 8 (*.f64 27 (pow.f64 x 3)))) (+.f64 (+.f64 4 (*.f64 (*.f64 x x) 9)) (*.f64 6 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x 3) (-.f64 4 (*.f64 (*.f64 x x) 9))) (+.f64 2 (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (*.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 3) (*.f64 (+.f64 2 (*.f64 x -3)) (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) (*.f64 x (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2) (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)) (*.f64 (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (*.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 x 3) (*.f64 (pow.f64 (+.f64 2 (*.f64 x -3)) 3) 27))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (+.f64 2 (*.f64 x -3)) 3) 27) (pow.f64 x 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 27 (pow.f64 x 3)) (pow.f64 (+.f64 2 (*.f64 x -3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3/2) (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)) 3) (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) 3) (pow.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2) x) (+.f64 6 (*.f64 (*.f64 x -3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2) (*.f64 x 3)) (+.f64 2 (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2) (+.f64 6 (*.f64 (*.f64 x -3) 3))) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2) 1) (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2) (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2))) (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2) (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))) (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 6))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 3 (log.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 6 x) (*.f64 (*.f64 x -3) (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 6 x) (*.f64 (*.f64 x 3) (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x 3) (-.f64 8 (*.f64 27 (pow.f64 x 3)))) (+.f64 (+.f64 4 (*.f64 (*.f64 x x) 9)) (*.f64 6 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x 3) (-.f64 4 (*.f64 (*.f64 x x) 9))) (+.f64 2 (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 6 (*.f64 (*.f64 x -3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 6 (*.f64 3 (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 8 (*.f64 27 (pow.f64 x 3))) 3) (+.f64 (+.f64 4 (*.f64 (*.f64 x x) 9)) (*.f64 6 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 4 (*.f64 (*.f64 x x) 9)) 3) (+.f64 2 (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (-.f64 8 (*.f64 27 (pow.f64 x 3)))) (+.f64 (+.f64 4 (*.f64 (*.f64 x x) 9)) (*.f64 6 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (-.f64 4 (*.f64 (*.f64 x x) 9))) (+.f64 2 (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (+.f64 2 (*.f64 x -3)) 3) 27) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 (+.f64 2 (*.f64 x -3)) 2) 9))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 3) (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (+.f64 2 (*.f64 x -3)) 3) 27))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))))

simplify150.0ms (1.5%)

Algorithm
egg-herbie
Rules
578×distribute-rgt-out_binary64
492×unswap-sqr_binary64
453×associate-*l*_binary64
441×*-commutative_binary64
441×fma-def_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
042533
1101524
2229470
3658459
42580455
54826455
65124455
75580455
86406455
97345455
Stop Event
node limit
Counts
154 → 118
Calls
Call 1
Inputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 3 (*.f64 (pow.f64 x 2) (cbrt.f64 -27)))
(+.f64 (*.f64 -2 (*.f64 x (cbrt.f64 -27))) (*.f64 3 (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(+.f64 (*.f64 -2 (*.f64 x (cbrt.f64 -27))) (*.f64 3 (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(+.f64 (*.f64 -2 (*.f64 x (cbrt.f64 -27))) (*.f64 3 (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(*.f64 216 (pow.f64 x 3))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (*.f64 216 (pow.f64 x 3)))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 216 (pow.f64 x 3)) (*.f64 1458 (pow.f64 x 5))))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 216 (pow.f64 x 3)) (+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6)))))
(*.f64 -729 (pow.f64 x 6))
(+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6)))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6))))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 216 (pow.f64 x 3)) (+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6)))))
(*.f64 -729 (pow.f64 x 6))
(+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6)))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6))))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 216 (pow.f64 x 3)) (+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6)))))
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
6
(+.f64 (*.f64 -9 x) 6)
(+.f64 (*.f64 -9 x) 6)
(+.f64 (*.f64 -9 x) 6)
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
Outputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 3 (*.f64 (pow.f64 x 2) (cbrt.f64 -27)))
(*.f64 3 (*.f64 (*.f64 x x) (cbrt.f64 -27)))
(*.f64 (*.f64 x x) (*.f64 (cbrt.f64 -27) 3))
(*.f64 (cbrt.f64 -27) (*.f64 (*.f64 x x) 3))
(*.f64 x (*.f64 3 (*.f64 x (cbrt.f64 -27))))
(*.f64 (*.f64 x x) (*.f64 3 (cbrt.f64 -27)))
(+.f64 (*.f64 -2 (*.f64 x (cbrt.f64 -27))) (*.f64 3 (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(fma.f64 -2 (*.f64 x (cbrt.f64 -27)) (*.f64 3 (*.f64 (*.f64 x x) (cbrt.f64 -27))))
(*.f64 (cbrt.f64 -27) (+.f64 (*.f64 x -2) (*.f64 (*.f64 x x) 3)))
(*.f64 (cbrt.f64 -27) (*.f64 x (+.f64 -2 (*.f64 x 3))))
(*.f64 x (*.f64 (fma.f64 x 3 -2) (cbrt.f64 -27)))
(*.f64 (*.f64 x (cbrt.f64 -27)) (fma.f64 x 3 -2))
(+.f64 (*.f64 -2 (*.f64 x (cbrt.f64 -27))) (*.f64 3 (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(fma.f64 -2 (*.f64 x (cbrt.f64 -27)) (*.f64 3 (*.f64 (*.f64 x x) (cbrt.f64 -27))))
(*.f64 (cbrt.f64 -27) (+.f64 (*.f64 x -2) (*.f64 (*.f64 x x) 3)))
(*.f64 (cbrt.f64 -27) (*.f64 x (+.f64 -2 (*.f64 x 3))))
(*.f64 x (*.f64 (fma.f64 x 3 -2) (cbrt.f64 -27)))
(*.f64 (*.f64 x (cbrt.f64 -27)) (fma.f64 x 3 -2))
(+.f64 (*.f64 -2 (*.f64 x (cbrt.f64 -27))) (*.f64 3 (*.f64 (pow.f64 x 2) (cbrt.f64 -27))))
(fma.f64 -2 (*.f64 x (cbrt.f64 -27)) (*.f64 3 (*.f64 (*.f64 x x) (cbrt.f64 -27))))
(*.f64 (cbrt.f64 -27) (+.f64 (*.f64 x -2) (*.f64 (*.f64 x x) 3)))
(*.f64 (cbrt.f64 -27) (*.f64 x (+.f64 -2 (*.f64 x 3))))
(*.f64 x (*.f64 (fma.f64 x 3 -2) (cbrt.f64 -27)))
(*.f64 (*.f64 x (cbrt.f64 -27)) (fma.f64 x 3 -2))
(*.f64 216 (pow.f64 x 3))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (*.f64 216 (pow.f64 x 3)))
(fma.f64 -972 (pow.f64 x 4) (*.f64 216 (pow.f64 x 3)))
(fma.f64 216 (pow.f64 x 3) (*.f64 -972 (pow.f64 x 4)))
(*.f64 (pow.f64 x 3) (+.f64 216 (*.f64 x -972)))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 216 (pow.f64 x 3)) (*.f64 1458 (pow.f64 x 5))))
(fma.f64 -972 (pow.f64 x 4) (fma.f64 216 (pow.f64 x 3) (*.f64 1458 (pow.f64 x 5))))
(fma.f64 216 (pow.f64 x 3) (fma.f64 -972 (pow.f64 x 4) (*.f64 1458 (pow.f64 x 5))))
(fma.f64 1458 (pow.f64 x 5) (*.f64 (pow.f64 x 3) (+.f64 216 (*.f64 x -972))))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 216 (pow.f64 x 3)) (+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6)))))
(fma.f64 -972 (pow.f64 x 4) (fma.f64 216 (pow.f64 x 3) (fma.f64 1458 (pow.f64 x 5) (*.f64 -729 (pow.f64 x 6)))))
(fma.f64 216 (pow.f64 x 3) (fma.f64 -972 (pow.f64 x 4) (fma.f64 1458 (pow.f64 x 5) (*.f64 -729 (pow.f64 x 6)))))
(fma.f64 1458 (pow.f64 x 5) (*.f64 (pow.f64 x 3) (+.f64 (*.f64 x -972) (fma.f64 (pow.f64 x 3) -729 216))))
(fma.f64 -972 (pow.f64 x 4) (fma.f64 216 (pow.f64 x 3) (*.f64 (pow.f64 x 5) (+.f64 1458 (*.f64 x -729)))))
(*.f64 -729 (pow.f64 x 6))
(+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6)))
(fma.f64 1458 (pow.f64 x 5) (*.f64 -729 (pow.f64 x 6)))
(*.f64 (pow.f64 x 5) (+.f64 1458 (*.f64 x -729)))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6))))
(fma.f64 -972 (pow.f64 x 4) (fma.f64 1458 (pow.f64 x 5) (*.f64 -729 (pow.f64 x 6))))
(fma.f64 1458 (pow.f64 x 5) (fma.f64 -729 (pow.f64 x 6) (*.f64 -972 (pow.f64 x 4))))
(fma.f64 -972 (pow.f64 x 4) (*.f64 (pow.f64 x 5) (+.f64 1458 (*.f64 x -729))))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 216 (pow.f64 x 3)) (+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6)))))
(fma.f64 -972 (pow.f64 x 4) (fma.f64 216 (pow.f64 x 3) (fma.f64 1458 (pow.f64 x 5) (*.f64 -729 (pow.f64 x 6)))))
(fma.f64 216 (pow.f64 x 3) (fma.f64 -972 (pow.f64 x 4) (fma.f64 1458 (pow.f64 x 5) (*.f64 -729 (pow.f64 x 6)))))
(fma.f64 1458 (pow.f64 x 5) (*.f64 (pow.f64 x 3) (+.f64 (*.f64 x -972) (fma.f64 (pow.f64 x 3) -729 216))))
(fma.f64 -972 (pow.f64 x 4) (fma.f64 216 (pow.f64 x 3) (*.f64 (pow.f64 x 5) (+.f64 1458 (*.f64 x -729)))))
(*.f64 -729 (pow.f64 x 6))
(+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6)))
(fma.f64 1458 (pow.f64 x 5) (*.f64 -729 (pow.f64 x 6)))
(*.f64 (pow.f64 x 5) (+.f64 1458 (*.f64 x -729)))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6))))
(fma.f64 -972 (pow.f64 x 4) (fma.f64 1458 (pow.f64 x 5) (*.f64 -729 (pow.f64 x 6))))
(fma.f64 1458 (pow.f64 x 5) (fma.f64 -729 (pow.f64 x 6) (*.f64 -972 (pow.f64 x 4))))
(fma.f64 -972 (pow.f64 x 4) (*.f64 (pow.f64 x 5) (+.f64 1458 (*.f64 x -729))))
(+.f64 (*.f64 -972 (pow.f64 x 4)) (+.f64 (*.f64 216 (pow.f64 x 3)) (+.f64 (*.f64 1458 (pow.f64 x 5)) (*.f64 -729 (pow.f64 x 6)))))
(fma.f64 -972 (pow.f64 x 4) (fma.f64 216 (pow.f64 x 3) (fma.f64 1458 (pow.f64 x 5) (*.f64 -729 (pow.f64 x 6)))))
(fma.f64 216 (pow.f64 x 3) (fma.f64 -972 (pow.f64 x 4) (fma.f64 1458 (pow.f64 x 5) (*.f64 -729 (pow.f64 x 6)))))
(fma.f64 1458 (pow.f64 x 5) (*.f64 (pow.f64 x 3) (+.f64 (*.f64 x -972) (fma.f64 (pow.f64 x 3) -729 216))))
(fma.f64 -972 (pow.f64 x 4) (fma.f64 216 (pow.f64 x 3) (*.f64 (pow.f64 x 5) (+.f64 1458 (*.f64 x -729)))))
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
6
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)

localize69.0ms (0.7%)

Local error

Found 4 expressions with local error:

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

Compiled 50 to 40 computations (20% saved)

series15.0ms (0.1%)

Counts
2 → 16
Calls

6 calls:

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

rewrite97.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
955×pow1_binary64
892×add-log-exp_binary64
891×log1p-expm1-u_binary64
891×expm1-log1p-u_binary64
98×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01028
122328
2247628
Stop Event
node limit
Counts
2 → 69
Calls
Call 1
Inputs
(pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 2)
(sqrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 6 x) (*.f64 (*.f64 x -3) (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 6 x) (*.f64 (*.f64 x 3) (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 x (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 3) (+.f64 2 (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 2 (*.f64 x -3)) (*.f64 x 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (*.f64 (cbrt.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))) (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)) (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (*.f64 x x) 9)) (*.f64 (cbrt.f64 (*.f64 x 3)) (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) 2) (*.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x 3)) (*.f64 (sqrt.f64 (*.f64 x 3)) (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1/4) (*.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1/4) (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) (*.f64 (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1/4)) (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (+.f64 2 (*.f64 x -3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (pow.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) 2)) (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)))) (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 x 3) (pow.f64 (cbrt.f64 (+.f64 2 (*.f64 x -3))) 2)) (cbrt.f64 (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 x 3) (sqrt.f64 (+.f64 2 (*.f64 x -3)))) (sqrt.f64 (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) (cbrt.f64 (*.f64 x x))) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))) (cbrt.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (sqrt.f64 x)) (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x 3) (-.f64 8 (*.f64 (pow.f64 x 3) 27))) (+.f64 (+.f64 4 (*.f64 (*.f64 x x) 9)) (*.f64 6 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x 3) (-.f64 4 (*.f64 (*.f64 x x) 9))) (+.f64 2 (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (*.f64 (pow.f64 x 3) 27) (pow.f64 (+.f64 2 (*.f64 x -3)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) (cbrt.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))) (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x 3)) (sqrt.f64 (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1/4) (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2))) (sqrt.f64 (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 2)) 1/2) (pow.f64 (cbrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3/2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 1/4) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (sqrt.f64 (*.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x)))))))))

simplify92.0ms (0.9%)

Algorithm
egg-herbie
Rules
939×associate-/l*_binary64
475×fma-neg_binary64
415×fma-def_binary64
378×associate-*l/_binary64
283×associate-/l/_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
080498
1244340
2937314
33285302
Stop Event
node limit
Counts
85 → 94
Calls
Call 1
Inputs
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2)))
(+.f64 (*.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x)) (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(+.f64 (*.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x)) (+.f64 (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2))) (+.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))) (/.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)))))
(+.f64 (*.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x)) (+.f64 (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2))) (+.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))) (+.f64 (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 4) x))) (+.f64 (/.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)) (/.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 4) x)))))))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2)))
(+.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))) (*.f64 -2 (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(+.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))) (+.f64 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 2)) (+.f64 (*.f64 -2 (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)) (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 2))))))
(+.f64 (*.f64 -1 (/.f64 (+.f64 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 4)) (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 4)))) x)) (+.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))) (+.f64 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 2)) (+.f64 (*.f64 -2 (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)) (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 2)))))))
(*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))
(+.f64 (/.f64 (sqrt.f64 3) (sqrt.f64 -3)) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x)))
(+.f64 (/.f64 (sqrt.f64 3) (sqrt.f64 -3)) (+.f64 (*.f64 -1/2 (/.f64 (sqrt.f64 3) (*.f64 (pow.f64 (sqrt.f64 -3) 3) x))) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))))
(+.f64 (/.f64 (sqrt.f64 3) (sqrt.f64 -3)) (+.f64 (*.f64 1/2 (/.f64 (sqrt.f64 3) (*.f64 (pow.f64 (sqrt.f64 -3) 5) (pow.f64 x 2)))) (+.f64 (*.f64 -1/2 (/.f64 (sqrt.f64 3) (*.f64 (pow.f64 (sqrt.f64 -3) 3) x))) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x)))))
(*.f64 -1 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x)))
(+.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (*.f64 -1 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))))
(+.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (+.f64 (*.f64 -1 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))) (*.f64 1/2 (/.f64 (sqrt.f64 -3) (*.f64 (pow.f64 (sqrt.f64 3) 3) x)))))
(+.f64 (*.f64 1/2 (/.f64 (sqrt.f64 -3) (*.f64 (pow.f64 (sqrt.f64 3) 5) (pow.f64 x 2)))) (+.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (+.f64 (*.f64 -1 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))) (*.f64 1/2 (/.f64 (sqrt.f64 -3) (*.f64 (pow.f64 (sqrt.f64 3) 3) x))))))
Outputs
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)) (*.f64 x x))
(*.f64 (*.f64 x x) -9)
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x)) (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))))
(fma.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x) (*.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)) (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (+.f64 (*.f64 x -9) 6))
(+.f64 (*.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x)) (+.f64 (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2))) (+.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))) (/.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)))))
(fma.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x) (*.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)) (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (+.f64 (*.f64 x -9) 6))
(+.f64 (*.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x)) (+.f64 (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2))) (+.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))) (+.f64 (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 4) x))) (+.f64 (/.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)) (/.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 4) x)))))))
(fma.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x) (*.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)) (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (+.f64 (*.f64 x -9) 6))
(*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2)))
(*.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)) (*.f64 x x))
(*.f64 (*.f64 x x) -9)
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))) (*.f64 -2 (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)))
(fma.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x) (*.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)) (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (+.f64 (*.f64 x -9) 6))
(+.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))) (+.f64 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 2)) (+.f64 (*.f64 -2 (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)) (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 2))))))
(fma.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x) (*.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)) (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (+.f64 (*.f64 x -9) 6))
(+.f64 (*.f64 -1 (/.f64 (+.f64 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 4)) (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 4)))) x)) (+.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (*.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 x 2))) (+.f64 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 2)) (+.f64 (*.f64 -2 (*.f64 (pow.f64 (sqrt.f64 -3) 2) x)) (*.f64 -1 (/.f64 (pow.f64 (sqrt.f64 -3) 2) (pow.f64 (sqrt.f64 3) 2)))))))
(fma.f64 2 (*.f64 (pow.f64 (sqrt.f64 3) 2) x) (*.f64 (*.f64 (pow.f64 (sqrt.f64 3) 2) (pow.f64 (sqrt.f64 -3) 2)) (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (+.f64 (*.f64 x -9) 6))
(*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))
(*.f64 (*.f64 (sqrt.f64 3) (sqrt.f64 -3)) x)
(*.f64 (sqrt.f64 -3) (*.f64 x (sqrt.f64 3)))
(+.f64 (/.f64 (sqrt.f64 3) (sqrt.f64 -3)) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x)))
(+.f64 (*.f64 (*.f64 (sqrt.f64 3) (sqrt.f64 -3)) x) (/.f64 (sqrt.f64 3) (sqrt.f64 -3)))
(fma.f64 (*.f64 (sqrt.f64 3) (sqrt.f64 -3)) x (/.f64 (sqrt.f64 3) (sqrt.f64 -3)))
(fma.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x) (/.f64 (sqrt.f64 3) (sqrt.f64 -3)))
(+.f64 (/.f64 (sqrt.f64 3) (sqrt.f64 -3)) (+.f64 (*.f64 -1/2 (/.f64 (sqrt.f64 3) (*.f64 (pow.f64 (sqrt.f64 -3) 3) x))) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))))
(+.f64 (/.f64 (sqrt.f64 3) (sqrt.f64 -3)) (fma.f64 -1/2 (/.f64 (/.f64 (sqrt.f64 3) (pow.f64 (sqrt.f64 -3) 3)) x) (*.f64 (*.f64 (sqrt.f64 3) (sqrt.f64 -3)) x)))
(+.f64 (/.f64 (sqrt.f64 3) (sqrt.f64 -3)) (fma.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x) (*.f64 -1/2 (/.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) (*.f64 -3 x))))))
(fma.f64 (/.f64 1/6 (sqrt.f64 -3)) (/.f64 (sqrt.f64 3) x) (fma.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x) (/.f64 (sqrt.f64 3) (sqrt.f64 -3))))
(fma.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x) (*.f64 (+.f64 (/.f64 -1/2 (*.f64 -3 x)) 1) (/.f64 (sqrt.f64 3) (sqrt.f64 -3))))
(+.f64 (/.f64 (sqrt.f64 3) (sqrt.f64 -3)) (+.f64 (*.f64 1/2 (/.f64 (sqrt.f64 3) (*.f64 (pow.f64 (sqrt.f64 -3) 5) (pow.f64 x 2)))) (+.f64 (*.f64 -1/2 (/.f64 (sqrt.f64 3) (*.f64 (pow.f64 (sqrt.f64 -3) 3) x))) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x)))))
(+.f64 (/.f64 (sqrt.f64 3) (sqrt.f64 -3)) (fma.f64 1/2 (/.f64 (/.f64 (sqrt.f64 3) (pow.f64 (sqrt.f64 -3) 5)) (*.f64 x x)) (fma.f64 -1/2 (/.f64 (/.f64 (sqrt.f64 3) (pow.f64 (sqrt.f64 -3) 3)) x) (*.f64 (*.f64 (sqrt.f64 3) (sqrt.f64 -3)) x))))
(+.f64 (/.f64 (sqrt.f64 3) (sqrt.f64 -3)) (fma.f64 1/2 (/.f64 (sqrt.f64 3) (*.f64 (*.f64 x x) (pow.f64 (sqrt.f64 -3) 5))) (fma.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x) (*.f64 -1/2 (/.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) (*.f64 -3 x)))))))
(fma.f64 1/2 (/.f64 (sqrt.f64 3) (*.f64 (*.f64 x x) (pow.f64 (sqrt.f64 -3) 5))) (fma.f64 (/.f64 1/6 (sqrt.f64 -3)) (/.f64 (sqrt.f64 3) x) (fma.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x) (/.f64 (sqrt.f64 3) (sqrt.f64 -3)))))
(+.f64 (fma.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x) (/.f64 (sqrt.f64 3) (sqrt.f64 -3))) (*.f64 (/.f64 (sqrt.f64 3) x) (+.f64 (/.f64 1/6 (sqrt.f64 -3)) (/.f64 1/2 (*.f64 x (pow.f64 (sqrt.f64 -3) 5))))))
(*.f64 -1 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x)))
(neg.f64 (*.f64 (*.f64 (sqrt.f64 3) (sqrt.f64 -3)) x))
(neg.f64 (*.f64 (sqrt.f64 -3) (*.f64 x (sqrt.f64 3))))
(*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) (neg.f64 x)))
(+.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (*.f64 -1 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))))
(+.f64 (neg.f64 (*.f64 (*.f64 (sqrt.f64 3) (sqrt.f64 -3)) x)) (/.f64 (sqrt.f64 -3) (sqrt.f64 3)))
(-.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (*.f64 (sqrt.f64 -3) (*.f64 x (sqrt.f64 3))))
(-.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x)))
(+.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (+.f64 (*.f64 -1 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))) (*.f64 1/2 (/.f64 (sqrt.f64 -3) (*.f64 (pow.f64 (sqrt.f64 3) 3) x)))))
(+.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (fma.f64 -1 (*.f64 (*.f64 (sqrt.f64 3) (sqrt.f64 -3)) x) (/.f64 (*.f64 1/2 (sqrt.f64 -3)) (*.f64 x (pow.f64 (sqrt.f64 3) 3)))))
(+.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (-.f64 (*.f64 1/2 (/.f64 (sqrt.f64 -3) (*.f64 (sqrt.f64 3) (*.f64 3 x)))) (*.f64 (sqrt.f64 -3) (*.f64 x (sqrt.f64 3)))))
(-.f64 (fma.f64 (/.f64 1/6 (sqrt.f64 3)) (/.f64 (sqrt.f64 -3) x) (/.f64 (sqrt.f64 -3) (sqrt.f64 3))) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x)))
(-.f64 (*.f64 (+.f64 (/.f64 1/2 (*.f64 3 x)) 1) (/.f64 (sqrt.f64 -3) (sqrt.f64 3))) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x)))
(+.f64 (*.f64 1/2 (/.f64 (sqrt.f64 -3) (*.f64 (pow.f64 (sqrt.f64 3) 5) (pow.f64 x 2)))) (+.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (+.f64 (*.f64 -1 (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))) (*.f64 1/2 (/.f64 (sqrt.f64 -3) (*.f64 (pow.f64 (sqrt.f64 3) 3) x))))))
(fma.f64 1/2 (/.f64 (/.f64 (sqrt.f64 -3) (pow.f64 (sqrt.f64 3) 5)) (*.f64 x x)) (+.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (fma.f64 -1 (*.f64 (*.f64 (sqrt.f64 3) (sqrt.f64 -3)) x) (/.f64 (*.f64 1/2 (sqrt.f64 -3)) (*.f64 x (pow.f64 (sqrt.f64 3) 3))))))
(+.f64 (-.f64 (*.f64 1/2 (/.f64 (sqrt.f64 -3) (*.f64 (sqrt.f64 3) (*.f64 3 x)))) (*.f64 (sqrt.f64 -3) (*.f64 x (sqrt.f64 3)))) (fma.f64 1/2 (/.f64 (sqrt.f64 -3) (*.f64 (*.f64 x x) (pow.f64 (sqrt.f64 3) 5))) (/.f64 (sqrt.f64 -3) (sqrt.f64 3))))
(fma.f64 1/2 (/.f64 (sqrt.f64 -3) (*.f64 (*.f64 x x) (pow.f64 (sqrt.f64 3) 5))) (-.f64 (fma.f64 (/.f64 1/6 (sqrt.f64 3)) (/.f64 (sqrt.f64 -3) x) (/.f64 (sqrt.f64 -3) (sqrt.f64 3))) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))))
(+.f64 (/.f64 (sqrt.f64 -3) (sqrt.f64 3)) (-.f64 (*.f64 (/.f64 (sqrt.f64 -3) x) (+.f64 (/.f64 1/6 (sqrt.f64 3)) (/.f64 1/2 (*.f64 x (pow.f64 (sqrt.f64 3) 5))))) (*.f64 (sqrt.f64 3) (*.f64 (sqrt.f64 -3) x))))

eval280.0ms (2.8%)

Compiler

Compiled 7016 to 5629 computations (19.8% saved)

prune137.0ms (1.4%)

Pruning

16 alts after pruning (13 fresh and 3 done)

PrunedKeptTotal
New4269435
Fresh7411
Picked101
Done134
Total43516451
Error
0b
Counts
451 → 16
Alt Table
Click to see full alt table
StatusErrorProgram
0.3b
(+.f64 (*.f64 6 x) (*.f64 (*.f64 x 3) (*.f64 x -3)))
43.1b
(pow.f64 (sqrt.f64 (*.f64 x 6)) 2)
43.8b
(*.f64 (/.f64 (*.f64 x (*.f64 x -27)) (+.f64 2 (*.f64 3 x))) x)
8.8b
(*.f64 (pow.f64 (sqrt.f64 (*.f64 3 (-.f64 2 (*.f64 3 x)))) 2) x)
8.0b
(/.f64 (*.f64 (+.f64 (pow.f64 (*.f64 -9 x) 2) -36) x) (fma.f64 -9 x -6))
0.3b
(*.f64 (+.f64 2 (*.f64 x -3)) (*.f64 x 3))
0.2b
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
0.3b
(*.f64 (/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x))) x)
43.8b
(*.f64 -9 (pow.f64 x 2))
0.3b
(/.f64 x (/.f64 1 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))
34.8b
(*.f64 (sqrt.f64 (*.f64 x 3)) (*.f64 (sqrt.f64 (*.f64 x 3)) (+.f64 2 (*.f64 x -3))))
43.8b
(*.f64 (*.f64 x -9) x)
19.0b
(*.f64 x 6)
0.3b
(*.f64 (*.f64 x (+.f64 2 (*.f64 x -3))) 3)
48.2b
(cbrt.f64 (pow.f64 (*.f64 x 6) 3))
1.4b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 3)
Compiler

Compiled 312 to 249 computations (20.2% saved)

localize19.0ms (0.2%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f64 2 (*.f64 x -3))
0.1b
(*.f64 x (+.f64 2 (*.f64 x -3)))
0.1b
(*.f64 (*.f64 x (+.f64 2 (*.f64 x -3))) 3)
Compiler

Compiled 29 to 22 computations (24.1% saved)

series9.0ms (0.1%)

Counts
3 → 36
Calls

9 calls:

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

rewrite107.0ms (1.1%)

Algorithm
batch-egg-rewrite
Rules
977×pow1_binary64
913×add-log-exp_binary64
912×log1p-expm1-u_binary64
912×expm1-log1p-u_binary64
99×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0930
119924
2250524
Stop Event
node limit
Counts
3 → 72
Calls
Call 1
Inputs
(*.f64 (*.f64 x (+.f64 2 (*.f64 x -3))) 3)
(*.f64 x (+.f64 2 (*.f64 x -3)))
(+.f64 2 (*.f64 x -3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x 2) 3) (*.f64 (*.f64 -3 (*.f64 x x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 3 (*.f64 x 2)) (*.f64 3 (*.f64 -3 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (*.f64 (fma.f64 x -3 2) 3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 (fma.f64 x -3 2) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (*.f64 (fma.f64 x -3 2) 3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (*.f64 (fma.f64 x -3 2) 3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (*.f64 (fma.f64 x -3 2) 3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 9 (pow.f64 (*.f64 x (fma.f64 x -3 2)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (*.f64 (fma.f64 x -3 2) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (*.f64 (fma.f64 x -3 2) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (*.f64 (fma.f64 x -3 2) 3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 (fma.f64 x -3 2) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 (fma.f64 x -3 2) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (*.f64 (fma.f64 x -3 2) 3))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x 2) (*.f64 -3 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 -3 (*.f64 x x)) (*.f64 x 2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x 2) 1) (*.f64 (*.f64 -3 (*.f64 x x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (fma.f64 x -3 2)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x 2) 3) (pow.f64 (*.f64 -3 (*.f64 x x)) 3)) (+.f64 (*.f64 (*.f64 x 2) (*.f64 x 2)) (-.f64 (*.f64 (*.f64 -3 (*.f64 x x)) (*.f64 -3 (*.f64 x x))) (*.f64 (*.f64 x 2) (*.f64 -3 (*.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 x 2) (*.f64 x 2)) (*.f64 (*.f64 -3 (*.f64 x x)) (*.f64 -3 (*.f64 x x)))) (-.f64 (*.f64 x 2) (*.f64 -3 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 8 (*.f64 (pow.f64 x 3) -27)) x) (+.f64 4 (-.f64 (*.f64 9 (*.f64 x x)) (*.f64 -6 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) x) (+.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 8 (*.f64 (pow.f64 x 3) -27))) (+.f64 4 (-.f64 (*.f64 9 (*.f64 x x)) (*.f64 -6 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 4 (*.f64 9 (*.f64 x x)))) (+.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (fma.f64 x -3 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (fma.f64 x -3 2)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (fma.f64 x -3 2))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (fma.f64 x -3 2))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (fma.f64 x -3 2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (fma.f64 x -3 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (fma.f64 x -3 2)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (fma.f64 x -3 2) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 x -3 2) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (fma.f64 x -3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (fma.f64 x -3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (fma.f64 x -3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x 2 (*.f64 -3 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 2 x (*.f64 -3 (*.f64 x x)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 x -3 2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 4 (+.f64 2 (*.f64 3 x))) (/.f64 (*.f64 9 (*.f64 x x)) (+.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x -3 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x -3 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x -3 2)) (pow.f64 (cbrt.f64 (fma.f64 x -3 2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x -3 2)) 2) (cbrt.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x -3 2)) (sqrt.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 8 (*.f64 (pow.f64 x 3) -27)) (/.f64 1 (+.f64 4 (-.f64 (*.f64 9 (*.f64 x x)) (*.f64 -6 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) (/.f64 1 (+.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 4 (-.f64 (*.f64 9 (*.f64 x x)) (*.f64 -6 x))) (+.f64 8 (*.f64 (pow.f64 x 3) -27))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 2 (*.f64 3 x)) (-.f64 4 (*.f64 9 (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 8 (*.f64 (pow.f64 x 3) -27)) (+.f64 4 (-.f64 (*.f64 9 (*.f64 x x)) (*.f64 -6 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 8 (*.f64 (pow.f64 x 3) -27)) (+.f64 (*.f64 9 (*.f64 x x)) (-.f64 4 (*.f64 -6 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) (+.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 8 (*.f64 (pow.f64 x 3) -27))) (neg.f64 (+.f64 4 (-.f64 (*.f64 9 (*.f64 x x)) (*.f64 -6 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 4 (*.f64 9 (*.f64 x x)))) (neg.f64 (+.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 9 (*.f64 x x)) 4) (-.f64 (*.f64 x -3) 2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x -3 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -3 2) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x -3 2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x -3 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x -3 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 x -3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x -3 2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x -3 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -3 x 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x -3) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 9 (*.f64 x x))) (cbrt.f64 (*.f64 x -3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x -3)) (sqrt.f64 (*.f64 x -3)) 2)))))

simplify212.0ms (2.1%)

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

Useful iterations: 3 (0.0ms)

IterNodesCost
016288
131288
251252
3102234
4269234
5806234
61244234
71708234
81816234
91951234
102123234
112366234
122679234
133049234
143505234
154088234
164796234
175654234
186078234
196392234
206700234
216778234
226812234
Stop Event
node limit
Counts
108 → 88
Calls
Call 1
Inputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 2 x)
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(*.f64 -3 (pow.f64 x 2))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(*.f64 -3 (pow.f64 x 2))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
2
(+.f64 (*.f64 -3 x) 2)
(+.f64 (*.f64 -3 x) 2)
(+.f64 (*.f64 -3 x) 2)
(*.f64 -3 x)
(+.f64 2 (*.f64 -3 x))
(+.f64 2 (*.f64 -3 x))
(+.f64 2 (*.f64 -3 x))
(*.f64 -3 x)
(+.f64 2 (*.f64 -3 x))
(+.f64 2 (*.f64 -3 x))
(+.f64 2 (*.f64 -3 x))
Outputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 2 x)
(*.f64 x 2)
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(fma.f64 2 x (*.f64 (*.f64 x x) -3))
(fma.f64 x 2 (*.f64 (*.f64 x x) -3))
(*.f64 x (fma.f64 x -3 2))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(fma.f64 2 x (*.f64 (*.f64 x x) -3))
(fma.f64 x 2 (*.f64 (*.f64 x x) -3))
(*.f64 x (fma.f64 x -3 2))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(fma.f64 2 x (*.f64 (*.f64 x x) -3))
(fma.f64 x 2 (*.f64 (*.f64 x x) -3))
(*.f64 x (fma.f64 x -3 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(fma.f64 2 x (*.f64 (*.f64 x x) -3))
(fma.f64 x 2 (*.f64 (*.f64 x x) -3))
(*.f64 x (fma.f64 x -3 2))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(fma.f64 2 x (*.f64 (*.f64 x x) -3))
(fma.f64 x 2 (*.f64 (*.f64 x x) -3))
(*.f64 x (fma.f64 x -3 2))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(fma.f64 2 x (*.f64 (*.f64 x x) -3))
(fma.f64 x 2 (*.f64 (*.f64 x x) -3))
(*.f64 x (fma.f64 x -3 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(fma.f64 2 x (*.f64 (*.f64 x x) -3))
(fma.f64 x 2 (*.f64 (*.f64 x x) -3))
(*.f64 x (fma.f64 x -3 2))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(fma.f64 2 x (*.f64 (*.f64 x x) -3))
(fma.f64 x 2 (*.f64 (*.f64 x x) -3))
(*.f64 x (fma.f64 x -3 2))
(+.f64 (*.f64 2 x) (*.f64 -3 (pow.f64 x 2)))
(fma.f64 2 x (*.f64 (*.f64 x x) -3))
(fma.f64 x 2 (*.f64 (*.f64 x x) -3))
(*.f64 x (fma.f64 x -3 2))
2
(+.f64 (*.f64 -3 x) 2)
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 (*.f64 -3 x) 2)
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 (*.f64 -3 x) 2)
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(*.f64 -3 x)
(*.f64 x -3)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(*.f64 -3 x)
(*.f64 x -3)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 2 (*.f64 -3 x))
(fma.f64 -3 x 2)
(fma.f64 x -3 2)

localize13.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.1b
(*.f64 (*.f64 x -9) x)
Compiler

Compiled 11 to 7 computations (36.4% saved)

series2.0ms (0%)

Counts
1 → 12
Calls

3 calls:

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

rewrite65.0ms (0.6%)

Algorithm
batch-egg-rewrite
Rules
446×pow1_binary64
432×add-sqr-sqrt_binary64
423×*-un-lft-identity_binary64
414×add-log-exp_binary64
414×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify193.0ms (1.9%)

Algorithm
egg-herbie
Rules
1082×sqr-pow_binary64
617×cube-prod_binary64
554×fabs-mul_binary64
523×pow-sqr_binary64
441×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0684
11284
22384
34484
410584
533184
6125084
7212384
8228784
9247184
10267984
11297684
12337184
13385284
14441884
15510284
16593584
17632784
18661984
19689584
20696984
21700384
22794484
Stop Event
node limit
Counts
23 → 13
Calls
Call 1
Inputs
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
Outputs
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))

localize39.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(+.f64 2 (*.f64 -3 x))
0.1b
(/.f64 1 (*.f64 3 (+.f64 2 (*.f64 -3 x))))
0.1b
(*.f64 3 (+.f64 2 (*.f64 -3 x)))
0.3b
(/.f64 x (/.f64 1 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))
Compiler

Compiled 41 to 34 computations (17.1% saved)

series11.0ms (0.1%)

Counts
4 → 42
Calls

12 calls:

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

rewrite208.0ms (2.1%)

Algorithm
batch-egg-rewrite
Rules
518×log-prod_binary64
402×exp-prod_binary64
281×pow-prod-down_binary64
279×pow2_binary64
195×expm1-udef_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01140
124830
2314726
Stop Event
node limit
Counts
4 → 220
Calls
Call 1
Inputs
(/.f64 x (/.f64 1 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))
(*.f64 3 (+.f64 2 (*.f64 -3 x)))
(/.f64 1 (*.f64 3 (+.f64 2 (*.f64 -3 x))))
(+.f64 2 (*.f64 -3 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 6 x) (*.f64 (*.f64 x -9) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x 6) (*.f64 x (*.f64 x -9)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (fma.f64 x -9 6))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (fma.f64 x -9 6)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (fma.f64 x -9 6)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (fma.f64 x -9 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x -9 6) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (fma.f64 x -9 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (fma.f64 x -9 6))) (pow.f64 (cbrt.f64 (*.f64 x (fma.f64 x -9 6))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x (fma.f64 x -9 6))) 2) (cbrt.f64 (*.f64 x (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (fma.f64 x -9 6))) (sqrt.f64 (*.f64 x (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x -9 6)) (/.f64 x (pow.f64 (fma.f64 x -9 6) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 x) (/.f64 1 (/.f64 -1 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 x) 2) 1) (/.f64 (cbrt.f64 x) (/.f64 1 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 x) 1) (/.f64 (sqrt.f64 x) (/.f64 1 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (pow.f64 (fma.f64 x -9 6) -2))) (/.f64 x (/.f64 1 (cbrt.f64 (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 x) 2) (cbrt.f64 (pow.f64 (fma.f64 x -9 6) -2))) (cbrt.f64 (*.f64 x (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 x) (cbrt.f64 (pow.f64 (fma.f64 x -9 6) -2))) (/.f64 (sqrt.f64 x) (/.f64 1 (cbrt.f64 (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 x) 2) (pow.f64 (fma.f64 x -9 6) -1/2)) (/.f64 (cbrt.f64 x) (pow.f64 (fma.f64 x -9 6) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (fma.f64 x -3 2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x -1) (neg.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x 1/3) (fma.f64 x -3 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 3) (fma.f64 x -3 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (cbrt.f64 (pow.f64 (fma.f64 x -9 6) 2))) (cbrt.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (sqrt.f64 (fma.f64 x -9 6))) (sqrt.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (fma.f64 x -9 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (*.f64 x (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (fma.f64 x -9 6)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (fma.f64 x -9 6)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (fma.f64 x -9 6))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (fma.f64 x -9 6))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (*.f64 x (fma.f64 x -9 6))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 x 3) (pow.f64 (fma.f64 x -9 6) -3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 1 (*.f64 x (fma.f64 x -9 6))) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 x 3) (pow.f64 (fma.f64 x -9 6) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 (fma.f64 x -9 6) 3) (pow.f64 x 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (cbrt.f64 (fma.f64 x -9 6)) (cbrt.f64 x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 (fma.f64 x -9 6)) (sqrt.f64 x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (*.f64 x (fma.f64 x -9 6)))) 2)) (cbrt.f64 (log.f64 (*.f64 x (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 x (fma.f64 x -9 6))))) (sqrt.f64 (log.f64 (*.f64 x (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 x (/.f64 -1 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (fma.f64 x -9 6)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (fma.f64 x -9 6)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 x 3) (pow.f64 (fma.f64 x -9 6) -3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x (fma.f64 x -9 6))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (*.f64 x (fma.f64 x -9 6)) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x (fma.f64 x -9 6)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 x (fma.f64 x -9 6)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (neg.f64 (log.f64 (*.f64 x (fma.f64 x -9 6)))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 x (fma.f64 x -9 6))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x 6 (*.f64 x (*.f64 x -9)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 6 x (*.f64 (*.f64 x -9) x))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (fma.f64 x -9 6))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 6 (*.f64 x -9))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 6 (*.f64 (*.f64 x -9) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x -9) 6)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (exp.f64 (fma.f64 x -3 2)) 2)) (fma.f64 x -3 2))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x -9 6)))) (log.f64 (sqrt.f64 (exp.f64 (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 x -9 6))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 1 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (/.f64 1 (fma.f64 x -9 6)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 3 (/.f64 1 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 x -3 2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 x -9 6) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (cbrt.f64 (pow.f64 (fma.f64 x -9 6) 2)) (/.f64 1 (cbrt.f64 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (sqrt.f64 (fma.f64 x -9 6)) (pow.f64 (fma.f64 x -9 6) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 -1 (/.f64 -1 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (fma.f64 x -9 6)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 1 (cbrt.f64 (pow.f64 (fma.f64 x -9 6) -2))) (/.f64 1 (cbrt.f64 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 216 (pow.f64 (*.f64 x -9) 3)) (+.f64 36 (-.f64 (pow.f64 (*.f64 x -9) 2) (*.f64 6 (*.f64 x -9)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 36 (pow.f64 (*.f64 x -9) 2)) (-.f64 6 (*.f64 x -9)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (fma.f64 (pow.f64 x 3) -27 8) 3) (fma.f64 (*.f64 x -3) (fma.f64 x -3 -2) 4))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 4 (*.f64 (*.f64 x x) 9)) 3) (+.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (fma.f64 (pow.f64 x 3) -27 8)) (fma.f64 (*.f64 x -3) (fma.f64 x -3 -2) 4))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 3 (-.f64 4 (*.f64 (*.f64 x x) 9))) (+.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x -9 6) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (fma.f64 x -9 6)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -9 6) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -9 6) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -9 6) -3) -1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x -9 6)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (cbrt.f64 (fma.f64 x -9 6))) -3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x -9 6)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -9 6) -1/2) -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 1 (fma.f64 x -9 6)) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (fma.f64 x -9 6))) 2)) (cbrt.f64 (log.f64 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (fma.f64 x -9 6)))) (sqrt.f64 (log.f64 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x -9 6) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x -9 6) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 x -9 6)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (neg.f64 (log.f64 (fma.f64 x -9 6))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (fma.f64 x -9 6))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 x -9 6))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (fma.f64 x -9 6))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (fma.f64 x -9 6)) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (fma.f64 x -9 6)) -1) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (neg.f64 (log.f64 (fma.f64 x -9 6))) 1) -1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x -9 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x -9) 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 3 (*.f64 x -3) 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -3 (*.f64 x 3) 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x -3) 3 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x -3)) 2) (*.f64 (cbrt.f64 (*.f64 x -3)) 3) 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x -3)) (*.f64 (sqrt.f64 (*.f64 x -3)) 3) 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x -9)) 2) (cbrt.f64 (*.f64 x -9)) 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x -9)) (sqrt.f64 (*.f64 x -9)) 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 3 x) -3 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -9 x 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 3 (pow.f64 (cbrt.f64 (*.f64 x -3)) 2)) (cbrt.f64 (*.f64 x -3)) 6)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 3 (sqrt.f64 (*.f64 x -3))) (sqrt.f64 (*.f64 x -3)) 6)))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 1 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 1 (fma.f64 x -9 6)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 1 (fma.f64 x -9 6))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 1 (fma.f64 x -9 6))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 1 (fma.f64 x -9 6))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 1 (fma.f64 x -9 6)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 1 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 x -9 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (fma.f64 x -9 6))) (cbrt.f64 (pow.f64 (fma.f64 x -9 6) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (fma.f64 x -9 6) -2)) (/.f64 1 (cbrt.f64 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (fma.f64 x -9 6) -1/2) (pow.f64 (fma.f64 x -9 6) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (/.f64 -1 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/3 (/.f64 1 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 x -3 2)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/3 (fma.f64 (pow.f64 x 3) -27 8)) (fma.f64 (*.f64 x -3) (fma.f64 x -3 -2) 4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/3 (-.f64 4 (*.f64 (*.f64 x x) 9))) (+.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x -9 6)) -2) (/.f64 1 (cbrt.f64 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x -9 6) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (fma.f64 x -9 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (neg.f64 (log.f64 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -9 6) 2) -1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -9 6) 3) -1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -9 6) -2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -9 6) -3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x -9 6)) -3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (cbrt.f64 (fma.f64 x -9 6))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x -9 6)) -2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -9 6) -1/2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 -1) (log.f64 (fma.f64 x -9 6)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (neg.f64 (neg.f64 (fma.f64 x -9 6))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (neg.f64 (log.f64 (fma.f64 x -9 6)))) 2)) (cbrt.f64 (neg.f64 (log.f64 (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (neg.f64 (log.f64 (fma.f64 x -9 6))))) (sqrt.f64 (neg.f64 (log.f64 (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x -9 6) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 1 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 1 (fma.f64 x -9 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x -9 6) -3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 1 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 1 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (neg.f64 (log.f64 (fma.f64 x -9 6))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 x -9 6)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (neg.f64 (log.f64 (fma.f64 x -9 6))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (fma.f64 x -9 6) -3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (neg.f64 (log.f64 (cbrt.f64 (fma.f64 x -9 6)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 -1/2 (log.f64 (fma.f64 x -9 6))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (fma.f64 x -9 6)) 1) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (fma.f64 x -9 6)) -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (neg.f64 (log.f64 (fma.f64 x -9 6))) 1) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 x -3 2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 4 (+.f64 2 (*.f64 3 x))) (/.f64 (*.f64 (*.f64 x x) 9) (+.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x -3 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x -3 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x -3 2)) (pow.f64 (cbrt.f64 (fma.f64 x -3 2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x -3 2)) 2) (cbrt.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x -3 2)) (sqrt.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (pow.f64 x 3) -27 8) (/.f64 1 (fma.f64 (*.f64 x -3) (fma.f64 x -3 -2) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 4 (*.f64 (*.f64 x x) 9)) (/.f64 1 (+.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (*.f64 x -3) (fma.f64 x -3 -2) 4) (fma.f64 (pow.f64 x 3) -27 8)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 2 (*.f64 3 x)) (-.f64 4 (*.f64 (*.f64 x x) 9))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 (pow.f64 x 3) -27 8) (fma.f64 (*.f64 x -3) (fma.f64 x -3 -2) 4))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 (pow.f64 x 3) -27 8) (fma.f64 (*.f64 x x) 9 (-.f64 4 (*.f64 -6 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 4 (*.f64 (*.f64 x x) 9)) (+.f64 2 (*.f64 3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (fma.f64 (pow.f64 x 3) -27 8)) (neg.f64 (fma.f64 (*.f64 x -3) (fma.f64 x -3 -2) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 4 (*.f64 (*.f64 x x) 9))) (neg.f64 (+.f64 2 (*.f64 3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 (*.f64 x x) 9 -4) (fma.f64 x -3 -2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x -3 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -3 2) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -3 2) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x -3 2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x -3 2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 (*.f64 x -3) (fma.f64 x -3 -2) 4) (fma.f64 (pow.f64 x 3) -27 8)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 2 (*.f64 3 x)) (-.f64 4 (*.f64 (*.f64 x x) 9))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (fma.f64 x -3 2))) 2)) (cbrt.f64 (log.f64 (fma.f64 x -3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (fma.f64 x -3 2)))) (sqrt.f64 (log.f64 (fma.f64 x -3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x -3 2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 x -3 2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x -3 2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 x -3 2)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (fma.f64 x -3 2))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 x -3 2))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (fma.f64 x -3 2))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (fma.f64 x -3 2)) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x -3 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x -3) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -3 x 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x -3) 1 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) 2) (*.f64 (cbrt.f64 x) -3) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x -3)) (pow.f64 (cbrt.f64 (*.f64 x -3)) 2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x -3)) 2) (cbrt.f64 (*.f64 x -3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) -3) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x -3)) (sqrt.f64 (*.f64 x -3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 -3 (pow.f64 (cbrt.f64 x) 2)) (cbrt.f64 x) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 -3 (sqrt.f64 x)) (sqrt.f64 x) 2)))))

simplify154.0ms (1.5%)

Algorithm
egg-herbie
Rules
651×fma-neg_binary64
492×times-frac_binary64
421×fma-def_binary64
342×associate-*l/_binary64
338×cancel-sign-sub-inv_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
055390
1137376
2335346
3974339
42881339
57314339
Stop Event
node limit
Counts
262 → 247
Calls
Call 1
Inputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
6
(+.f64 (*.f64 -9 x) 6)
(+.f64 (*.f64 -9 x) 6)
(+.f64 (*.f64 -9 x) 6)
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(*.f64 -9 x)
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
(+.f64 6 (*.f64 -9 x))
1/6
(+.f64 1/6 (*.f64 1/4 x))
(+.f64 1/6 (+.f64 (*.f64 3/8 (pow.f64 x 2)) (*.f64 1/4 x)))
(+.f64 1/6 (+.f64 (*.f64 3/8 (pow.f64 x 2)) (+.f64 (*.f64 1/4 x) (*.f64 9/16 (pow.f64 x 3)))))
(/.f64 -1/9 x)
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (*.f64 1/9 (/.f64 1 x))))
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 4/81 (/.f64 1 (pow.f64 x 3))) (*.f64 1/9 (/.f64 1 x)))))
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 8/243 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 4/81 (/.f64 1 (pow.f64 x 3))) (*.f64 1/9 (/.f64 1 x))))))
(/.f64 -1/9 x)
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (*.f64 1/9 (/.f64 1 x))))
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 4/81 (/.f64 1 (pow.f64 x 3))) (*.f64 1/9 (/.f64 1 x)))))
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 8/243 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 4/81 (/.f64 1 (pow.f64 x 3))) (*.f64 1/9 (/.f64 1 x))))))
2
(+.f64 (*.f64 -3 x) 2)
(+.f64 (*.f64 -3 x) 2)
(+.f64 (*.f64 -3 x) 2)
(*.f64 -3 x)
(*.f64 -3 x)
Outputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
6
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 (*.f64 -9 x) 6)
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(*.f64 -9 x)
(*.f64 x -9)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
(+.f64 6 (*.f64 -9 x))
(fma.f64 -9 x 6)
(fma.f64 x -9 6)
1/6
(+.f64 1/6 (*.f64 1/4 x))
(+.f64 1/6 (*.f64 x 1/4))
(fma.f64 x 1/4 1/6)
(+.f64 1/6 (+.f64 (*.f64 3/8 (pow.f64 x 2)) (*.f64 1/4 x)))
(+.f64 1/6 (fma.f64 3/8 (*.f64 x x) (*.f64 x 1/4)))
(+.f64 1/6 (fma.f64 x 1/4 (*.f64 x (*.f64 x 3/8))))
(fma.f64 x 1/4 (fma.f64 x (*.f64 x 3/8) 1/6))
(fma.f64 x (fma.f64 x 3/8 1/4) 1/6)
(+.f64 1/6 (+.f64 (*.f64 3/8 (pow.f64 x 2)) (+.f64 (*.f64 1/4 x) (*.f64 9/16 (pow.f64 x 3)))))
(+.f64 1/6 (fma.f64 3/8 (*.f64 x x) (fma.f64 1/4 x (*.f64 9/16 (pow.f64 x 3)))))
(+.f64 1/6 (fma.f64 (*.f64 x x) 3/8 (fma.f64 x 1/4 (*.f64 9/16 (pow.f64 x 3)))))
(+.f64 1/6 (fma.f64 x 1/4 (*.f64 (*.f64 x x) (+.f64 3/8 (*.f64 x 9/16)))))
(fma.f64 x (*.f64 x (fma.f64 x 9/16 3/8)) (fma.f64 x 1/4 1/6))
(fma.f64 x 1/4 (fma.f64 x (*.f64 x (fma.f64 x 9/16 3/8)) 1/6))
(/.f64 -1/9 x)
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (*.f64 1/9 (/.f64 1 x))))
(neg.f64 (+.f64 (/.f64 2/27 (*.f64 x x)) (/.f64 1/9 x)))
(+.f64 (/.f64 -2/27 (*.f64 x x)) (/.f64 -1/9 x))
(+.f64 (/.f64 (/.f64 -2/27 x) x) (/.f64 -1/9 x))
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 4/81 (/.f64 1 (pow.f64 x 3))) (*.f64 1/9 (/.f64 1 x)))))
(neg.f64 (+.f64 (/.f64 2/27 (*.f64 x x)) (+.f64 (/.f64 1/9 x) (/.f64 4/81 (pow.f64 x 3)))))
(-.f64 (/.f64 -2/27 (*.f64 x x)) (+.f64 (/.f64 1/9 x) (/.f64 4/81 (pow.f64 x 3))))
(+.f64 (+.f64 (/.f64 -2/27 (*.f64 x x)) (/.f64 -1/9 x)) (/.f64 -4/81 (pow.f64 x 3)))
(+.f64 (+.f64 (/.f64 (/.f64 -2/27 x) x) (/.f64 -1/9 x)) (/.f64 -4/81 (pow.f64 x 3)))
(+.f64 (/.f64 -1/9 x) (+.f64 (/.f64 -2/27 (*.f64 x x)) (/.f64 -4/81 (pow.f64 x 3))))
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 8/243 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 4/81 (/.f64 1 (pow.f64 x 3))) (*.f64 1/9 (/.f64 1 x))))))
(neg.f64 (+.f64 (/.f64 2/27 (*.f64 x x)) (+.f64 (+.f64 (/.f64 1/9 x) (/.f64 4/81 (pow.f64 x 3))) (/.f64 8/243 (pow.f64 x 4)))))
(-.f64 (/.f64 -2/27 (*.f64 x x)) (+.f64 (/.f64 4/81 (pow.f64 x 3)) (+.f64 (/.f64 1/9 x) (/.f64 8/243 (pow.f64 x 4)))))
(+.f64 (+.f64 (+.f64 (/.f64 -2/27 (*.f64 x x)) (/.f64 -1/9 x)) (/.f64 -4/81 (pow.f64 x 3))) (/.f64 -8/243 (pow.f64 x 4)))
(-.f64 (-.f64 (+.f64 (/.f64 (/.f64 -2/27 x) x) (/.f64 -1/9 x)) (/.f64 8/243 (pow.f64 x 4))) (/.f64 4/81 (pow.f64 x 3)))
(+.f64 (+.f64 (/.f64 -2/27 (*.f64 x x)) (/.f64 -1/9 x)) (+.f64 (/.f64 -4/81 (pow.f64 x 3)) (/.f64 -8/243 (pow.f64 x 4))))
(/.f64 -1/9 x)
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (*.f64 1/9 (/.f64 1 x))))
(neg.f64 (+.f64 (/.f64 2/27 (*.f64 x x)) (/.f64 1/9 x)))
(+.f64 (/.f64 -2/27 (*.f64 x x)) (/.f64 -1/9 x))
(+.f64 (/.f64 (/.f64 -2/27 x) x) (/.f64 -1/9 x))
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 4/81 (/.f64 1 (pow.f64 x 3))) (*.f64 1/9 (/.f64 1 x)))))
(neg.f64 (+.f64 (/.f64 2/27 (*.f64 x x)) (+.f64 (/.f64 1/9 x) (/.f64 4/81 (pow.f64 x 3)))))
(-.f64 (/.f64 -2/27 (*.f64 x x)) (+.f64 (/.f64 1/9 x) (/.f64 4/81 (pow.f64 x 3))))
(+.f64 (+.f64 (/.f64 -2/27 (*.f64 x x)) (/.f64 -1/9 x)) (/.f64 -4/81 (pow.f64 x 3)))
(+.f64 (+.f64 (/.f64 (/.f64 -2/27 x) x) (/.f64 -1/9 x)) (/.f64 -4/81 (pow.f64 x 3)))
(+.f64 (/.f64 -1/9 x) (+.f64 (/.f64 -2/27 (*.f64 x x)) (/.f64 -4/81 (pow.f64 x 3))))
(neg.f64 (+.f64 (*.f64 2/27 (/.f64 1 (pow.f64 x 2))) (+.f64 (*.f64 8/243 (/.f64 1 (pow.f64 x 4))) (+.f64 (*.f64 4/81 (/.f64 1 (pow.f64 x 3))) (*.f64 1/9 (/.f64 1 x))))))
(neg.f64 (+.f64 (/.f64 2/27 (*.f64 x x)) (+.f64 (+.f64 (/.f64 1/9 x) (/.f64 4/81 (pow.f64 x 3))) (/.f64 8/243 (pow.f64 x 4)))))
(-.f64 (/.f64 -2/27 (*.f64 x x)) (+.f64 (/.f64 4/81 (pow.f64 x 3)) (+.f64 (/.f64 1/9 x) (/.f64 8/243 (pow.f64 x 4)))))
(+.f64 (+.f64 (+.f64 (/.f64 -2/27 (*.f64 x x)) (/.f64 -1/9 x)) (/.f64 -4/81 (pow.f64 x 3))) (/.f64 -8/243 (pow.f64 x 4)))
(-.f64 (-.f64 (+.f64 (/.f64 (/.f64 -2/27 x) x) (/.f64 -1/9 x)) (/.f64 8/243 (pow.f64 x 4))) (/.f64 4/81 (pow.f64 x 3)))
(+.f64 (+.f64 (/.f64 -2/27 (*.f64 x x)) (/.f64 -1/9 x)) (+.f64 (/.f64 -4/81 (pow.f64 x 3)) (/.f64 -8/243 (pow.f64 x 4))))
2
(+.f64 (*.f64 -3 x) 2)
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 (*.f64 -3 x) 2)
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(+.f64 (*.f64 -3 x) 2)
(fma.f64 -3 x 2)
(fma.f64 x -3 2)
(*.f64 -3 x)
(*.f64 x -3)
(*.f64 -3 x)
(*.f64 x -3)

localize21.0ms (0.2%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.3b
(pow.f64 (*.f64 x 6) 3)
36.6b
(cbrt.f64 (pow.f64 (*.f64 x 6) 3))
Compiler

Compiled 18 to 14 computations (22.2% saved)

series43.0ms (0.4%)

Counts
2 → 24
Calls

6 calls:

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

rewrite80.0ms (0.8%)

Algorithm
batch-egg-rewrite
Rules
527×pow1_binary64
520×add-sqr-sqrt_binary64
500×add-log-exp_binary64
500×log1p-expm1-u_binary64
500×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0711
115111
2143111
Stop Event
node limit
Counts
2 → 51
Calls
Call 1
Inputs
(cbrt.f64 (pow.f64 (*.f64 x 6) 3))
(pow.f64 (*.f64 x 6) 3)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x 6)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (pow.f64 216 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 6 x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 6) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x 6)) (pow.f64 (cbrt.f64 (*.f64 x 6)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x 6)) (pow.f64 (*.f64 36 (*.f64 x x)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x 6)) 2) (cbrt.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x 6)) (sqrt.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 36 (*.f64 x x)) 1/3) (cbrt.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 x 6) 3/2) 1/3) (pow.f64 (pow.f64 (*.f64 x 6) 3/2) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 6 (cbrt.f64 (*.f64 x x))) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 6 (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 6) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 216 (pow.f64 x 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x 6)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x 6)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 36 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) 6))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x 6)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 216 (pow.f64 x 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (*.f64 6 (*.f64 36 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 6 (*.f64 x (*.f64 36 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 6) (*.f64 36 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 216 (pow.f64 x 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 216 (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 216 (pow.f64 x 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 36 (*.f64 x x)) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x 6)) 2) (*.f64 (cbrt.f64 (*.f64 x 6)) (*.f64 36 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x 6)) (*.f64 (sqrt.f64 (*.f64 x 6)) (*.f64 36 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 x 3) 216)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x 6) 3/2) (pow.f64 (*.f64 x 6) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 x 6)) 2) 3) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (*.f64 x 6)) 3) (pow.f64 (sqrt.f64 (*.f64 x 6)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 36 (*.f64 x x)) x) 6)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 36 (*.f64 x x)) 6) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 36 (*.f64 x x)) 1) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 36 (*.f64 x x)) (pow.f64 (cbrt.f64 (*.f64 x 6)) 2)) (cbrt.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 36 (*.f64 x x)) (sqrt.f64 (*.f64 x 6))) (sqrt.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x 6) 6))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (pow.f64 x 3)) 216))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 216 (pow.f64 x 3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 216 (pow.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 216 (pow.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 3 (log.f64 (*.f64 x 6))))))))

simplify199.0ms (2%)

Algorithm
egg-herbie
Rules
1274×sqr-pow_binary64
666×pow-sqr_binary64
529×cube-prod_binary64
470×fabs-mul_binary64
443×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
013164
128164
258164
386164
4147164
5379164
61272164
71971164
82090164
92483164
102641164
112884164
123206164
133628164
144129164
154730164
165450164
175769164
186053164
196279164
206457164
216537164
227477164
Stop Event
node limit
Counts
75 → 54
Calls
Call 1
Inputs
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 -1 (*.f64 (cbrt.f64 -216) x))
(*.f64 -1 (*.f64 (cbrt.f64 -216) x))
(*.f64 -1 (*.f64 (cbrt.f64 -216) x))
(*.f64 -1 (*.f64 (cbrt.f64 -216) x))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
Outputs
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 -1 (*.f64 (cbrt.f64 -216) x))
(neg.f64 (*.f64 x (cbrt.f64 -216)))
(*.f64 (cbrt.f64 -216) (neg.f64 x))
(*.f64 x (neg.f64 (cbrt.f64 -216)))
(*.f64 -1 (*.f64 (cbrt.f64 -216) x))
(neg.f64 (*.f64 x (cbrt.f64 -216)))
(*.f64 (cbrt.f64 -216) (neg.f64 x))
(*.f64 x (neg.f64 (cbrt.f64 -216)))
(*.f64 -1 (*.f64 (cbrt.f64 -216) x))
(neg.f64 (*.f64 x (cbrt.f64 -216)))
(*.f64 (cbrt.f64 -216) (neg.f64 x))
(*.f64 x (neg.f64 (cbrt.f64 -216)))
(*.f64 -1 (*.f64 (cbrt.f64 -216) x))
(neg.f64 (*.f64 x (cbrt.f64 -216)))
(*.f64 (cbrt.f64 -216) (neg.f64 x))
(*.f64 x (neg.f64 (cbrt.f64 -216)))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))
(*.f64 216 (pow.f64 x 3))

localize83.0ms (0.8%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 3 (-.f64 2 (*.f64 3 x)))
0.1b
(*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))
0.6b
(cbrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))))
0.7b
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 3)
Compiler

Compiled 50 to 40 computations (20% saved)

series55.0ms (0.5%)

Counts
2 → 0
Calls

6 calls:

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

rewrite128.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
972×pow1_binary64
913×add-log-exp_binary64
912×log1p-expm1-u_binary64
912×expm1-log1p-u_binary64
99×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01028
122528
2252728
Stop Event
node limit
Counts
2 → 71
Calls
Call 1
Inputs
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 3)
(cbrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 6 x) (*.f64 (*.f64 x -3) (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 6 x) (*.f64 (*.f64 x 3) (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 x (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 (+.f64 2 (*.f64 x -3)) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 3) (+.f64 2 (*.f64 x -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 2 (*.f64 x -3)) (*.f64 x 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2) (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (*.f64 x x) 9)) (*.f64 (cbrt.f64 (*.f64 x 3)) (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (*.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))) 2) (*.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))) (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) 2) (*.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) (sqrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x 3)) (*.f64 (sqrt.f64 (*.f64 x 3)) (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1/6) (*.f64 (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1/6) (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) (*.f64 (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))) 2) 3) (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1/6) 3) (pow.f64 (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1/6) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (+.f64 2 (*.f64 x -3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (pow.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) 2)) (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)))) (sqrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 x 3) (pow.f64 (cbrt.f64 (+.f64 2 (*.f64 x -3))) 2)) (cbrt.f64 (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 x 3) (sqrt.f64 (+.f64 2 (*.f64 x -3)))) (sqrt.f64 (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) (cbrt.f64 (*.f64 x x))) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) (sqrt.f64 x)) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2) 1) (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2) (cbrt.f64 x)) (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2) (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))) 2)) (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2) (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1/6)) (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x 3) (-.f64 8 (*.f64 (pow.f64 x 3) 27))) (+.f64 (+.f64 4 (*.f64 (*.f64 x x) 9)) (*.f64 6 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x 3) (-.f64 4 (*.f64 (*.f64 x x) 9))) (+.f64 2 (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (exp.f64 x) 3) (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (*.f64 (pow.f64 x 3) 27) (pow.f64 (+.f64 2 (*.f64 x -3)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3)) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x 3)) (cbrt.f64 (+.f64 2 (*.f64 x -3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))) (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))) (pow.f64 (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))) 2) (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 6 (*.f64 (*.f64 x -3) 3))) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1/6) (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2) 1/3) (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 1/3) (pow.f64 (sqrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))) 1/6) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3)))))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cbrt.f64 (*.f64 x (+.f64 6 (*.f64 (*.f64 x -3) 3))))))))))

simplify14.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

eval595.0ms (5.9%)

Compiler

Compiled 6508 to 5142 computations (21% saved)

prune249.0ms (2.5%)

Pruning

16 alts after pruning (11 fresh and 5 done)

PrunedKeptTotal
New4899498
Fresh628
Picked101
Done257
Total49816514
Error
0b
Counts
514 → 16
Alt Table
Click to see full alt table
StatusErrorProgram
43.8b
(*.f64 (/.f64 (*.f64 x (*.f64 x -27)) (+.f64 2 (*.f64 3 x))) x)
19.6b
(*.f64 x (pow.f64 216 1/3))
18.8b
(/.f64 x (+.f64 1/6 (*.f64 1/4 x)))
43.8b
(*.f64 (*.f64 x -9) x)
19.1b
(/.f64 x 1/6)
19.0b
(*.f64 x 6)
0.3b
(*.f64 (*.f64 x (+.f64 2 (*.f64 x -3))) 3)
43.9b
(*.f64 (*.f64 x (*.f64 x -3)) 3)
0.3b
(*.f64 (+.f64 2 (*.f64 x -3)) (*.f64 x 3))
0.2b
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
43.8b
(/.f64 x (/.f64 -1/9 x))
50.5b
(sqrt.f64 (*.f64 36 (*.f64 x x)))
43.1b
(pow.f64 (sqrt.f64 (*.f64 x 6)) 2)
19.9b
(pow.f64 (cbrt.f64 (*.f64 x 6)) 3)
0.3b
(+.f64 (*.f64 6 x) (*.f64 (*.f64 x 3) (*.f64 x -3)))
0.3b
(*.f64 (/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x))) x)
Compiler

Compiled 224 to 171 computations (23.7% saved)

localize29.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 6 x) (*.f64 (*.f64 x 3) (*.f64 x -3)))
0.3b
(*.f64 (*.f64 x 3) (*.f64 x -3))
Compiler

Compiled 32 to 23 computations (28.1% saved)

series3.0ms (0%)

Counts
2 → 24
Calls

6 calls:

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

rewrite101.0ms (1%)

Algorithm
batch-egg-rewrite
Rules
942×pow1_binary64
882×add-log-exp_binary64
882×log1p-expm1-u_binary64
882×expm1-log1p-u_binary64
107×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01024
121617
2283017
Stop Event
node limit
Counts
2 → 52
Calls
Call 1
Inputs
(*.f64 (*.f64 x 3) (*.f64 x -3))
(+.f64 (*.f64 6 x) (*.f64 (*.f64 x 3) (*.f64 x -3)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (*.f64 -9 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 3) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 -9 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (*.f64 -9 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (*.f64 -9 x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (*.f64 -9 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (*.f64 -9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (*.f64 -9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (*.f64 -9 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 -9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 -9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (*.f64 -9 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (*.f64 36 (*.f64 x x)) (*.f64 x (-.f64 6 (*.f64 -9 x)))) (/.f64 (pow.f64 (*.f64 x (*.f64 -9 x)) 2) (*.f64 x (-.f64 6 (*.f64 -9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (+.f64 (*.f64 -9 x) 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (+.f64 6 (*.f64 -9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x (+.f64 (*.f64 -9 x) 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6))) (cbrt.f64 (pow.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6)) 2)) (cbrt.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6))) (sqrt.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 216 (pow.f64 x 3)) (pow.f64 (*.f64 x (*.f64 -9 x)) 3)) (/.f64 1 (+.f64 (*.f64 36 (*.f64 x x)) (*.f64 (*.f64 x (*.f64 -9 x)) (-.f64 (*.f64 x (*.f64 -9 x)) (*.f64 x 6))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 36 (*.f64 x x)) (pow.f64 (*.f64 x (*.f64 -9 x)) 2)) (/.f64 1 (*.f64 x (-.f64 6 (*.f64 -9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (*.f64 36 (*.f64 x x)) (*.f64 (*.f64 x (*.f64 -9 x)) (-.f64 (*.f64 x (*.f64 -9 x)) (*.f64 x 6)))) (+.f64 (*.f64 216 (pow.f64 x 3)) (pow.f64 (*.f64 x (*.f64 -9 x)) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (*.f64 x (-.f64 6 (*.f64 -9 x))) (-.f64 (*.f64 36 (*.f64 x x)) (pow.f64 (*.f64 x (*.f64 -9 x)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 216 (pow.f64 x 3)) (pow.f64 (*.f64 x (*.f64 -9 x)) 3)) (+.f64 (*.f64 36 (*.f64 x x)) (*.f64 (*.f64 x (*.f64 -9 x)) (-.f64 (*.f64 x (*.f64 -9 x)) (*.f64 x 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 216 (pow.f64 x 3)) (pow.f64 (*.f64 x (*.f64 -9 x)) 3)) (+.f64 (pow.f64 (*.f64 x (*.f64 -9 x)) 2) (-.f64 (*.f64 36 (*.f64 x x)) (*.f64 6 (*.f64 x (*.f64 x (*.f64 -9 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 36 (*.f64 x x)) (pow.f64 (*.f64 x (*.f64 -9 x)) 2)) (*.f64 x (-.f64 6 (*.f64 -9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (*.f64 216 (pow.f64 x 3)) (pow.f64 (*.f64 x (*.f64 -9 x)) 3))) (neg.f64 (+.f64 (*.f64 36 (*.f64 x x)) (*.f64 (*.f64 x (*.f64 -9 x)) (-.f64 (*.f64 x (*.f64 -9 x)) (*.f64 x 6))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (*.f64 36 (*.f64 x x)) (pow.f64 (*.f64 x (*.f64 -9 x)) 2))) (neg.f64 (*.f64 x (-.f64 6 (*.f64 -9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (*.f64 x (*.f64 -9 x)) 2) (*.f64 36 (*.f64 x x))) (-.f64 (*.f64 x (*.f64 -9 x)) (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (+.f64 (*.f64 -9 x) 6))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x 6 (*.f64 x (*.f64 -9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 -9 x) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x 3) (*.f64 x 3) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 6 x (*.f64 x (*.f64 -9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x (*.f64 -9 x)) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x 6) (*.f64 x (*.f64 -9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x 6)) 2) (cbrt.f64 (*.f64 x 6)) (*.f64 x (*.f64 -9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x (*.f64 -9 x))) 2) (cbrt.f64 (*.f64 x (*.f64 -9 x))) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x 6)) (sqrt.f64 (*.f64 x 6)) (*.f64 x (*.f64 -9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (*.f64 x 3)) -3 (*.f64 x 6))))))

simplify194.0ms (1.9%)

Algorithm
egg-herbie
Rules
778×sqr-pow_binary64
555×cube-prod_binary64
551×fabs-mul_binary64
542×associate-*l*_binary64
434×unswap-sqr_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
09201
118201
232192
369174
4168174
5495174
61760174
73006174
83210174
93423174
103643174
113956174
124358174
134869174
145435174
156127174
166964174
177356174
187644174
197922174
207996174
Stop Event
node limit
Counts
76 → 58
Calls
Call 1
Inputs
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
Outputs
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 6 x)
(*.f64 x 6)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 (*.f64 -9 x) 6))
(*.f64 x (fma.f64 -9 x 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 (*.f64 -9 x) 6))
(*.f64 x (fma.f64 -9 x 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 (*.f64 -9 x) 6))
(*.f64 x (fma.f64 -9 x 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 (*.f64 -9 x) 6))
(*.f64 x (fma.f64 -9 x 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 (*.f64 -9 x) 6))
(*.f64 x (fma.f64 -9 x 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 (*.f64 -9 x) 6))
(*.f64 x (fma.f64 -9 x 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 (*.f64 -9 x) 6))
(*.f64 x (fma.f64 -9 x 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 (*.f64 -9 x) 6))
(*.f64 x (fma.f64 -9 x 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 x 6))
(*.f64 x (+.f64 (*.f64 -9 x) 6))
(*.f64 x (fma.f64 -9 x 6))

localize4.0ms (0%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.3b
(/.f64 x 1/6)
Compiler

Compiled 6 to 4 computations (33.3% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
0.0ms
x
@-inf
(/.f64 x 1/6)
0.0ms
x
@0
(/.f64 x 1/6)
0.0ms
x
@inf
(/.f64 x 1/6)

rewrite73.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
397×pow1_binary64
396×add-sqr-sqrt_binary64
380×*-un-lft-identity_binary64
377×add-log-exp_binary64
377×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
044
1884
210234
Stop Event
node limit
Counts
1 → 39
Calls
Call 1
Inputs
(/.f64 x 1/6)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 x) 6)) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 x) 6))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) 6))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) 6))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x 6)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x 6)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (pow.f64 (cbrt.f64 6) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (pow.f64 (sqrt.f64 6) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 6) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x 6)) (pow.f64 (cbrt.f64 (*.f64 x 6)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x 6)) 2) (cbrt.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x 6)) (sqrt.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 x) -6)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 6 x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 6 (pow.f64 (/.f64 1 x) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (*.f64 x 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (*.f64 (pow.f64 x 3) 216)) 1/3) (pow.f64 (sqrt.f64 (*.f64 (pow.f64 x 3) 216)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (*.f64 (*.f64 x x) 36) x) 1/3) (cbrt.f64 6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (*.f64 (*.f64 x x) 36) (pow.f64 (cbrt.f64 (*.f64 x 6)) 2)) 1/3) (cbrt.f64 (cbrt.f64 (*.f64 x 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (*.f64 (*.f64 x x) 36) (sqrt.f64 (*.f64 x 6))) 1/3) (cbrt.f64 (sqrt.f64 (*.f64 x 6))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 6))) 2) 3) (cbrt.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (*.f64 x 6))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (*.f64 x 6))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (/.f64 1/6 x)) 2) -1) (cbrt.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 6) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (*.f64 x x) 36) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 x 3) 216) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x 6)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x 6)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/6 x) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 1/6 x) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 x -1/6))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (*.f64 x x) 36))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) 6))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) 216))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x 6)))))))

simplify62.0ms (0.6%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0448
1548
Stop Event
saturated
Counts
51 → 39
Calls
Call 1
Inputs
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
Outputs
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)
(*.f64 6 x)

localize31.0ms (0.3%)

Local error

Found 2 expressions with local error:

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

Compiled 19 to 13 computations (31.6% saved)

series12.0ms (0.1%)

Counts
2 → 24
Calls

6 calls:

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

rewrite264.0ms (2.6%)

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

Useful iterations: 1 (0.0ms)

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

simplify219.0ms (2.2%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
08168
115168
230168
362168
4160168
5503168
6692168
71106168
81206168
91341168
101513168
111756168
122073168
132443168
142899168
153486168
164192168
175050168
185478168
195792168
206098168
216176168
226212168
Stop Event
node limit
Counts
46 → 26
Calls
Call 1
Inputs
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
(*.f64 -3 (pow.f64 x 2))
Outputs
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 -9 x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))
(*.f64 -3 (pow.f64 x 2))
(*.f64 (*.f64 x x) -3)
(*.f64 x (*.f64 x -3))
(*.f64 -3 (*.f64 x x))

localize42.0ms (0.4%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 2 (*.f64 x -3))
0.2b
(*.f64 (+.f64 2 (*.f64 x -3)) (*.f64 x 3))
Compiler

Compiled 25 to 19 computations (24% saved)

series7.0ms (0.1%)

Counts
1 → 12
Calls

3 calls:

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

rewrite92.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
829×pow1_binary64
776×add-log-exp_binary64
775×log1p-expm1-u_binary64
775×expm1-log1p-u_binary64
764×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0913
119311
2240711
Stop Event
node limit
Counts
1 → 19
Calls
Call 1
Inputs
(*.f64 (+.f64 2 (*.f64 x -3)) (*.f64 x 3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x x) 9) (*.f64 -6 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 -6 x) (*.f64 (*.f64 x x) 9))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (*.f64 3 (fma.f64 x -3 2)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 8 (*.f64 (pow.f64 x 3) -27)) (*.f64 x -3)) (+.f64 4 (-.f64 (*.f64 (*.f64 x x) 9) (*.f64 -6 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 4 (*.f64 (*.f64 x x) 9)) (*.f64 x -3)) (fma.f64 x -3 2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x -3) (+.f64 8 (*.f64 (pow.f64 x 3) -27))) (+.f64 4 (-.f64 (*.f64 (*.f64 x x) 9) (*.f64 -6 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (*.f64 x -3) (-.f64 4 (*.f64 (*.f64 x x) 9))) (fma.f64 x -3 2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 3 (fma.f64 x -3 2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (*.f64 3 (fma.f64 x -3 2))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (fma.f64 x -3 2)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 (fma.f64 x -3 2)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (*.f64 3 (fma.f64 x -3 2))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 (exp.f64 x) -3) (fma.f64 x -3 2)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (*.f64 3 (fma.f64 x -3 2))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 x -3 2) 3) (*.f64 (pow.f64 x 3) -27)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (*.f64 (pow.f64 x 3) -27) (pow.f64 (fma.f64 x -3 2) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 3 (fma.f64 x -3 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 3 (fma.f64 x -3 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (*.f64 3 (fma.f64 x -3 2)))))))))

simplify252.0ms (2.5%)

Algorithm
egg-herbie
Rules
778×sqr-pow_binary64
565×cube-prod_binary64
561×fabs-mul_binary64
529×associate-*l*_binary64
528×pow-sqr_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
09117
118117
232108
36890
416890
548090
6170190
7294490
8314890
9336290
10358290
11389390
12429790
13480690
14537490
15605690
16688990
17728590
18757790
19785590
20793190
21796790
Stop Event
node limit
Counts
31 → 24
Calls
Call 1
Inputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 -9 (pow.f64 x 2))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
Outputs
(*.f64 6 x)
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(*.f64 -9 (pow.f64 x 2))
(*.f64 -9 (*.f64 x x))
(*.f64 x (*.f64 x -9))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(fma.f64 6 x (*.f64 -9 (*.f64 x x)))
(fma.f64 -9 (*.f64 x x) (*.f64 6 x))
(*.f64 x (+.f64 6 (*.f64 x -9)))
(*.f64 x (fma.f64 x -9 6))

localize29.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.2b
(*.f64 x (pow.f64 216 1/3))
1.0b
(pow.f64 216 1/3)
Compiler

Compiled 12 to 10 computations (16.7% saved)

series11.0ms (0.1%)

Counts
2 → 12
Calls

3 calls:

TimeVariablePointExpression
9.0ms
x
@0
(*.f64 x (pow.f64 216 1/3))
1.0ms
x
@inf
(*.f64 x (pow.f64 216 1/3))
1.0ms
x
@-inf
(*.f64 x (pow.f64 216 1/3))

rewrite87.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
498×pow1_binary64
490×add-sqr-sqrt_binary64
470×add-log-exp_binary64
470×log1p-expm1-u_binary64
470×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
069
11289
213059
Stop Event
node limit
Counts
2 → 23
Calls
Call 1
Inputs
(pow.f64 216 1/3)
(*.f64 x (pow.f64 216 1/3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (cbrt.f64 216)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 216) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (cbrt.f64 216))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 216)) (cbrt.f64 (cbrt.f64 46656)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 46656)) (cbrt.f64 (cbrt.f64 216)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 216 1/6) (pow.f64 216 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (cbrt.f64 46656))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (cbrt.f64 216)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 216)))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (cbrt.f64 216)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (cbrt.f64 216)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (cbrt.f64 216)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 (cbrt.f64 216) x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (cbrt.f64 216) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 216 (pow.f64 x 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (cbrt.f64 216) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (cbrt.f64 216) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (*.f64 x x) (cbrt.f64 46656)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (cbrt.f64 216)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 216 (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (cbrt.f64 216) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (cbrt.f64 216) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (cbrt.f64 216) x)))))))

simplify119.0ms (1.2%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0572
1672
Stop Event
saturated
Counts
35 → 24
Calls
Call 1
Inputs
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
Outputs
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)
(*.f64 (cbrt.f64 216) x)

eval106.0ms (1%)

Compiler

Compiled 2307 to 1745 computations (24.4% saved)

prune100.0ms (1%)

Pruning

14 alts after pruning (7 fresh and 7 done)

PrunedKeptTotal
New2054209
Fresh336
Picked011
Done369
Total21114225
Error
0b
Counts
225 → 14
Alt Table
Click to see full alt table
StatusErrorProgram
18.8b
(/.f64 x (+.f64 1/6 (*.f64 1/4 x)))
43.8b
(*.f64 (*.f64 x -9) x)
19.1b
(/.f64 x 1/6)
19.0b
(*.f64 x 6)
0.2b
(+.f64 (*.f64 6 x) (*.f64 -9 (*.f64 x x)))
43.9b
(*.f64 (*.f64 x -3) (*.f64 x 3))
50.5b
(sqrt.f64 (*.f64 (*.f64 x x) 36))
43.8b
(/.f64 x (/.f64 -1/9 x))
19.1b
(pow.f64 (/.f64 1/6 x) -1)
19.9b
(pow.f64 (cbrt.f64 (*.f64 x 6)) 3)
19.6b
(*.f64 x (pow.f64 216 1/3))
0.3b
(*.f64 (*.f64 x (+.f64 2 (*.f64 x -3))) 3)
0.2b
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
0.3b
(*.f64 (/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x))) x)
Compiler

Compiled 108 to 82 computations (24.1% saved)

regimes139.0ms (1.4%)

Counts
40 → 1
Calls
Call 1
Inputs
(/.f64 x 1/6)
(*.f64 x 6)
(/.f64 x (/.f64 -1/9 x))
(*.f64 (*.f64 x -9) x)
(*.f64 (*.f64 x -3) (*.f64 x 3))
(/.f64 x (+.f64 1/6 (*.f64 1/4 x)))
(*.f64 (*.f64 x (*.f64 x -3)) 3)
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
(+.f64 (*.f64 6 x) (*.f64 -9 (*.f64 x x)))
(*.f64 (+.f64 2 (*.f64 x -3)) (*.f64 x 3))
(*.f64 (*.f64 x (+.f64 2 (*.f64 x -3))) 3)
(+.f64 (*.f64 (*.f64 x -9) x) (*.f64 6 x))
(*.f64 (*.f64 3 (-.f64 2 (*.f64 x 3))) x)
(+.f64 (*.f64 6 x) (*.f64 (*.f64 x 3) (*.f64 x -3)))
(+.f64 (*.f64 6 x) (*.f64 (*.f64 x 3) (*.f64 x -3)))
(/.f64 x (/.f64 1 (*.f64 3 (+.f64 2 (*.f64 -3 x)))))
(*.f64 (/.f64 (*.f64 x (*.f64 x -27)) (+.f64 2 (*.f64 3 x))) x)
(*.f64 x (/.f64 (-.f64 (*.f64 (*.f64 x -9) (*.f64 x -9)) 36) (-.f64 (*.f64 x -9) 6)))
(*.f64 (/.f64 (*.f64 (-.f64 4 (*.f64 9 (*.f64 x x))) 3) (+.f64 2 (*.f64 3 x))) x)
(pow.f64 (/.f64 1/6 x) -1)
(*.f64 x (pow.f64 216 1/3))
(*.f64 -9 (pow.f64 x 2))
(sqrt.f64 (*.f64 (*.f64 x x) 36))
(sqrt.f64 (*.f64 36 (*.f64 x x)))
(*.f64 x (fma.f64 x -9 6))
(+.f64 (*.f64 6 x) (*.f64 -9 (pow.f64 x 2)))
(*.f64 (/.f64 (*.f64 (-.f64 8 (*.f64 27 (pow.f64 x 3))) 3) (+.f64 4 (+.f64 (*.f64 9 (*.f64 x x)) (*.f64 6 x)))) x)
(pow.f64 (sqrt.f64 (*.f64 x 6)) 2)
(pow.f64 (cbrt.f64 (*.f64 x 6)) 3)
(pow.f64 (sqrt.f64 (*.f64 x 6)) 2)
(cbrt.f64 (pow.f64 (*.f64 x 6) 3))
(*.f64 (cbrt.f64 (pow.f64 (*.f64 3 (-.f64 2 (*.f64 3 x))) 3)) x)
(*.f64 (pow.f64 (sqrt.f64 (*.f64 3 (-.f64 2 (*.f64 3 x)))) 2) x)
(cbrt.f64 (pow.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x)))) 3))
(pow.f64 (sqrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 2)
(pow.f64 (cbrt.f64 (*.f64 x (*.f64 3 (-.f64 2 (*.f64 3 x))))) 3)
(/.f64 (*.f64 (+.f64 (pow.f64 (*.f64 -9 x) 2) -36) x) (fma.f64 -9 x -6))
(*.f64 (sqrt.f64 (*.f64 x 3)) (*.f64 (sqrt.f64 (*.f64 x 3)) (+.f64 2 (*.f64 x -3))))
(cbrt.f64 (*.f64 (pow.f64 (*.f64 3 (-.f64 2 (*.f64 3 x))) 3) (pow.f64 x 3)))
(*.f64 (*.f64 3 (*.f64 (pow.f64 (cbrt.f64 (-.f64 2 (*.f64 3 x))) 2) (cbrt.f64 (-.f64 2 (*.f64 3 x))))) x)
Outputs
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
Calls

2 calls:

73.0ms
x
42.0ms
(*.f64 (*.f64 3 (-.f64 2 (*.f64 x 3))) x)
Results
ErrorSegmentsBranch
0.2b1x
0.2b1(*.f64 (*.f64 3 (-.f64 2 (*.f64 x 3))) x)
Compiler

Compiled 393 to 299 computations (23.9% saved)

regimes35.0ms (0.3%)

Counts
7 → 3
Calls
Call 1
Inputs
(/.f64 x 1/6)
(*.f64 x 6)
(/.f64 x (/.f64 -1/9 x))
(*.f64 (*.f64 x -9) x)
(*.f64 (*.f64 x -3) (*.f64 x 3))
(/.f64 x (+.f64 1/6 (*.f64 1/4 x)))
(*.f64 (*.f64 x (*.f64 x -3)) 3)
Outputs
(*.f64 (*.f64 x -9) x)
(/.f64 x (+.f64 1/6 (*.f64 1/4 x)))
(/.f64 x (/.f64 -1/9 x))
Calls

1 calls:

29.0ms
x
Results
ErrorSegmentsBranch
1.4b3x
Compiler

Compiled 40 to 27 computations (32.5% saved)

bsearch54.0ms (0.5%)

Algorithm
binary-search
Steps
TimeLeftRight
25.0ms
1.3738252580529614e-6
2015.3503017544597
28.0ms
-2.323917429247241
-0.0003844672967310156
Compiler

Compiled 14 to 11 computations (21.4% saved)

regimes30.0ms (0.3%)

Counts
5 → 3
Calls
Call 1
Inputs
(/.f64 x 1/6)
(*.f64 x 6)
(/.f64 x (/.f64 -1/9 x))
(*.f64 (*.f64 x -9) x)
(*.f64 (*.f64 x -3) (*.f64 x 3))
Outputs
(*.f64 (*.f64 x -9) x)
(*.f64 x 6)
(/.f64 x (/.f64 -1/9 x))
Calls

1 calls:

23.0ms
x
Results
ErrorSegmentsBranch
2.2b3x
Compiler

Compiled 26 to 17 computations (34.6% saved)

bsearch71.0ms (0.7%)

Algorithm
binary-search
Steps
TimeLeftRight
32.0ms
1.3738252580529614e-6
2015.3503017544597
39.0ms
-2.323917429247241
-0.0003844672967310156
Compiler

Compiled 14 to 11 computations (21.4% saved)

regimes79.0ms (0.8%)

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

1 calls:

77.0ms
x
Results
ErrorSegmentsBranch
2.3b3x
Compiler

Compiled 14 to 9 computations (35.7% saved)

bsearch192.0ms (1.9%)

Algorithm
binary-search
Steps
TimeLeftRight
143.0ms
1.3738252580529614e-6
2015.3503017544597
49.0ms
-2.323917429247241
-0.0003844672967310156
Compiler

Compiled 14 to 11 computations (21.4% saved)

regimes13.0ms (0.1%)

Accuracy

Total -0.1b remaining (-0.7%)

Threshold costs -0.1b (-0.7%)

Counts
2 → 1
Calls
Call 1
Inputs
(/.f64 x 1/6)
(*.f64 x 6)
Outputs
(*.f64 x 6)
Calls

1 calls:

12.0ms
x
Results
ErrorSegmentsBranch
19.0b1x
Compiler

Compiled 9 to 6 computations (33.3% saved)

simplify23.0ms (0.2%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
+-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
029114
136114
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
(if (<=.f64 x -2616498417099419/1125899906842624) (*.f64 (*.f64 x -9) x) (if (<=.f64 x 3243853175974523/2361183241434822606848) (/.f64 x (+.f64 1/6 (*.f64 1/4 x))) (/.f64 x (/.f64 -1/9 x))))
(if (<=.f64 x -2616498417099419/1125899906842624) (*.f64 (*.f64 x -9) x) (if (<=.f64 x 3243853175974523/2361183241434822606848) (*.f64 x 6) (/.f64 x (/.f64 -1/9 x))))
(if (<=.f64 x -2616498417099419/1125899906842624) (/.f64 x (/.f64 -1/9 x)) (if (<=.f64 x 3243853175974523/2361183241434822606848) (*.f64 x 6) (/.f64 x (/.f64 -1/9 x))))
(*.f64 x 6)
(/.f64 x 1/6)
Outputs
(*.f64 (+.f64 (*.f64 -9 x) 6) x)
(*.f64 x (+.f64 6 (*.f64 -9 x)))
(if (<=.f64 x -2616498417099419/1125899906842624) (*.f64 (*.f64 x -9) x) (if (<=.f64 x 3243853175974523/2361183241434822606848) (/.f64 x (+.f64 1/6 (*.f64 1/4 x))) (/.f64 x (/.f64 -1/9 x))))
(if (<=.f64 x -2616498417099419/1125899906842624) (*.f64 x (*.f64 -9 x)) (if (<=.f64 x 3243853175974523/2361183241434822606848) (/.f64 x (+.f64 1/6 (*.f64 x 1/4))) (/.f64 x (/.f64 -1/9 x))))
(if (<=.f64 x -2616498417099419/1125899906842624) (*.f64 (*.f64 x -9) x) (if (<=.f64 x 3243853175974523/2361183241434822606848) (*.f64 x 6) (/.f64 x (/.f64 -1/9 x))))
(if (<=.f64 x -2616498417099419/1125899906842624) (*.f64 x (*.f64 -9 x)) (if (<=.f64 x 3243853175974523/2361183241434822606848) (*.f64 x 6) (/.f64 x (/.f64 -1/9 x))))
(if (<=.f64 x -2616498417099419/1125899906842624) (/.f64 x (/.f64 -1/9 x)) (if (<=.f64 x 3243853175974523/2361183241434822606848) (*.f64 x 6) (/.f64 x (/.f64 -1/9 x))))
(*.f64 x 6)
(/.f64 x 1/6)
Compiler

Compiled 86 to 60 computations (30.2% saved)

soundness0.0ms (0%)

end119.0ms (1.2%)

Compiler

Compiled 81 to 55 computations (32.1% saved)

Profiling

Loading profile data...