Details

Time bar (total: 4.6s)

analyze5.0ms (0.1%)

Algorithm
search
Search
TrueOtherFalseIter
0%100%0%0
0%100%0%1
0%100%0%2
50%50%0%3
50%37.5%12.5%4
62.5%18.7%18.8%5
68.7%9.4%21.9%6
71.8%4.7%23.5%7
73.4%2.3%24.3%8
74.2%1.2%24.6%9
74.6%0.6%24.8%10
74.8%0.3%24.9%11
74.9%0.1%25%12
Compiler

Compiled 15 to 12 computations (20% saved)

sample989.0ms (21.4%)

Results
966.0ms8252×body64valid
2.0ms18×body64invalid
1.0msbody128valid

preprocess52.0ms (1.1%)

Algorithm
egg-herbie
Rules
972×fma-def_binary64
722×fma-neg_binary64
154×cancel-sign-sub-inv_binary64
107×distribute-rgt-in_binary64
80×associate-*l*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01119
13314
27612
318212
43779
55429
68699
715359
824469
928279
1029399
1130659
1230719
1330719
011
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
Outputs
0
Call 2
Inputs
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
Outputs
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
(*.f64 3 (+.f64 (fma.f64 (*.f64 3 x) x (neg.f64 (*.f64 x 4))) 1))
(fma.f64 3 (*.f64 x (-.f64 (*.f64 3 x) 4)) 3)
(*.f64 3 (fma.f64 x (fma.f64 3 x -4) 1))
(fma.f64 (*.f64 x x) 9 (fma.f64 x -12 3))
(fma.f64 x (fma.f64 x 9 -12) 3)
Compiler

Compiled 14 to 11 computations (21.4% saved)

simplify94.0ms (2%)

Algorithm
egg-herbie
Rules
972×fma-def_binary64
722×fma-neg_binary64
154×cancel-sign-sub-inv_binary64
107×distribute-rgt-in_binary64
80×associate-*l*_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01119
13314
27612
318212
43779
55429
68699
715359
824469
928279
1029399
1130659
1230719
1330719
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
Outputs
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
(*.f64 3 (+.f64 (fma.f64 (*.f64 3 x) x (neg.f64 (*.f64 x 4))) 1))
(fma.f64 3 (*.f64 x (-.f64 (*.f64 3 x) 4)) 3)
(*.f64 3 (fma.f64 x (fma.f64 3 x -4) 1))
(fma.f64 (*.f64 x x) 9 (fma.f64 x -12 3))
(fma.f64 x (fma.f64 x 9 -12) 3)

prune3.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.0b
Counts
3 → 2
Alt Table
StatusErrorProgram
0.1b
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
0.1b
(fma.f64 x (fma.f64 x 9 -12) 3)
Compiler

Compiled 65 to 50 computations (23.1% saved)

localize4.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 x 9 -12)
0.1b
(fma.f64 x (fma.f64 x 9 -12) 3)

series3.0ms (0.1%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
1.0ms
x
@0
(fma.f64 x (fma.f64 x 9 -12) 3)
1.0ms
x
@-inf
(fma.f64 x (fma.f64 x 9 -12) 3)
0.0ms
x
@inf
(fma.f64 x (fma.f64 x 9 -12) 3)
0.0ms
x
@-inf
(fma.f64 x 9 -12)
0.0ms
x
@inf
(fma.f64 x 9 -12)

rewrite46.0ms (1%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0714
114214
2149514
Stop Event
node limit
Counts
2 → 42
Calls
Call 1
Inputs
(fma.f64 x (fma.f64 x 9 -12) 3)
(fma.f64 x 9 -12)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 3 (*.f64 x (fma.f64 x 9 -12)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (fma.f64 x 9 -12)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x (fma.f64 x 9 -12)) 1) 3)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 x (fma.f64 x 9 -12) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x (fma.f64 x 9 -12) 3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x (fma.f64 x 9 -12) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x (fma.f64 x 9 -12) 3)) (pow.f64 (cbrt.f64 (fma.f64 x (fma.f64 x 9 -12) 3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x (fma.f64 x 9 -12) 3)) 2) (cbrt.f64 (fma.f64 x (fma.f64 x 9 -12) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x (fma.f64 x 9 -12) 3)) (sqrt.f64 (fma.f64 x (fma.f64 x 9 -12) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x (fma.f64 x 9 -12)) 3) 27) (+.f64 (*.f64 (*.f64 x (fma.f64 x 9 -12)) (*.f64 x (fma.f64 x 9 -12))) (-.f64 9 (*.f64 (*.f64 x (fma.f64 x 9 -12)) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 x (fma.f64 x 9 -12)) (*.f64 x (fma.f64 x 9 -12))) 9) (-.f64 (*.f64 x (fma.f64 x 9 -12)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x (fma.f64 x 9 -12) 3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x (fma.f64 x 9 -12) 3) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x (fma.f64 x 9 -12) 3)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x (fma.f64 x 9 -12) 3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x (fma.f64 x 9 -12) 3) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x (fma.f64 x 9 -12) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x (fma.f64 x 9 -12) 3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x (fma.f64 x 9 -12) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x (fma.f64 x 9 -12) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x (fma.f64 x 9 -12) 3)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 -12 (*.f64 x 9))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x 9) -12)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 x 9) 1) -12)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 x 9 -12)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x 9 -12) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x 9 -12))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x 9 -12)) (pow.f64 (cbrt.f64 (fma.f64 x 9 -12)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x 9 -12)) 2) (cbrt.f64 (fma.f64 x 9 -12)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 x 9 -12)) (sqrt.f64 (fma.f64 x 9 -12)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 x 9) 3) -1728) (+.f64 (*.f64 (*.f64 x 9) (*.f64 x 9)) (-.f64 144 (*.f64 (*.f64 x 9) -12))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 x 9) (*.f64 x 9)) 144) (-.f64 (*.f64 x 9) -12))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x 9 -12) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x 9 -12) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x 9 -12)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 x 9 -12)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x 9 -12) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x 9 -12)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x 9 -12) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x 9 -12)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x 9 -12)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x 9 -12)))))))

simplify127.0ms (2.8%)

Algorithm
egg-herbie
Rules
802×sqr-pow_binary64
540×cube-prod_binary64
532×associate-*l*_binary64
528×fabs-mul_binary64
494×fma-def_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
016180
135168
256156
388144
4192144
5531144
61764144
73092144
83297144
93509144
103729144
114037144
124437144
134947144
145507144
156193144
167030144
177422144
187708144
197982144
Stop Event
node limit
Counts
66 → 56
Calls
Call 1
Inputs
3
(+.f64 (*.f64 -12 x) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(*.f64 9 (pow.f64 x 2))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(*.f64 9 (pow.f64 x 2))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
-12
(-.f64 (*.f64 9 x) 12)
(-.f64 (*.f64 9 x) 12)
(-.f64 (*.f64 9 x) 12)
(*.f64 9 x)
(-.f64 (*.f64 9 x) 12)
(-.f64 (*.f64 9 x) 12)
(-.f64 (*.f64 9 x) 12)
(*.f64 9 x)
(-.f64 (*.f64 9 x) 12)
(-.f64 (*.f64 9 x) 12)
(-.f64 (*.f64 9 x) 12)
Outputs
3
(+.f64 (*.f64 -12 x) 3)
(fma.f64 -12 x 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 -12 x (fma.f64 9 (*.f64 x x) 3))
(+.f64 3 (*.f64 x (fma.f64 x 9 -12)))
(fma.f64 x (fma.f64 x 9 -12) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 -12 x (fma.f64 9 (*.f64 x x) 3))
(+.f64 3 (*.f64 x (fma.f64 x 9 -12)))
(fma.f64 x (fma.f64 x 9 -12) 3)
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 x (*.f64 x 9))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(fma.f64 -12 x (*.f64 9 (*.f64 x x)))
(fma.f64 9 (*.f64 x x) (*.f64 -12 x))
(*.f64 x (fma.f64 x 9 -12))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 -12 x (fma.f64 9 (*.f64 x x) 3))
(+.f64 3 (*.f64 x (fma.f64 x 9 -12)))
(fma.f64 x (fma.f64 x 9 -12) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 -12 x (fma.f64 9 (*.f64 x x) 3))
(+.f64 3 (*.f64 x (fma.f64 x 9 -12)))
(fma.f64 x (fma.f64 x 9 -12) 3)
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 x (*.f64 x 9))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(fma.f64 -12 x (*.f64 9 (*.f64 x x)))
(fma.f64 9 (*.f64 x x) (*.f64 -12 x))
(*.f64 x (fma.f64 x 9 -12))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 -12 x (fma.f64 9 (*.f64 x x) 3))
(+.f64 3 (*.f64 x (fma.f64 x 9 -12)))
(fma.f64 x (fma.f64 x 9 -12) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 -12 x (fma.f64 9 (*.f64 x x) 3))
(+.f64 3 (*.f64 x (fma.f64 x 9 -12)))
(fma.f64 x (fma.f64 x 9 -12) 3)
-12
(-.f64 (*.f64 9 x) 12)
(fma.f64 9 x -12)
(fma.f64 x 9 -12)
(-.f64 (*.f64 9 x) 12)
(fma.f64 9 x -12)
(fma.f64 x 9 -12)
(-.f64 (*.f64 9 x) 12)
(fma.f64 9 x -12)
(fma.f64 x 9 -12)
(*.f64 9 x)
(*.f64 x 9)
(-.f64 (*.f64 9 x) 12)
(fma.f64 9 x -12)
(fma.f64 x 9 -12)
(-.f64 (*.f64 9 x) 12)
(fma.f64 9 x -12)
(fma.f64 x 9 -12)
(-.f64 (*.f64 9 x) 12)
(fma.f64 9 x -12)
(fma.f64 x 9 -12)
(*.f64 9 x)
(*.f64 x 9)
(-.f64 (*.f64 9 x) 12)
(fma.f64 9 x -12)
(fma.f64 x 9 -12)
(-.f64 (*.f64 9 x) 12)
(fma.f64 9 x -12)
(fma.f64 x 9 -12)
(-.f64 (*.f64 9 x) 12)
(fma.f64 9 x -12)
(fma.f64 x 9 -12)

prune89.0ms (1.9%)

Pruning

4 alts after pruning (3 fresh and 1 done)

PrunedKeptTotal
New54256
Fresh011
Picked011
Done000
Total54458
Error
0b
Counts
58 → 4
Alt Table
StatusErrorProgram
0.1b
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
0.1b
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
0.8b
(pow.f64 (sqrt.f64 (fma.f64 x (fma.f64 x 9 -12) 3)) 2)
0.1b
(fma.f64 x (fma.f64 x 9 -12) 3)
Compiler

Compiled 673 to 527 computations (21.7% saved)

localize6.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
0.2b
(*.f64 9 (pow.f64 x 2))

series3.0ms (0.1%)

Counts
2 → 6
Calls

6 calls:

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

rewrite62.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
479×log-prod_binary64
408×fma-def_binary64
368×exp-prod_binary64
318×pow-prod-down_binary64
289×pow2_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01121
124719
2306519
Stop Event
node limit
Counts
2 → 107
Calls
Call 1
Inputs
(*.f64 9 (pow.f64 x 2))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
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 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (*.f64 x 9))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (*.f64 x 9)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (*.f64 x 9)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (*.f64 x 9)))))))) (#(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 (pow.f64 (*.f64 x 3) 4) 1/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 x 3) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 x 6) 729) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (*.f64 9 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (*.f64 9 (*.f64 x x)))) 2)) (cbrt.f64 (log.f64 (*.f64 9 (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 9 (*.f64 x x))))) (sqrt.f64 (log.f64 (*.f64 9 (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x 3) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (*.f64 x 9)))))) (#(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 (pow.f64 x 6) 729))))) (#(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 exp.f64 (*.f64 (log.f64 (pow.f64 (cbrt.f64 (*.f64 x 3)) 2)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x 3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (pow.f64 x 6) 729)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 9 (*.f64 x x))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 9 (*.f64 x x))) 3) 1/3))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (*.f64 (*.f64 x x) 144) (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3))) (/.f64 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2) (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) (pow.f64 (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) 2) (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 (*.f64 x 3) (sqrt.f64 (fma.f64 x -12 3))) (hypot.f64 (*.f64 x 3) (sqrt.f64 (fma.f64 x -12 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3)) (/.f64 1 (fma.f64 (fma.f64 9 (*.f64 x x) 3) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)) (*.f64 (*.f64 x x) 144))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 (*.f64 x x) 144) (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2)) (/.f64 1 (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (fma.f64 9 (*.f64 x x) 3) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)) (*.f64 (*.f64 x x) 144)) (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3)) (-.f64 (*.f64 (*.f64 x x) 144) (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3)) (fma.f64 (fma.f64 9 (*.f64 x x) 3) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)) (*.f64 (*.f64 x x) 144)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3)) (+.f64 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2) (-.f64 (*.f64 (*.f64 x x) 144) (*.f64 x (*.f64 -12 (fma.f64 9 (*.f64 x x) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 x x) 144) (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2)) (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3))) (neg.f64 (fma.f64 (fma.f64 9 (*.f64 x x) 3) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)) (*.f64 (*.f64 x x) 144))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (*.f64 (*.f64 x x) 144) (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2))) (neg.f64 (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (fma.f64 x -12 3) 3) (*.f64 (pow.f64 x 6) 729)) (+.f64 (pow.f64 (fma.f64 x -12 3) 2) (-.f64 (pow.f64 (*.f64 x 3) 4) (*.f64 (fma.f64 x -12 3) (*.f64 9 (*.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2) (*.f64 (*.f64 x x) 144)) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (fma.f64 x -12 3) 2) (pow.f64 (*.f64 x 3) 4)) (-.f64 (fma.f64 x -12 3) (*.f64 9 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (hypot.f64 (*.f64 x 3) (sqrt.f64 (fma.f64 x -12 3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 (fma.f64 9 (*.f64 x x) 3) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)) (*.f64 (*.f64 x x) 144)) (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3)) (-.f64 (*.f64 (*.f64 x x) 144) (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))) 2)) (cbrt.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))) (sqrt.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 9 (*.f64 x x)))) (exp.f64 (fma.f64 x -12 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 x -12))) (exp.f64 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 x) -12) (+.f64 1 (expm1.f64 (fma.f64 9 (*.f64 x x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 x -12))) (+.f64 1 (expm1.f64 (fma.f64 9 (*.f64 x x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (fma.f64 9 (*.f64 x x) 3))) (pow.f64 (exp.f64 x) -12)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (fma.f64 9 (*.f64 x x) 3)) (+.f64 1 (expm1.f64 (*.f64 x -12)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (fma.f64 9 (*.f64 x x) 3))) (+.f64 1 (expm1.f64 (*.f64 x -12)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (fma.f64 x -12 3)) (+.f64 1 (expm1.f64 (*.f64 9 (*.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 9 (*.f64 x x) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 x 9) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x x) 9 (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 9 (*.f64 x x)) 1 (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -12 x (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x -12) 1 (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 9 (*.f64 x x) 3) 1 (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 9 (*.f64 x x)) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 x -12 3) (*.f64 9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x -12)) (cbrt.f64 (*.f64 (*.f64 x x) 144)) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 (*.f64 x x) 144)) (cbrt.f64 (*.f64 x -12)) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) -12) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cbrt.f64 x) x) (*.f64 (cbrt.f64 (*.f64 x x)) 9) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x 3)) 2) (cbrt.f64 (pow.f64 (*.f64 x 3) 4)) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (*.f64 x 3) 4)) (pow.f64 (cbrt.f64 (*.f64 x 3)) 2) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (fma.f64 9 (*.f64 x x) 3)) (cbrt.f64 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2)) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2)) (cbrt.f64 (fma.f64 9 (*.f64 x x) 3)) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x -12)) (sqrt.f64 (*.f64 x -12)) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x 3) (*.f64 x 3) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) -12) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (fma.f64 9 (*.f64 x x) 3)) (sqrt.f64 (fma.f64 9 (*.f64 x x) 3)) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 (pow.f64 x 6) 729 27) (/.f64 1 (fma.f64 (*.f64 9 (*.f64 x x)) (fma.f64 9 (*.f64 x x) -3) 9)) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 9 (pow.f64 (*.f64 x 3) 4)) (/.f64 1 (+.f64 3 (*.f64 -9 (*.f64 x x)))) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 x -12 3) 1 (*.f64 9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 x -12 3)) 2) (cbrt.f64 (fma.f64 x -12 3)) (*.f64 9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (fma.f64 x -12 3)) (sqrt.f64 (fma.f64 x -12 3)) (*.f64 9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 -12 (cbrt.f64 (*.f64 x x))) (cbrt.f64 x) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 -12 (sqrt.f64 x)) (sqrt.f64 x) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 9 x) x (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 9 (*.f64 (cbrt.f64 x) x)) (cbrt.f64 (*.f64 x x)) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (hypot.f64 (*.f64 x 3) (sqrt.f64 (fma.f64 x -12 3)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) 1) 1))))))

simplify147.0ms (3.2%)

Algorithm
egg-herbie
Rules
801×sqr-pow_binary64
565×cube-prod_binary64
558×fabs-mul_binary64
545×associate-*l*_binary64
541×pow-sqr_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
01142
12242
23740
37336
417236
547436
6171236
7296636
8317036
9338236
10360236
11390536
12430536
13481536
14537836
15606436
16689936
17729336
18758336
19785736
20792936
21796536
Stop Event
node limit
Counts
113 → 114
Calls
Call 1
Inputs
3
(+.f64 (*.f64 -12 x) 3)
(*.f64 9 (pow.f64 x 2))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(*.f64 9 (pow.f64 x 2))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
Outputs
3
(+.f64 (*.f64 -12 x) 3)
(fma.f64 -12 x 3)
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 x (*.f64 x 9))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(fma.f64 -12 x (*.f64 9 (*.f64 x x)))
(fma.f64 -12 x (*.f64 x (*.f64 x 9)))
(*.f64 x (+.f64 -12 (*.f64 x 9)))
(*.f64 x (fma.f64 x 9 -12))
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(*.f64 x (*.f64 x 9))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(fma.f64 -12 x (*.f64 9 (*.f64 x x)))
(fma.f64 -12 x (*.f64 x (*.f64 x 9)))
(*.f64 x (+.f64 -12 (*.f64 x 9)))
(*.f64 x (fma.f64 x 9 -12))

prune268.0ms (5.8%)

Pruning

4 alts after pruning (2 fresh and 2 done)

PrunedKeptTotal
New1131114
Fresh112
Picked011
Done011
Total1144118
Error
0b
Counts
118 → 4
Alt Table
StatusErrorProgram
0.1b
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
0.1b
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
0.1b
(+.f64 (*.f64 -12 x) (+.f64 3 (pow.f64 (*.f64 x 3) 2)))
0.1b
(fma.f64 x (fma.f64 x 9 -12) 3)
Compiler

Compiled 1930 to 1321 computations (31.6% saved)

localize6.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 -12 x) (+.f64 3 (pow.f64 (*.f64 x 3) 2)))
0.3b
(pow.f64 (*.f64 x 3) 2)

series4.0ms (0.1%)

Counts
2 → 24
Calls

6 calls:

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

rewrite60.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
470×log-prod_binary64
407×fma-def_binary64
354×exp-prod_binary64
317×pow-prod-down_binary64
274×pow2_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01021
123119
2295619
Stop Event
node limit
Counts
2 → 116
Calls
Call 1
Inputs
(pow.f64 (*.f64 x 3) 2)
(+.f64 (*.f64 -12 x) (+.f64 3 (pow.f64 (*.f64 x 3) 2)))
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 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 9) (*.f64 x x))) 2)) (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 *.f64 x (*.f64 3 (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (*.f64 x (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 3) (*.f64 x 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 9 (*.f64 x x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 9 (*.f64 x x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x 3)) 2) (cbrt.f64 (pow.f64 (*.f64 x 3) 4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 x 3) 4)) (pow.f64 (cbrt.f64 (*.f64 x 3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x 3)) (pow.f64 (*.f64 x 3) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x x) 9)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x 3) 3/2) (sqrt.f64 (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 x 3) x) 3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (*.f64 x 3) 3) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x 3)) 5) (cbrt.f64 (*.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x 3) 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 (pow.f64 x 6) 729))))) (#(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 (*.f64 2 (log.f64 (*.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (log.f64 (*.f64 x 3))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (cbrt.f64 (*.f64 x 3)) 2)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (pow.f64 x 6) 729)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 x 3)) 1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (*.f64 2 (log.f64 (*.f64 x 3))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (*.f64 2 (log.f64 (*.f64 x 3))) 3) 1/3))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (*.f64 144 (*.f64 x x)) (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3))) (/.f64 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2) (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) (pow.f64 (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) 2) (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (hypot.f64 (*.f64 x 3) (sqrt.f64 (fma.f64 x -12 3))) (hypot.f64 (*.f64 x 3) (sqrt.f64 (fma.f64 x -12 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3)) (/.f64 1 (fma.f64 (fma.f64 9 (*.f64 x x) 3) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)) (*.f64 144 (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 144 (*.f64 x x)) (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2)) (/.f64 1 (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (fma.f64 9 (*.f64 x x) 3) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)) (*.f64 144 (*.f64 x x))) (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3)) (-.f64 (*.f64 144 (*.f64 x x)) (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3)) (fma.f64 (fma.f64 9 (*.f64 x x) 3) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)) (*.f64 144 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3)) (+.f64 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2) (-.f64 (*.f64 144 (*.f64 x x)) (*.f64 x (*.f64 -12 (fma.f64 9 (*.f64 x x) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 144 (*.f64 x x)) (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2)) (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3))) (neg.f64 (fma.f64 (fma.f64 9 (*.f64 x x) 3) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)) (*.f64 144 (*.f64 x x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (*.f64 144 (*.f64 x x)) (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2))) (neg.f64 (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (fma.f64 x -12 3) 3) (*.f64 (pow.f64 x 6) 729)) (+.f64 (pow.f64 (fma.f64 x -12 3) 2) (-.f64 (pow.f64 (*.f64 x 3) 4) (*.f64 (fma.f64 x -12 3) (*.f64 9 (*.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2) (*.f64 144 (*.f64 x x))) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (fma.f64 x -12 3) 2) (pow.f64 (*.f64 x 3) 4)) (-.f64 (fma.f64 x -12 3) (*.f64 9 (*.f64 x x))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (hypot.f64 (*.f64 x 3) (sqrt.f64 (fma.f64 x -12 3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 (fma.f64 9 (*.f64 x x) 3) (-.f64 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12)) (*.f64 144 (*.f64 x x))) (fma.f64 (pow.f64 x 3) -1728 (pow.f64 (fma.f64 9 (*.f64 x x) 3) 3))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (-.f64 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3)) (-.f64 (*.f64 144 (*.f64 x x)) (pow.f64 (fma.f64 9 (*.f64 x x) 3) 2))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))) 2)) (cbrt.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))) (sqrt.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 9 (*.f64 x x)))) (exp.f64 (fma.f64 x -12 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 x -12))) (exp.f64 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 x) -12) (+.f64 1 (expm1.f64 (fma.f64 9 (*.f64 x x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 x -12))) (+.f64 1 (expm1.f64 (fma.f64 9 (*.f64 x x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (fma.f64 9 (*.f64 x x) 3))) (pow.f64 (exp.f64 x) -12)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (fma.f64 9 (*.f64 x x) 3)) (+.f64 1 (expm1.f64 (*.f64 x -12)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (fma.f64 9 (*.f64 x x) 3))) (+.f64 1 (expm1.f64 (*.f64 x -12)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (fma.f64 x -12 3)) (+.f64 1 (expm1.f64 (*.f64 9 (*.f64 x x))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 3 (*.f64 x 3)) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 3 (*.f64 x (*.f64 x 3)) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x 3) (*.f64 x 3) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 9 (*.f64 x x)) 1 (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -12 x (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x -12) 1 (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 9 (*.f64 x x) 3) 1 (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 9 (*.f64 x x)) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x -12) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 9 (*.f64 x x) 3) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 x -12 3) (*.f64 9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 9 (*.f64 x x) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x -12)) (cbrt.f64 (*.f64 144 (*.f64 x x))) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 144 (*.f64 x x))) (cbrt.f64 (*.f64 x -12)) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 x x)) (*.f64 (cbrt.f64 x) -12) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (fma.f64 9 (*.f64 x x) 3)) (pow.f64 (cbrt.f64 (fma.f64 9 (*.f64 x x) 3)) 2) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 9 (*.f64 x x) 3)) 2) (cbrt.f64 (fma.f64 9 (*.f64 x x) 3)) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x 3)) 2) (cbrt.f64 (pow.f64 (*.f64 x 3) 4)) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 (*.f64 x 3) 4)) (pow.f64 (cbrt.f64 (*.f64 x 3)) 2) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x -12)) (sqrt.f64 (*.f64 x -12)) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 x) (*.f64 (sqrt.f64 x) -12) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (fma.f64 9 (*.f64 x x) 3)) (sqrt.f64 (fma.f64 9 (*.f64 x x) 3)) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 x 3)) (pow.f64 (*.f64 x 3) 3/2) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x x) 9 (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 (pow.f64 x 6) 729 27) (/.f64 1 (fma.f64 (*.f64 9 (*.f64 x x)) (fma.f64 9 (*.f64 x x) -3) 9)) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 9 (pow.f64 (*.f64 x 3) 4)) (/.f64 1 (-.f64 3 (*.f64 9 (*.f64 x x)))) (*.f64 x -12))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 x -12 3) 1 (*.f64 9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 x -12 3)) 2) (cbrt.f64 (fma.f64 x -12 3)) (*.f64 9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (fma.f64 x -12 3)) (sqrt.f64 (fma.f64 x -12 3)) (*.f64 9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (*.f64 x 3) 3/2) (sqrt.f64 (*.f64 x 3)) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 -12 (cbrt.f64 (*.f64 x x))) (cbrt.f64 x) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 -12 (sqrt.f64 x)) (sqrt.f64 x) (fma.f64 9 (*.f64 x x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 x 3) x) 3 (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (*.f64 x 3) 3) x (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 x 3)) 5) (cbrt.f64 (*.f64 x 3)) (fma.f64 x -12 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (hypot.f64 (*.f64 x 3) (sqrt.f64 (fma.f64 x -12 3)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))) 1) 1))))))

simplify123.0ms (2.7%)

Algorithm
egg-herbie
Rules
803×sqr-pow_binary64
550×associate-*l*_binary64
540×cube-prod_binary64
533×fabs-mul_binary64
513×fma-def_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
013210
128198
249196
394174
4206174
5553174
61822174
73154174
83360174
93572174
103792174
114099174
124501174
135011174
145573174
156255174
167092174
177484174
187776174
Stop Event
node limit
Counts
140 → 124
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))
3
(+.f64 (*.f64 -12 x) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(*.f64 9 (pow.f64 x 2))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(*.f64 9 (pow.f64 x 2))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.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))
3
(+.f64 (*.f64 -12 x) 3)
(fma.f64 -12 x 3)
(fma.f64 x -12 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))
(fma.f64 9 (*.f64 x x) (fma.f64 x -12 3))
(fma.f64 x (fma.f64 9 x -12) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))
(fma.f64 9 (*.f64 x x) (fma.f64 x -12 3))
(fma.f64 x (fma.f64 9 x -12) 3)
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(fma.f64 -12 x (*.f64 9 (*.f64 x x)))
(fma.f64 9 (*.f64 x x) (*.f64 x -12))
(*.f64 x (+.f64 (*.f64 9 x) -12))
(*.f64 x (fma.f64 9 x -12))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))
(fma.f64 9 (*.f64 x x) (fma.f64 x -12 3))
(fma.f64 x (fma.f64 9 x -12) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))
(fma.f64 9 (*.f64 x x) (fma.f64 x -12 3))
(fma.f64 x (fma.f64 9 x -12) 3)
(*.f64 9 (pow.f64 x 2))
(*.f64 9 (*.f64 x x))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(fma.f64 -12 x (*.f64 9 (*.f64 x x)))
(fma.f64 9 (*.f64 x x) (*.f64 x -12))
(*.f64 x (+.f64 (*.f64 9 x) -12))
(*.f64 x (fma.f64 9 x -12))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))
(fma.f64 9 (*.f64 x x) (fma.f64 x -12 3))
(fma.f64 x (fma.f64 9 x -12) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 9 (*.f64 x x)))
(fma.f64 x -12 (fma.f64 9 (*.f64 x x) 3))
(fma.f64 9 (*.f64 x x) (fma.f64 x -12 3))
(fma.f64 x (fma.f64 9 x -12) 3)

prune449.0ms (9.7%)

Pruning

4 alts after pruning (1 fresh and 3 done)

PrunedKeptTotal
New1240124
Fresh011
Picked011
Done022
Total1244128
Error
0b
Counts
128 → 4
Alt Table
StatusErrorProgram
0.1b
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
0.1b
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
0.1b
(+.f64 (*.f64 -12 x) (+.f64 3 (pow.f64 (*.f64 x 3) 2)))
0.1b
(fma.f64 x (fma.f64 x 9 -12) 3)
Compiler

Compiled 2053 to 1437 computations (30% saved)

localize7.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4))
0.1b
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
0.2b
(*.f64 (*.f64 x 3) x)

series4.0ms (0.1%)

Counts
3 → 36
Calls

9 calls:

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

rewrite87.0ms (1.9%)

Algorithm
batch-egg-rewrite
Rules
707×fma-def_binary64
571×log-prod_binary64
400×fma-neg_binary64
343×pow-prod-down_binary64
303×pow2_binary64
Iterations

Useful iterations: 2 (0.0ms)

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

simplify154.0ms (3.3%)

Algorithm
egg-herbie
Rules
2020×unswap-sqr_binary64
1104×sqr-pow_binary64
639×fabs-mul_binary64
628×pow-sqr_binary64
611×cube-prod_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
017327
136315
264304
3135264
4316264
5839264
61310264
71776264
81885264
92019264
102188264
112433264
122746264
133118264
143572264
154155264
164863264
175723264
186149264
196463264
206771264
216851264
226887264
Stop Event
node limit
Counts
297 → 276
Calls
Call 1
Inputs
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (pow.f64 x 2))
3
(+.f64 (*.f64 -12 x) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(*.f64 9 (pow.f64 x 2))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(*.f64 9 (pow.f64 x 2))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(*.f64 -4 x)
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(*.f64 3 (pow.f64 x 2))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
Outputs
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
3
(+.f64 (*.f64 -12 x) 3)
(fma.f64 -12 x 3)
(fma.f64 x -12 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 (*.f64 x x) 9))
(fma.f64 x -12 (fma.f64 (*.f64 x x) 9 3))
(fma.f64 x -12 (fma.f64 x (*.f64 x 9) 3))
(fma.f64 x (fma.f64 x 9 -12) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 (*.f64 x x) 9))
(fma.f64 x -12 (fma.f64 (*.f64 x x) 9 3))
(fma.f64 x -12 (fma.f64 x (*.f64 x 9) 3))
(fma.f64 x (fma.f64 x 9 -12) 3)
(*.f64 9 (pow.f64 x 2))
(*.f64 (*.f64 x x) 9)
(*.f64 x (*.f64 x 9))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(fma.f64 -12 x (*.f64 (*.f64 x x) 9))
(fma.f64 x -12 (*.f64 x (*.f64 x 9)))
(*.f64 x (+.f64 -12 (*.f64 x 9)))
(*.f64 x (fma.f64 x 9 -12))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 (*.f64 x x) 9))
(fma.f64 x -12 (fma.f64 (*.f64 x x) 9 3))
(fma.f64 x -12 (fma.f64 x (*.f64 x 9) 3))
(fma.f64 x (fma.f64 x 9 -12) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 (*.f64 x x) 9))
(fma.f64 x -12 (fma.f64 (*.f64 x x) 9 3))
(fma.f64 x -12 (fma.f64 x (*.f64 x 9) 3))
(fma.f64 x (fma.f64 x 9 -12) 3)
(*.f64 9 (pow.f64 x 2))
(*.f64 (*.f64 x x) 9)
(*.f64 x (*.f64 x 9))
(+.f64 (*.f64 -12 x) (*.f64 9 (pow.f64 x 2)))
(fma.f64 -12 x (*.f64 (*.f64 x x) 9))
(fma.f64 x -12 (*.f64 x (*.f64 x 9)))
(*.f64 x (+.f64 -12 (*.f64 x 9)))
(*.f64 x (fma.f64 x 9 -12))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 (*.f64 x x) 9))
(fma.f64 x -12 (fma.f64 (*.f64 x x) 9 3))
(fma.f64 x -12 (fma.f64 x (*.f64 x 9) 3))
(fma.f64 x (fma.f64 x 9 -12) 3)
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(+.f64 (fma.f64 -12 x 3) (*.f64 (*.f64 x x) 9))
(fma.f64 x -12 (fma.f64 (*.f64 x x) 9 3))
(fma.f64 x -12 (fma.f64 x (*.f64 x 9) 3))
(fma.f64 x (fma.f64 x 9 -12) 3)
(*.f64 -4 x)
(*.f64 x -4)
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(fma.f64 3 (*.f64 x x) (*.f64 x -4))
(*.f64 x (+.f64 (*.f64 3 x) -4))
(*.f64 x (fma.f64 3 x -4))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(fma.f64 3 (*.f64 x x) (*.f64 x -4))
(*.f64 x (+.f64 (*.f64 3 x) -4))
(*.f64 x (fma.f64 3 x -4))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(fma.f64 3 (*.f64 x x) (*.f64 x -4))
(*.f64 x (+.f64 (*.f64 3 x) -4))
(*.f64 x (fma.f64 3 x -4))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(fma.f64 3 (*.f64 x x) (*.f64 x -4))
(*.f64 x (+.f64 (*.f64 3 x) -4))
(*.f64 x (fma.f64 3 x -4))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(fma.f64 3 (*.f64 x x) (*.f64 x -4))
(*.f64 x (+.f64 (*.f64 3 x) -4))
(*.f64 x (fma.f64 3 x -4))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(fma.f64 3 (*.f64 x x) (*.f64 x -4))
(*.f64 x (+.f64 (*.f64 3 x) -4))
(*.f64 x (fma.f64 3 x -4))
(*.f64 3 (pow.f64 x 2))
(*.f64 3 (*.f64 x x))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(fma.f64 3 (*.f64 x x) (*.f64 x -4))
(*.f64 x (+.f64 (*.f64 3 x) -4))
(*.f64 x (fma.f64 3 x -4))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(fma.f64 3 (*.f64 x x) (*.f64 x -4))
(*.f64 x (+.f64 (*.f64 3 x) -4))
(*.f64 x (fma.f64 3 x -4))
(+.f64 (*.f64 3 (pow.f64 x 2)) (*.f64 -4 x))
(fma.f64 3 (*.f64 x x) (*.f64 x -4))
(*.f64 x (+.f64 (*.f64 3 x) -4))
(*.f64 x (fma.f64 3 x -4))

prune1.8s (38.5%)

Pruning

4 alts after pruning (0 fresh and 4 done)

PrunedKeptTotal
New2760276
Fresh000
Picked011
Done033
Total2764280
Error
0b
Counts
280 → 4
Alt Table
StatusErrorProgram
0.1b
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
0.1b
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
0.1b
(+.f64 (*.f64 -12 x) (+.f64 3 (pow.f64 (*.f64 x 3) 2)))
0.1b
(fma.f64 x (fma.f64 x 9 -12) 3)
Compiler

Compiled 5880 to 4581 computations (22.1% saved)

regimes28.0ms (0.6%)

Accuracy

Total -0.9b remaining (-1474%)

Threshold costs -0.9b (-1474%)

Counts
5 → 1
Calls
Call 1
Inputs
(+.f64 (*.f64 -12 x) (+.f64 3 (pow.f64 (*.f64 x 3) 2)))
(+.f64 (*.f64 -12 x) (+.f64 3 (*.f64 9 (pow.f64 x 2))))
(pow.f64 (sqrt.f64 (fma.f64 x (fma.f64 x 9 -12) 3)) 2)
(fma.f64 x (fma.f64 x 9 -12) 3)
(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
Outputs
(fma.f64 x (fma.f64 x 9 -12) 3)
Results
4.0ms0.1bx
15.0ms0.1b(*.f64 3 (+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1))
2.0ms0.1b(+.f64 (-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4)) 1)
4.0ms0.1b(-.f64 (*.f64 (*.f64 x 3) x) (*.f64 x 4))
Compiler

Compiled 91 to 70 computations (23.1% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
079
Stop Event
saturated
Calls
Call 1
Inputs
(fma.f64 x (fma.f64 x 9 -12) 3)
Outputs
(fma.f64 x (fma.f64 x 9 -12) 3)

end14.0ms (0.3%)

Stop Event
done
Compiler

Compiled 16 to 12 computations (25% saved)

Profiling

Loading profile data...