Details

Time bar (total: 19.8s)

analyze10.0ms (0%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%49.7%50.3%0%0%0%0
0%0%49.7%50.3%0%0%0%1
0%0%49.7%50.3%0%0%0%2
50%24.8%24.8%50.3%0%0%0%3
75%37.3%12.4%50.3%0%0%0%4
87.5%43.5%6.2%50.3%0%0%0%5
93.8%46.6%3.1%50.3%0%0%0%6
96.9%48.1%1.6%50.3%0%0%0%7
98.4%48.9%0.8%50.3%0%0%0%8
99.2%49.3%0.4%50.3%0%0%0%9
99.6%49.5%0.2%50.3%0%0%0%10
99.8%49.6%0.1%50.3%0%0%0%11
99.9%49.6%0%50.3%0%0%0%12
Compiler

Compiled 16 to 12 computations (25% saved)

sample14.5s (73.5%)

Results
11.9s4099×body2048valid
1.7s2115×body1024valid
425.0ms1031×body512valid
252.0ms224×body4096valid
161.0ms787×body256valid
Bogosity

preprocess23.0ms (0.1%)

Algorithm
egg-herbie
Rules
39×fma-def_binary64
32×fma-neg_binary64
15×cancel-sign-sub-inv_binary64
12×sub-neg_binary64
10×distribute-rgt-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0712
11112
21712
32512
43512
55312
69012
712412
816812
920412
1023012
1123212
011
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
Outputs
0
Call 2
Inputs
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Outputs
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
(+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))
Compiler

Compiled 10 to 8 computations (20% saved)

simplify17.0ms (0.1%)

Algorithm
egg-herbie
Rules
39×fma-def_binary64
32×fma-neg_binary64
15×cancel-sign-sub-inv_binary64
12×sub-neg_binary64
10×distribute-rgt-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0712
11112
21712
32512
43512
55312
69012
712412
816812
920412
1023012
1123212
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Outputs
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
(+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))

eval1.0ms (0%)

Compiler

Compiled 17 to 12 computations (29.4% saved)

prune2.0ms (0%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New112
Fresh011
Picked000
Done000
Total123
Error
60.1b
Counts
3 → 1
Alt Table
Click to see full alt table
StatusErrorProgram
60.1b
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Compiler

Compiled 9 to 7 computations (22.2% saved)

localize19.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(/.f64 1 (tan.f64 x))
3.6b
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Compiler

Compiled 20 to 12 computations (40% saved)

series6.0ms (0%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
2.0ms
x
@inf
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
2.0ms
x
@0
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
1.0ms
x
@-inf
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
0.0ms
x
@inf
(/.f64 1 (tan.f64 x))
0.0ms
x
@-inf
(/.f64 1 (tan.f64 x))

rewrite63.0ms (0.3%)

Algorithm
batch-egg-rewrite
Rules
883×pow1_binary64
823×add-log-exp_binary64
823×log1p-expm1-u_binary64
823×expm1-log1p-u_binary64
805×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0718
116018
2236518
Stop Event
node limit
Counts
2 → 64
Calls
Call 1
Inputs
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
(/.f64 1 (tan.f64 x))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 1 x) (*.f64 (/.f64 -1 (tan.f64 x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))) (fma.f64 (/.f64 -1 (tan.f64 x)) 1 (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 (tan.f64 x)))) (cbrt.f64 (pow.f64 (tan.f64 x) -2)) (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))) (fma.f64 (neg.f64 (pow.f64 (tan.f64 x) -1/2)) (pow.f64 (tan.f64 x) -1/2) (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 -1 (tan.f64 x)) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))) (pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))) 2) (cbrt.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))) (sqrt.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (tan.f64 x) x) (/.f64 (/.f64 1 x) (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 x -3) (pow.f64 (tan.f64 x) -3)) (/.f64 1 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (tan.f64 x) -2) (/.f64 (/.f64 1 x) (tan.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 x -2) (pow.f64 (tan.f64 x) -2)) (/.f64 1 (+.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 x -1/2) (pow.f64 (tan.f64 x) -1/2)) (-.f64 (pow.f64 x -1/2) (pow.f64 (tan.f64 x) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (*.f64 (tan.f64 x) x) (-.f64 (tan.f64 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (tan.f64 x) -2) (/.f64 (/.f64 1 x) (tan.f64 x)))) (-.f64 (pow.f64 x -3) (pow.f64 (tan.f64 x) -3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))) (-.f64 (pow.f64 x -2) (pow.f64 (tan.f64 x) -2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (tan.f64 x) x) (*.f64 (tan.f64 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 x -3) (pow.f64 (tan.f64 x) -3)) (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (tan.f64 x) -2) (/.f64 (/.f64 1 x) (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 x -2) (pow.f64 (tan.f64 x) -2)) (+.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (tan.f64 x) x)) (neg.f64 (*.f64 (tan.f64 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 x -3) (pow.f64 (tan.f64 x) -3))) (neg.f64 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (tan.f64 x) -2) (/.f64 (/.f64 1 x) (tan.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 x -2) (pow.f64 (tan.f64 x) -2))) (neg.f64 (+.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (neg.f64 (tan.f64 x)) (*.f64 (neg.f64 x) 1)) (*.f64 (neg.f64 x) (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (neg.f64 (tan.f64 x)) (*.f64 x -1)) (*.f64 x (neg.f64 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 -1 (neg.f64 (tan.f64 x))) (*.f64 (neg.f64 x) -1)) (*.f64 (neg.f64 x) (neg.f64 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 x -3) (pow.f64 (/.f64 -1 (tan.f64 x)) 3)) (+.f64 (pow.f64 x -2) (-.f64 (*.f64 (/.f64 -1 (tan.f64 x)) (/.f64 -1 (tan.f64 x))) (*.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 x -2) (*.f64 (/.f64 -1 (tan.f64 x)) (/.f64 -1 (tan.f64 x)))) (-.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (-.f64 (tan.f64 x) x) x) (tan.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 x -2)) (/.f64 1 (cbrt.f64 x)) (/.f64 -1 (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 x -1/2) (pow.f64 x -1/2) (/.f64 -1 (tan.f64 x)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (/.f64 1 (tan.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 1 (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (tan.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (tan.f64 x))) (cbrt.f64 (pow.f64 (tan.f64 x) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (tan.f64 x) -2)) (/.f64 1 (cbrt.f64 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (tan.f64 x) -1/2) (pow.f64 (tan.f64 x) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (/.f64 -1 (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (tan.f64 x)) 2) -1) (pow.f64 (cbrt.f64 (tan.f64 x)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (tan.f64 x)) -1) (pow.f64 (sqrt.f64 (tan.f64 x)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sin.f64 x)) (cos.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (tan.f64 x) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (tan.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (cbrt.f64 (tan.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (tan.f64 x) -1/2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (tan.f64 x) -3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (tan.f64 x) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (tan.f64 x) -3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (neg.f64 (log.f64 (tan.f64 x))))))))

simplify83.0ms (0.4%)

Algorithm
egg-herbie
Rules
855×fma-def_binary64
712×distribute-rgt-neg-in_binary64
624×unswap-sqr_binary64
603×distribute-lft-neg-in_binary64
438×associate-*l*_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
039281
196275
2220275
3570275
41053275
52194275
63053275
74079275
84575275
96502275
Stop Event
node limit
Counts
88 → 83
Calls
Call 1
Inputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (*.f64 1/45 (pow.f64 x 3))))
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
(*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(/.f64 1 x)
(+.f64 (*.f64 -1/3 x) (/.f64 1 x))
(+.f64 (*.f64 -1/45 (pow.f64 x 3)) (+.f64 (*.f64 -1/3 x) (/.f64 1 x)))
(+.f64 (*.f64 -2/945 (pow.f64 x 5)) (+.f64 (*.f64 -1/45 (pow.f64 x 3)) (+.f64 (*.f64 -1/3 x) (/.f64 1 x))))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
Outputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (*.f64 1/45 (pow.f64 x 3))))
(fma.f64 1/3 x (fma.f64 2/945 (pow.f64 x 5) (*.f64 1/45 (pow.f64 x 3))))
(fma.f64 1/3 x (fma.f64 1/45 (pow.f64 x 3) (*.f64 2/945 (pow.f64 x 5))))
(fma.f64 2/945 (pow.f64 x 5) (fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x)))
(fma.f64 x (fma.f64 x (*.f64 x 1/45) 1/3) (*.f64 2/945 (pow.f64 x 5)))
(fma.f64 x (fma.f64 1/45 (*.f64 x x) 1/3) (*.f64 2/945 (pow.f64 x 5)))
(fma.f64 2/945 (pow.f64 x 5) (*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3)))
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
(fma.f64 1/3 x (fma.f64 2/945 (pow.f64 x 5) (fma.f64 1/45 (pow.f64 x 3) (*.f64 1/4725 (pow.f64 x 7)))))
(fma.f64 1/3 x (fma.f64 1/45 (pow.f64 x 3) (fma.f64 2/945 (pow.f64 x 5) (*.f64 1/4725 (pow.f64 x 7)))))
(fma.f64 x (fma.f64 x (*.f64 x 1/45) 1/3) (fma.f64 2/945 (pow.f64 x 5) (*.f64 1/4725 (pow.f64 x 7))))
(fma.f64 x (fma.f64 1/45 (*.f64 x x) 1/3) (fma.f64 2/945 (pow.f64 x 5) (*.f64 1/4725 (pow.f64 x 7))))
(*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)))
(neg.f64 (/.f64 (cos.f64 x) (sin.f64 x)))
(/.f64 (neg.f64 (cos.f64 x)) (sin.f64 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)))
(neg.f64 (/.f64 (cos.f64 x) (sin.f64 x)))
(/.f64 (neg.f64 (cos.f64 x)) (sin.f64 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(/.f64 1 x)
(+.f64 (*.f64 -1/3 x) (/.f64 1 x))
(fma.f64 -1/3 x (/.f64 1 x))
(fma.f64 x -1/3 (/.f64 1 x))
(+.f64 (*.f64 -1/45 (pow.f64 x 3)) (+.f64 (*.f64 -1/3 x) (/.f64 1 x)))
(fma.f64 -1/45 (pow.f64 x 3) (fma.f64 -1/3 x (/.f64 1 x)))
(fma.f64 (pow.f64 x 3) -1/45 (fma.f64 x -1/3 (/.f64 1 x)))
(fma.f64 x (fma.f64 x (*.f64 x -1/45) -1/3) (/.f64 1 x))
(fma.f64 x -1/3 (fma.f64 (pow.f64 x 3) -1/45 (/.f64 1 x)))
(fma.f64 x (fma.f64 -1/45 (*.f64 x x) -1/3) (/.f64 1 x))
(+.f64 (*.f64 -2/945 (pow.f64 x 5)) (+.f64 (*.f64 -1/45 (pow.f64 x 3)) (+.f64 (*.f64 -1/3 x) (/.f64 1 x))))
(fma.f64 -2/945 (pow.f64 x 5) (fma.f64 -1/45 (pow.f64 x 3) (fma.f64 -1/3 x (/.f64 1 x))))
(fma.f64 (pow.f64 x 5) -2/945 (fma.f64 (pow.f64 x 3) -1/45 (fma.f64 x -1/3 (/.f64 1 x))))
(fma.f64 (pow.f64 x 3) -1/45 (fma.f64 (pow.f64 x 5) -2/945 (fma.f64 x -1/3 (/.f64 1 x))))
(fma.f64 x -1/3 (fma.f64 (pow.f64 x 3) -1/45 (fma.f64 (pow.f64 x 5) -2/945 (/.f64 1 x))))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))
(/.f64 (cos.f64 x) (sin.f64 x))

eval25.0ms (0.1%)

Compiler

Compiled 1123 to 723 computations (35.6% saved)

prune16.0ms (0.1%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New78583
Fresh000
Picked011
Done000
Total78684
Error
0.3b
Counts
84 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
0.6b
(*.f64 1/3 x)
60.3b
(exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))
60.2b
(-.f64 (/.f64 1 x) (+.f64 (*.f64 -1/3 x) (/.f64 1 x)))
0.4b
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
60.1b
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
0.4b
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
Compiler

Compiled 125 to 97 computations (22.4% saved)

localize63.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(*.f64 1/4725 (pow.f64 x 7))
0.1b
(*.f64 1/45 (pow.f64 x 3))
0.1b
(*.f64 2/945 (pow.f64 x 5))
0.3b
(*.f64 1/3 x)
Compiler

Compiled 85 to 68 computations (20% saved)

series8.0ms (0%)

Counts
4 → 0
Calls

12 calls:

TimeVariablePointExpression
1.0ms
x
@-inf
(*.f64 1/3 x)
1.0ms
x
@0
(*.f64 2/945 (pow.f64 x 5))
1.0ms
x
@0
(*.f64 1/4725 (pow.f64 x 7))
1.0ms
x
@inf
(*.f64 2/945 (pow.f64 x 5))
1.0ms
x
@inf
(*.f64 1/4725 (pow.f64 x 7))

rewrite70.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
622×log-prod_binary64
378×pow2_binary64
307×pow-prod-down_binary64
266×expm1-udef_binary64
266×log1p-udef_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01625
134425
2353825
Stop Event
node limit
Counts
4 → 80
Calls
Call 1
Inputs
(*.f64 1/3 x)
(*.f64 2/945 (pow.f64 x 5))
(*.f64 1/45 (pow.f64 x 3))
(*.f64 1/4725 (pow.f64 x 7))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 1/3 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (exp.f64 x))) 2)) (log.f64 (cbrt.f64 (cbrt.f64 (exp.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (cbrt.f64 (exp.f64 x)))) (log.f64 (sqrt.f64 (cbrt.f64 (exp.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 1/3 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 1/3 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (*.f64 x x) 1/9) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 1/3 x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 1/3 x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 1/3 x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (*.f64 x x) 1/9))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (cbrt.f64 (exp.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 1/3 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 1/3 x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 1/3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 1/3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 1/3 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 1/3 x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (*.f64 1/3 x))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 1/3 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 1/3 x))) 2))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 2/945 (pow.f64 x 5)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 2/945) (pow.f64 x 5))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 2/945) (pow.f64 x 5)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 2/945) (pow.f64 x 5)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 2/945) (pow.f64 x 5)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 2/945 (pow.f64 x 5)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 2/945 (pow.f64 x 5)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 4/893025 (pow.f64 x 10)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 2/945 (pow.f64 x 5)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 2/945 (pow.f64 x 5))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 2/945) (pow.f64 x 5/2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 4/893025 (pow.f64 x 10)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 2/945) (pow.f64 x 5)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 2/945 (pow.f64 x 5)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 2/945 (pow.f64 x 5)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 2/945 (pow.f64 x 5))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 2/945 (pow.f64 x 5))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 2/945 (pow.f64 x 5))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 2/945 (pow.f64 x 5))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (*.f64 2/945 (pow.f64 x 5)))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 2/945 (pow.f64 x 5)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (sqrt.f64 2/945) (pow.f64 x 5/2))) 2))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 1/45 (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 1/45) (pow.f64 x 3))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 1/45) (pow.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 1/45) (pow.f64 x 3)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 1/45) (pow.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 1/45 (pow.f64 x 3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 1/45 (pow.f64 x 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 1/2025 (pow.f64 x 6)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (cbrt.f64 1/45)) 9) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (cbrt.f64 1/45)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 1/45) (pow.f64 x 3/2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 1/2025 (pow.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 1/45) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 1/45 (pow.f64 x 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (cbrt.f64 1/45)) 9))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 1/45 (pow.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 1/45 (pow.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (fma.f64 3 (log.f64 x) (log.f64 1/45)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (fma.f64 3 (log.f64 x) (log.f64 1/45)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (*.f64 x (cbrt.f64 1/45)) 9)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x (cbrt.f64 1/45))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (sqrt.f64 1/45) (pow.f64 x 3/2))) 2))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 1/4725 (pow.f64 x 7)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 1/4725) (pow.f64 x 7))) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 1/4725) (pow.f64 x 7)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 1/4725) (pow.f64 x 7)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 1/4725) (pow.f64 x 7)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 1/4725 (pow.f64 x 7)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 1/4725 (pow.f64 x 7)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 x 14) 1/22325625) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 1/4725 (pow.f64 x 7)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 1/4725 (pow.f64 x 7))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 1/4725) (pow.f64 x 7/2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 x 14) 1/22325625))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 1/4725) (pow.f64 x 7)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 1/4725 (pow.f64 x 7)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 1/4725 (pow.f64 x 7)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 1/4725 (pow.f64 x 7))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 1/4725 (pow.f64 x 7))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (fma.f64 7 (log.f64 x) (log.f64 1/4725)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (fma.f64 7 (log.f64 x) (log.f64 1/4725)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (fma.f64 7 (log.f64 x) (log.f64 1/4725))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 1/4725 (pow.f64 x 7)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (sqrt.f64 1/4725) (pow.f64 x 7/2))) 2))))))

simplify21.0ms (0.1%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

localize3.0ms (0%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.3b
(*.f64 1/3 x)
Compiler

Compiled 6 to 4 computations (33.3% saved)

localize12.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.3b
(*.f64 -1/3 x)
3.6b
(-.f64 (/.f64 1 x) (+.f64 (*.f64 -1/3 x) (/.f64 1 x)))
Compiler

Compiled 28 to 20 computations (28.6% saved)

series2.0ms (0%)

Counts
2 → 12
Calls

6 calls:

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

rewrite103.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
633×unpow-prod-down_binary64
533×fma-def_binary64
404×log-prod_binary64
269×pow-prod-down_binary64
236×pow2_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0818
118318
2269718
Stop Event
node limit
Counts
2 → 152
Calls
Call 1
Inputs
(-.f64 (/.f64 1 x) (+.f64 (*.f64 -1/3 x) (/.f64 1 x)))
(*.f64 -1/3 x)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 1 x) (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 1 x) (*.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 (neg.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) (+.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) (neg.f64 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) (*.f64 -1 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) (*.f64 (neg.f64 (pow.f64 (cbrt.f64 x) -2)) (/.f64 1 (cbrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) (*.f64 (neg.f64 (pow.f64 x -1/2)) (pow.f64 x -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))) 2)) (log.f64 (cbrt.f64 (exp.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))) (log.f64 (sqrt.f64 (exp.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 2) (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 x -3) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 3)) (/.f64 1 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2) (+.f64 -1/3 (pow.f64 x -2))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 x -3) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 3)) (pow.f64 (/.f64 1 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2) (+.f64 -1/3 (pow.f64 x -2))))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 x -2) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2)) (/.f64 1 (+.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 x -2) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2)) (pow.f64 (/.f64 1 (+.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 x -1/2) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (-.f64 (pow.f64 x -1/2) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (+.f64 (pow.f64 x -1/2) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) 1) (pow.f64 (-.f64 (pow.f64 x -1/2) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (pow.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 3)) 1/3) (pow.f64 (sqrt.f64 (pow.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (*.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))) 2) 1/3) (cbrt.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 5/2) 1/3) (cbrt.f64 (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))) 2) 3) (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))) 3) (pow.f64 (sqrt.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2) (+.f64 -1/3 (pow.f64 x -2)))) (-.f64 (pow.f64 x -3) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) (-.f64 (pow.f64 x -2) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 x -3) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 3)) (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2) (+.f64 -1/3 (pow.f64 x -2)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 x -2) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2)) (+.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 x -3) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 3))) (neg.f64 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2) (+.f64 -1/3 (pow.f64 x -2))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 x -2) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2))) (neg.f64 (+.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (-.f64 (fma.f64 1/9 (*.f64 x x) (pow.f64 x -2)) -1/3) (*.f64 x (fma.f64 -1/27 (pow.f64 x 3) (pow.f64 x -3)))) (*.f64 x (-.f64 (fma.f64 1/9 (*.f64 x x) (pow.f64 x -2)) -1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 -1 (-.f64 (fma.f64 1/9 (*.f64 x x) (pow.f64 x -2)) -1/3) (neg.f64 (*.f64 (neg.f64 x) (fma.f64 -1/27 (pow.f64 x 3) (pow.f64 x -3))))) (*.f64 (neg.f64 x) (-.f64 (fma.f64 1/9 (*.f64 x x) (pow.f64 x -2)) -1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (-.f64 (*.f64 x -1/3) (/.f64 1 x)) (*.f64 x (-.f64 (*.f64 1/9 (*.f64 x x)) (pow.f64 x -2)))) (*.f64 x (-.f64 (*.f64 x -1/3) (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 -1 (-.f64 (*.f64 x -1/3) (/.f64 1 x))) (*.f64 (neg.f64 x) (-.f64 (*.f64 1/9 (*.f64 x x)) (pow.f64 x -2)))) (*.f64 (neg.f64 x) (-.f64 (*.f64 x -1/3) (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) 3) (pow.f64 x -3)) (+.f64 (pow.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) 2) (+.f64 (pow.f64 x -2) (*.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 x -3) (pow.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 3)) (+.f64 (pow.f64 x -2) (-.f64 (pow.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (*.f64 (/.f64 1 x) (neg.f64 (fma.f64 x -1/3 (/.f64 1 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) 2) (pow.f64 x -2)) (+.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 x -2) (pow.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2)) (-.f64 (/.f64 1 x) (neg.f64 (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2) (+.f64 -1/3 (pow.f64 x -2)))) (-.f64 (pow.f64 x -3) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 3))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (+.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) (-.f64 (pow.f64 x -2) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (+.f64 1 (expm1.f64 (/.f64 1 x))) (exp.f64 (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (exp.f64 (/.f64 1 x)) (+.f64 1 (expm1.f64 (fma.f64 x -1/3 (/.f64 1 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (+.f64 1 (expm1.f64 (/.f64 1 x))) (+.f64 1 (expm1.f64 (fma.f64 x -1/3 (/.f64 1 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (exp.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (+.f64 1 (expm1.f64 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (/.f64 (exp.f64 (/.f64 1 x)) (pow.f64 (exp.f64 -1/3) x)) (+.f64 1 (expm1.f64 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (/.f64 1 x))) (exp.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (/.f64 1 x))) (/.f64 1 (exp.f64 (fma.f64 x -1/3 (/.f64 1 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (exp.f64 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (exp.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (+.f64 1 (expm1.f64 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (/.f64 1 (exp.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (+.f64 1 (expm1.f64 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 3 (log.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 1 x) (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 1 x) (*.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 (neg.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) (+.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) (neg.f64 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) (*.f64 -1 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) (*.f64 (neg.f64 (pow.f64 (cbrt.f64 x) -2)) (/.f64 1 (cbrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 (/.f64 1 x) (*.f64 1/3 x)) (*.f64 (neg.f64 (pow.f64 x -1/2)) (pow.f64 x -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 x) 1 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 x) 1 (*.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 (neg.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x))) 1 (+.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 2) (fma.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 2) (fma.f64 (neg.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 2) (+.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 2) (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (fma.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 2) (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (fma.f64 (neg.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) 2) (cbrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (+.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (neg.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 (cbrt.f64 x)) (pow.f64 (cbrt.f64 x) -2) (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 (cbrt.f64 x)) (pow.f64 (cbrt.f64 x) -2) (*.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) -2) (/.f64 1 (cbrt.f64 x)) (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 x) -2) (/.f64 1 (cbrt.f64 x)) (*.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (fma.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (fma.f64 (neg.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (sqrt.f64 (-.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (+.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) (neg.f64 (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 x -1/2) (pow.f64 x -1/2) (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 x -1/2) (pow.f64 x -1/2) (*.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -1 (fma.f64 x -1/3 (/.f64 1 x)) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -1 (/.f64 1 (neg.f64 x)) (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -1 (/.f64 1 (neg.f64 x)) (*.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 x -3) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 3)) (/.f64 1 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2) (+.f64 -1/3 (pow.f64 x -2))))) (fma.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 x -3) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 3)) (/.f64 1 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2) (+.f64 -1/3 (pow.f64 x -2))))) (fma.f64 (neg.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 x -3) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 3)) (/.f64 1 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2) (+.f64 -1/3 (pow.f64 x -2))))) (+.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 x -2) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2)) (/.f64 1 (+.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (fma.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 x -2) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2)) (/.f64 1 (+.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (fma.f64 (neg.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 x -2) (pow.f64 (fma.f64 x -1/3 (/.f64 1 x)) 2)) (/.f64 1 (+.f64 (/.f64 1 x) (fma.f64 x -1/3 (/.f64 1 x)))) (+.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x)))) 2) (cbrt.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) 2) (cbrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (neg.f64 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) 2) (cbrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (*.f64 -1 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) 2) (cbrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (*.f64 (neg.f64 (pow.f64 (cbrt.f64 x) -2)) (/.f64 1 (cbrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) 2) (cbrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (*.f64 (neg.f64 (pow.f64 x -1/2)) (pow.f64 x -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (sqrt.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (sqrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (neg.f64 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (sqrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (*.f64 -1 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (sqrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (*.f64 (neg.f64 (pow.f64 (cbrt.f64 x) -2)) (/.f64 1 (cbrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (sqrt.f64 (+.f64 (/.f64 1 x) (*.f64 1/3 x))) (*.f64 (neg.f64 (pow.f64 x -1/2)) (pow.f64 x -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 x -1/2) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (-.f64 (pow.f64 x -1/2) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (fma.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) 1 (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 x -1/2) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (-.f64 (pow.f64 x -1/2) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (fma.f64 (neg.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 x -1/2) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (-.f64 (pow.f64 x -1/2) (sqrt.f64 (fma.f64 x -1/3 (/.f64 1 x)))) (+.f64 (neg.f64 (fma.f64 x -1/3 (/.f64 1 x))) (fma.f64 x -1/3 (/.f64 1 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 x -1/2) (sqrt.f64 (*.f64 x -1/3))) (-.f64 (pow.f64 x -1/2) (sqrt.f64 (*.f64 x -1/3))) (neg.f64 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 x -1/2) (sqrt.f64 (*.f64 x -1/3))) (-.f64 (pow.f64 x -1/2) (sqrt.f64 (*.f64 x -1/3))) (*.f64 -1 (/.f64 1 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 x -1/2) (sqrt.f64 (*.f64 x -1/3))) (-.f64 (pow.f64 x -1/2) (sqrt.f64 (*.f64 x -1/3))) (*.f64 (neg.f64 (pow.f64 (cbrt.f64 x) -2)) (/.f64 1 (cbrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (pow.f64 x -1/2) (sqrt.f64 (*.f64 x -1/3))) (-.f64 (pow.f64 x -1/2) (sqrt.f64 (*.f64 x -1/3))) (*.f64 (neg.f64 (pow.f64 x -1/2)) (pow.f64 x -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 (pow.f64 (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) 2)) (cbrt.f64 (fma.f64 x -1/3 (/.f64 1 x))) (/.f64 1 x))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x -1/3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (pow.f64 (exp.f64 -1/3) x)) 2)) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 -1/3) x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 -1/3) x))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 -1/3) x))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x -1/3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x -1/3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 1/9 (*.f64 x x)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x -1/3)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x -1/3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 -1/27 (pow.f64 x 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 1/9 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 -1/3) x))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x -1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 -1/27 (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x -1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x -1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x -1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x -1/3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 x -1/3))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 x -1/3))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 -1/27 (pow.f64 x 3))) 1/3))))))

simplify9.0ms (0%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0448
1548
Stop Event
saturated
Counts
164 → 153
Calls
Call 1
Inputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
Outputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)

localize8.0ms (0%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 1/45 (*.f64 x x) 1/3)
0.4b
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
Compiler

Compiled 21 to 11 computations (47.6% saved)

series6.0ms (0%)

Counts
2 → 24
Calls

6 calls:

TimeVariablePointExpression
4.0ms
x
@inf
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
1.0ms
x
@0
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
0.0ms
x
@-inf
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
0.0ms
x
@0
(fma.f64 1/45 (*.f64 x x) 1/3)
0.0ms
x
@-inf
(fma.f64 1/45 (*.f64 x x) 1/3)

rewrite67.0ms (0.3%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
0719
114219
2157119
Stop Event
node limit
Counts
2 → 34
Calls
Call 1
Inputs
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(fma.f64 1/45 (*.f64 x x) 1/3)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 1/45 (*.f64 x x)) x) (*.f64 1/3 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 1/45 (*.f64 x x))) (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (fma.f64 1/45 (*.f64 x x) 1/3)) x))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 1/3 (*.f64 1/45 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 1/45 (*.f64 x x)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 1/45 (*.f64 x x)) 1) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 1/45 (*.f64 x x) 1/3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 1/45 (*.f64 x x) 1/3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 1/45 (*.f64 x x) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 1/45 (*.f64 x x) 1/3)) (pow.f64 (cbrt.f64 (fma.f64 1/45 (*.f64 x x) 1/3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 1/45 (*.f64 x x) 1/3)) 2) (cbrt.f64 (fma.f64 1/45 (*.f64 x x) 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 1/45 (*.f64 x x) 1/3)) (sqrt.f64 (fma.f64 1/45 (*.f64 x x) 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 1/45 (*.f64 x x)) 3) 1/27) (+.f64 (*.f64 (*.f64 1/45 (*.f64 x x)) (*.f64 1/45 (*.f64 x x))) (-.f64 1/9 (*.f64 (*.f64 1/45 (*.f64 x x)) 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 1/45 (*.f64 x x)) (*.f64 1/45 (*.f64 x x))) 1/9) (-.f64 (*.f64 1/45 (*.f64 x x)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 1/45 (*.f64 x x) 1/3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 1/45 (*.f64 x x) 1/3) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 1/45 (*.f64 x x) 1/3)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 1/45 (*.f64 x x) 1/3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 1/45 (*.f64 x x) 1/3) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 1/45 (*.f64 x x) 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 1/45 (*.f64 x x) 1/3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 1/45 (*.f64 x x) 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 1/45 (*.f64 x x) 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 1/45 (*.f64 x x) 1/3)))))))

simplify173.0ms (0.9%)

Algorithm
egg-herbie
Rules
944×sqr-pow_binary64
564×cube-prod_binary64
536×unswap-sqr_binary64
534×fabs-mul_binary64
502×pow-sqr_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
013222
131204
261204
3134204
4336204
51386204
62757204
72943204
83194204
93481204
103860204
114370204
124977204
135689204
146160204
156481204
166753204
176921204
187013204
197690204
Stop Event
node limit
Counts
58 → 43
Calls
Call 1
Inputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
1/3
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(*.f64 1/45 (pow.f64 x 2))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(*.f64 1/45 (pow.f64 x 2))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
Outputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
1/3
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)

localize17.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(/.f64 1 (tan.f64 x))
0.1b
(exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))
3.6b
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Compiler

Compiled 39 to 25 computations (35.9% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
0.0ms
x
@0
(exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))
0.0ms
x
@-inf
(exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))
0.0ms
x
@inf
(exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))

rewrite101.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
952×pow1_binary64
885×add-log-exp_binary64
885×log1p-expm1-u_binary64
885×expm1-log1p-u_binary64
92×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0912
118412
2254912
Stop Event
node limit
Counts
1 → 51
Calls
Call 1
Inputs
(exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 1 x) (*.f64 (/.f64 -1 (tan.f64 x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))) (fma.f64 (/.f64 -1 (tan.f64 x)) 1 (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 (tan.f64 x)))) (cbrt.f64 (pow.f64 (tan.f64 x) -2)) (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))) (fma.f64 (neg.f64 (pow.f64 (tan.f64 x) -1/2)) (pow.f64 (tan.f64 x) -1/2) (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 -1 (tan.f64 x)) (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (tan.f64 x) (*.f64 (tan.f64 x) x)) (/.f64 x (*.f64 (tan.f64 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 x -3) (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (tan.f64 x) -2) (/.f64 (/.f64 1 x) (tan.f64 x))))) (/.f64 (pow.f64 (tan.f64 x) -3) (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (tan.f64 x) -2) (/.f64 (/.f64 1 x) (tan.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (pow.f64 x -2) (+.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))) (/.f64 (pow.f64 (tan.f64 x) -2) (+.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))) (pow.f64 (cbrt.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))) 2) (cbrt.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))) (sqrt.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (tan.f64 x) x) (/.f64 (/.f64 1 x) (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 x -3) (pow.f64 (tan.f64 x) -3)) (/.f64 1 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (tan.f64 x) -2) (/.f64 (/.f64 1 x) (tan.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 x -2) (pow.f64 (tan.f64 x) -2)) (/.f64 1 (+.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (pow.f64 x -1/2) (pow.f64 (tan.f64 x) -1/2)) (-.f64 (pow.f64 x -1/2) (pow.f64 (tan.f64 x) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (*.f64 (tan.f64 x) x) (-.f64 (tan.f64 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (tan.f64 x) -2) (/.f64 (/.f64 1 x) (tan.f64 x)))) (-.f64 (pow.f64 x -3) (pow.f64 (tan.f64 x) -3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))) (-.f64 (pow.f64 x -2) (pow.f64 (tan.f64 x) -2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (tan.f64 x) x) (*.f64 (tan.f64 x) x))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 x -3) (pow.f64 (tan.f64 x) -3)) (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (tan.f64 x) -2) (/.f64 (/.f64 1 x) (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 x -2) (pow.f64 (tan.f64 x) -2)) (+.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (tan.f64 x) x)) (neg.f64 (*.f64 (tan.f64 x) x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 x -3) (pow.f64 (tan.f64 x) -3))) (neg.f64 (+.f64 (pow.f64 x -2) (+.f64 (pow.f64 (tan.f64 x) -2) (/.f64 (/.f64 1 x) (tan.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 x -2) (pow.f64 (tan.f64 x) -2))) (neg.f64 (+.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (neg.f64 (tan.f64 x)) (*.f64 (neg.f64 x) 1)) (*.f64 (neg.f64 x) (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (neg.f64 (tan.f64 x)) (*.f64 x -1)) (*.f64 x (neg.f64 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 -1 (neg.f64 (tan.f64 x))) (*.f64 (neg.f64 x) -1)) (*.f64 (neg.f64 x) (neg.f64 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 x -3) (pow.f64 (/.f64 -1 (tan.f64 x)) 3)) (+.f64 (pow.f64 x -2) (-.f64 (*.f64 (/.f64 -1 (tan.f64 x)) (/.f64 -1 (tan.f64 x))) (*.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 x -2) (*.f64 (/.f64 -1 (tan.f64 x)) (/.f64 -1 (tan.f64 x)))) (-.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (/.f64 (-.f64 (tan.f64 x) x) x) (tan.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))))) 2)) (cbrt.f64 (log.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))) (sqrt.f64 (log.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 1 x) (/.f64 -1 (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (pow.f64 x -2)) (cbrt.f64 (/.f64 1 x)) (/.f64 -1 (tan.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 x -1/2) (pow.f64 x -1/2) (/.f64 -1 (tan.f64 x)))))))

simplify162.0ms (0.8%)

Algorithm
egg-herbie
Rules
675×sqr-pow_binary64
624×unswap-sqr_binary64
594×cube-prod_binary64
554×fma-def_binary64
417×fabs-mul_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
030168
174162
2153162
3367162
4677162
51437162
62099162
73090162
83307162
93633162
104034162
114566162
125297162
136300162
146946162
157455162
167858162
Stop Event
node limit
Counts
63 → 62
Calls
Call 1
Inputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (*.f64 1/45 (pow.f64 x 3))))
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
(*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
Outputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (*.f64 1/45 (pow.f64 x 3))))
(fma.f64 1/3 x (fma.f64 2/945 (pow.f64 x 5) (*.f64 1/45 (pow.f64 x 3))))
(fma.f64 1/3 x (fma.f64 1/45 (pow.f64 x 3) (*.f64 2/945 (pow.f64 x 5))))
(fma.f64 x (fma.f64 x (*.f64 x 1/45) 1/3) (*.f64 2/945 (pow.f64 x 5)))
(fma.f64 x (fma.f64 1/45 (*.f64 x x) 1/3) (*.f64 2/945 (pow.f64 x 5)))
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
(fma.f64 1/3 x (fma.f64 2/945 (pow.f64 x 5) (fma.f64 1/45 (pow.f64 x 3) (*.f64 1/4725 (pow.f64 x 7)))))
(fma.f64 1/45 (pow.f64 x 3) (fma.f64 2/945 (pow.f64 x 5) (fma.f64 1/3 x (*.f64 1/4725 (pow.f64 x 7)))))
(fma.f64 1/3 x (fma.f64 1/45 (pow.f64 x 3) (fma.f64 2/945 (pow.f64 x 5) (*.f64 1/4725 (pow.f64 x 7)))))
(fma.f64 2/945 (pow.f64 x 5) (fma.f64 1/4725 (pow.f64 x 7) (*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))))
(*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)))
(neg.f64 (/.f64 (cos.f64 x) (sin.f64 x)))
(/.f64 (neg.f64 (cos.f64 x)) (sin.f64 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)))
(neg.f64 (/.f64 (cos.f64 x) (sin.f64 x)))
(/.f64 (neg.f64 (cos.f64 x)) (sin.f64 x))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))
(+.f64 (*.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x))) (/.f64 1 x))
(fma.f64 -1 (/.f64 (cos.f64 x) (sin.f64 x)) (/.f64 1 x))
(-.f64 (/.f64 1 x) (/.f64 (cos.f64 x) (sin.f64 x)))

eval366.0ms (1.8%)

Compiler

Compiled 8323 to 6134 computations (26.3% saved)

prune110.0ms (0.6%)

Pruning

11 alts after pruning (7 fresh and 4 done)

PrunedKeptTotal
New4347441
Fresh000
Picked011
Done235
Total43611447
Error
0.2b
Counts
447 → 11
Alt Table
Click to see full alt table
StatusErrorProgram
1.8b
(pow.f64 (cbrt.f64 (*.f64 1/3 x)) 3)
0.6b
(*.f64 1/3 x)
33.5b
(pow.f64 (sqrt.f64 (*.f64 1/3 x)) 2)
60.3b
(exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))
36.0b
(exp.f64 (log.f64 (*.f64 1/3 x)))
0.4b
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
46.9b
(sqrt.f64 (*.f64 (*.f64 x x) 1/9))
38.0b
(cbrt.f64 (pow.f64 (*.f64 1/3 x) 3))
0.4b
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
60.1b
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
35.9b
(+.f64 (exp.f64 (log.f64 (*.f64 1/3 x))) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
Compiler

Compiled 182 to 147 computations (19.2% saved)

localize22.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 1/45 (*.f64 x x)) 1/3)
0.1b
(*.f64 1/45 (*.f64 x x))
0.4b
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
Compiler

Compiled 28 to 15 computations (46.4% saved)

series3.0ms (0%)

Counts
3 → 36
Calls

9 calls:

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

rewrite70.0ms (0.4%)

Algorithm
batch-egg-rewrite
Rules
894×pow1_binary64
840×add-log-exp_binary64
840×log1p-expm1-u_binary64
840×expm1-log1p-u_binary64
824×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0826
118126
2233026
Stop Event
node limit
Counts
3 → 68
Calls
Call 1
Inputs
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
(*.f64 1/45 (*.f64 x x))
(+.f64 (*.f64 1/45 (*.f64 x x)) 1/3)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x 1/3) (*.f64 1/45 (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 1/45 (pow.f64 x 3)) 1) (*.f64 (*.f64 x 1/3) 1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (fma.f64 (*.f64 x 1/45) x 1/3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 1/45 (pow.f64 x 3)) 3) (pow.f64 (*.f64 x 1/3) 3)) (+.f64 (*.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/45 (pow.f64 x 3))) (-.f64 (*.f64 (*.f64 x 1/3) (*.f64 x 1/3)) (*.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/45 (pow.f64 x 3))) (*.f64 (*.f64 x 1/3) (*.f64 x 1/3))) (-.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) -1/9) x) (fma.f64 1/45 (*.f64 x x) -1/3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3))) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 (*.f64 1/2025 (pow.f64 x 4)) -1/9)) (fma.f64 1/45 (*.f64 x x) -1/3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (fma.f64 (*.f64 x 1/45) x 1/3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (fma.f64 (*.f64 x 1/45) x 1/3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (fma.f64 (*.f64 x 1/45) x 1/3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (fma.f64 (*.f64 x 1/45) x 1/3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (fma.f64 (*.f64 x 1/45) x 1/3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (fma.f64 (*.f64 x 1/45) x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (fma.f64 (*.f64 x 1/45) x 1/3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (fma.f64 (*.f64 x 1/45) x 1/3) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 (*.f64 x 1/45) x 1/3) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (fma.f64 (*.f64 x 1/45) x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (fma.f64 (*.f64 x 1/45) x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (fma.f64 (*.f64 x 1/45) x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 x (*.f64 x 1/45)) (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (*.f64 x 1/45)) x (*.f64 x 1/3))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x (*.f64 x 1/45))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 x 1/45)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (*.f64 x 1/45))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (sqrt.f64 1/45)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 1/2025 (pow.f64 x 4)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 1/45) (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 x 1/45))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 x 1/45))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (*.f64 x 1/45))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (fma.f64 (*.f64 x 1/45) x 1/3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (*.f64 1/2025 (pow.f64 x 4)) (fma.f64 1/45 (*.f64 x x) -1/3)) (/.f64 1/9 (fma.f64 1/45 (*.f64 x x) -1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (*.f64 x 1/45) x 1/3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 (*.f64 x 1/45) x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 (*.f64 x 1/45) x 1/3)) (pow.f64 (cbrt.f64 (fma.f64 (*.f64 x 1/45) x 1/3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 (*.f64 x 1/45) x 1/3)) 2) (cbrt.f64 (fma.f64 (*.f64 x 1/45) x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 (*.f64 x 1/45) x 1/3)) (sqrt.f64 (fma.f64 (*.f64 x 1/45) x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) (/.f64 1 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) -1/9) (/.f64 1 (fma.f64 1/45 (*.f64 x x) -1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))) (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 1/45 (*.f64 x x) -1/3) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) -1/9)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) (+.f64 1/9 (-.f64 (*.f64 1/2025 (pow.f64 x 4)) (*.f64 (*.f64 x x) 1/135))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) -1/9) (fma.f64 1/45 (*.f64 x x) -1/3))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3))) (neg.f64 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) -1/9)) (neg.f64 (fma.f64 1/45 (*.f64 x x) -1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1/9 (*.f64 1/2025 (pow.f64 x 4))) (-.f64 1/3 (*.f64 x (*.f64 x 1/45))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 (*.f64 x 1/45) x 1/3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 (*.f64 x 1/45) x 1/3) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 (*.f64 x 1/45) x 1/3)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 (*.f64 x 1/45) x 1/3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 (*.f64 x 1/45) x 1/3) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 (*.f64 x 1/45) x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 (*.f64 x 1/45) x 1/3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 (*.f64 x 1/45) x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 (*.f64 x 1/45) x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 (*.f64 x 1/45) x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1/45 (*.f64 x x) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x x) 1/45 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 x (*.f64 x 1/45)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 1/2025 (pow.f64 x 4))) (cbrt.f64 (*.f64 x (*.f64 x 1/45))) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x (sqrt.f64 1/45)) (*.f64 x (sqrt.f64 1/45)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 x 1/45) x 1/3)))))

simplify217.0ms (1.1%)

Algorithm
egg-herbie
Rules
944×sqr-pow_binary64
564×cube-prod_binary64
536×unswap-sqr_binary64
534×fabs-mul_binary64
502×pow-sqr_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
013306
131288
261288
3134288
4336288
51386288
62757288
72943288
83194288
93481288
103860288
114370288
124977288
135689288
146160288
156481288
166753288
176921288
187013288
197690288
Stop Event
node limit
Counts
104 → 77
Calls
Call 1
Inputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (pow.f64 x 2))
1/3
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(*.f64 1/45 (pow.f64 x 2))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(*.f64 1/45 (pow.f64 x 2))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
Outputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
1/3
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(*.f64 1/45 (pow.f64 x 2))
(*.f64 1/45 (*.f64 x x))
(*.f64 x (*.f64 x 1/45))
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)
(+.f64 1/3 (*.f64 1/45 (pow.f64 x 2)))
(+.f64 1/3 (*.f64 1/45 (*.f64 x x)))
(fma.f64 1/45 (*.f64 x x) 1/3)
(fma.f64 x (*.f64 x 1/45) 1/3)

localize50.0ms (0.3%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (*.f64 x x) 1/9)
27.7b
(sqrt.f64 (*.f64 (*.f64 x x) 1/9))
Compiler

Compiled 17 to 8 computations (52.9% saved)

series4.0ms (0%)

Counts
2 → 24
Calls

6 calls:

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

rewrite93.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
508×pow1_binary64
492×add-sqr-sqrt_binary64
475×add-log-exp_binary64
475×log1p-expm1-u_binary64
475×expm1-log1p-u_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0616
112411
2139611
Stop Event
node limit
Counts
2 → 38
Calls
Call 1
Inputs
(sqrt.f64 (*.f64 (*.f64 x x) 1/9))
(*.f64 (*.f64 x x) 1/9)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x 1/3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (pow.f64 1/9 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x 1/3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x 1/3)) (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2) (cbrt.f64 (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x 1/3)) (sqrt.f64 (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (sqrt.f64 (*.f64 x 1/9)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (pow.f64 (*.f64 x 1/9) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/3 x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cbrt.f64 (*.f64 (pow.f64 x 4) 1/81))) (sqrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1/9 1/2) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 (pow.f64 x 4) 1/81)) 1/2) (pow.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (*.f64 x x) 1/9) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 1/3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x 1/3) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x 1/3)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x 1/3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x 1/3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x 1/3)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 (*.f64 x x) 1/9)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (*.f64 x x) 1/9) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 1/3) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 x 4) 1/81) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (*.f64 x x) 1/9) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2) 3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 x 4) 1/81))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (*.f64 x 1/9)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (*.f64 x x) 1/9) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (*.f64 x x) 1/9)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (*.f64 x x) 1/9)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (*.f64 x x) 1/9)))))))

simplify229.0ms (1.2%)

Algorithm
egg-herbie
Rules
1101×sqr-pow_binary64
582×associate-*l*_binary64
565×cube-prod_binary64
557×fabs-mul_binary64
528×pow-sqr_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
010132
118132
229132
358132
4138132
5442132
61604132
72497132
82661132
92874132
103094132
113397132
123799132
134292132
144860132
155550132
166383132
176773132
187057132
197333132
207409132
217443132
Stop Event
node limit
Counts
62 → 42
Calls
Call 1
Inputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 -1/3 x)
(*.f64 -1/3 x)
(*.f64 -1/3 x)
(*.f64 -1/3 x)
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
Outputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 -1/3 x)
(*.f64 x -1/3)
(*.f64 -1/3 x)
(*.f64 x -1/3)
(*.f64 -1/3 x)
(*.f64 x -1/3)
(*.f64 -1/3 x)
(*.f64 x -1/3)
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))

localize15.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.3b
(*.f64 1/3 x)
2.9b
(exp.f64 (log.f64 (*.f64 1/3 x)))
Compiler

Compiled 15 to 11 computations (26.7% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
0.0ms
x
@0
(exp.f64 (log.f64 (*.f64 1/3 x)))
0.0ms
x
@inf
(exp.f64 (log.f64 (*.f64 1/3 x)))
0.0ms
x
@-inf
(exp.f64 (log.f64 (*.f64 1/3 x)))

rewrite42.0ms (0.2%)

Algorithm
batch-egg-rewrite
Rules
431×pow1_binary64
418×add-sqr-sqrt_binary64
410×*-un-lft-identity_binary64
399×add-log-exp_binary64
399×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify7.0ms (0%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0448
1548
Stop Event
saturated
Counts
40 → 28
Calls
Call 1
Inputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
Outputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)

localize10.0ms (0%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.2b
(pow.f64 (*.f64 1/3 x) 3)
0.3b
(*.f64 1/3 x)
37.6b
(cbrt.f64 (pow.f64 (*.f64 1/3 x) 3))
Compiler

Compiled 18 to 14 computations (22.2% saved)

series5.0ms (0%)

Counts
2 → 24
Calls

6 calls:

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

rewrite91.0ms (0.5%)

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

Useful iterations: 0 (0.0ms)

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

simplify185.0ms (0.9%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
013148
128148
258148
386148
4148148
5385148
61266148
71961148
82079148
92467148
102625148
112869148
123191148
133613148
144113148
154714148
165438148
175761148
186047148
196269148
206447148
216531148
227471148
Stop Event
node limit
Counts
75 → 53
Calls
Call 1
Inputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 -1 (*.f64 (cbrt.f64 -1/27) x))
(*.f64 -1 (*.f64 (cbrt.f64 -1/27) x))
(*.f64 -1 (*.f64 (cbrt.f64 -1/27) x))
(*.f64 -1 (*.f64 (cbrt.f64 -1/27) x))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
Outputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 -1 (*.f64 (cbrt.f64 -1/27) x))
(neg.f64 (*.f64 x (cbrt.f64 -1/27)))
(*.f64 x (neg.f64 (cbrt.f64 -1/27)))
(*.f64 (cbrt.f64 -1/27) (neg.f64 x))
(*.f64 -1 (*.f64 (cbrt.f64 -1/27) x))
(neg.f64 (*.f64 x (cbrt.f64 -1/27)))
(*.f64 x (neg.f64 (cbrt.f64 -1/27)))
(*.f64 (cbrt.f64 -1/27) (neg.f64 x))
(*.f64 -1 (*.f64 (cbrt.f64 -1/27) x))
(neg.f64 (*.f64 x (cbrt.f64 -1/27)))
(*.f64 x (neg.f64 (cbrt.f64 -1/27)))
(*.f64 (cbrt.f64 -1/27) (neg.f64 x))
(*.f64 -1 (*.f64 (cbrt.f64 -1/27) x))
(neg.f64 (*.f64 x (cbrt.f64 -1/27)))
(*.f64 x (neg.f64 (cbrt.f64 -1/27)))
(*.f64 (cbrt.f64 -1/27) (neg.f64 x))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))
(*.f64 1/27 (pow.f64 x 3))

localize12.0ms (0.1%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.3b
(*.f64 1/3 x)
0.6b
(cbrt.f64 (*.f64 1/3 x))
0.7b
(pow.f64 (cbrt.f64 (*.f64 1/3 x)) 3)
Compiler

Compiled 17 to 13 computations (23.5% saved)

series7.0ms (0%)

Counts
2 → 0
Calls

6 calls:

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

rewrite58.0ms (0.3%)

Algorithm
batch-egg-rewrite
Rules
515×pow1_binary64
508×add-sqr-sqrt_binary64
487×add-log-exp_binary64
487×log1p-expm1-u_binary64
487×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify7.0ms (0%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

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

eval156.0ms (0.8%)

Compiler

Compiled 3057 to 2349 computations (23.2% saved)

prune205.0ms (1%)

Pruning

16 alts after pruning (9 fresh and 7 done)

PrunedKeptTotal
New3018309
Fresh112
Picked011
Done268
Total30416320
Error
0.0b
Counts
320 → 16
Alt Table
Click to see full alt table
StatusErrorProgram
1.0b
(*.f64 (pow.f64 1/27 1/3) x)
1.8b
(pow.f64 (cbrt.f64 (*.f64 1/3 x)) 3)
33.4b
(*.f64 (*.f64 1/3 (sqrt.f64 x)) (sqrt.f64 x))
0.6b
(*.f64 1/3 x)
28.5b
(*.f64 (cbrt.f64 (*.f64 (*.f64 x x) 1/9)) (cbrt.f64 (*.f64 1/3 x)))
46.9b
(sqrt.f64 (*.f64 x (*.f64 x 1/9)))
28.0b
(/.f64 (-.f64 (*.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/45 (pow.f64 x 3))) (*.f64 (*.f64 x 1/3) (*.f64 x 1/3))) (-.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3)))
0.4b
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
35.9b
(+.f64 (exp.f64 (log.f64 (*.f64 1/3 x))) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
33.5b
(pow.f64 (sqrt.f64 (*.f64 x 1/3)) 2)
60.3b
(exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))
46.9b
(sqrt.f64 (*.f64 (*.f64 x x) 1/9))
0.4b
(/.f64 (*.f64 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) -1/9) x) (fma.f64 1/45 (*.f64 x x) -1/3))
0.3b
(/.f64 (*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
0.4b
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
60.1b
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Compiler

Compiled 344 to 269 computations (21.8% saved)

localize126.0ms (0.6%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.2b
(*.f64 (*.f64 x x) 1/135)
0.3b
(*.f64 x 1/45)
0.3b
(*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x)
0.3b
(/.f64 (*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
Compiler

Compiled 105 to 73 computations (30.5% saved)

series16.0ms (0.1%)

Counts
4 → 48
Calls

12 calls:

TimeVariablePointExpression
7.0ms
x
@inf
(/.f64 (*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
2.0ms
x
@0
(/.f64 (*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
1.0ms
x
@inf
(*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x)
1.0ms
x
@0
(*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x)
1.0ms
x
@-inf
(*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x)

rewrite145.0ms (0.7%)

Algorithm
batch-egg-rewrite
Rules
620×fma-def_binary64
373×expm1-udef_binary64
373×log1p-udef_binary64
334×fma-neg_binary64
226×add-sqr-sqrt_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02162
148556
2622150
Stop Event
node limit
Counts
4 → 98
Calls
Call 1
Inputs
(/.f64 (*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
(*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x)
(*.f64 x 1/45)
(*.f64 (*.f64 x x) 1/135)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (*.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (/.f64 1 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (/.f64 1 (/.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (*.f64 x (/.f64 1 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) (/.f64 1 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)) (cbrt.f64 (pow.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x) 2)) (cbrt.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) 2) (*.f64 (cbrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) (/.f64 1 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)) (sqrt.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) (*.f64 (sqrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) (/.f64 1 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (neg.f64 x)) (/.f64 1 (neg.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x 1) (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) 1) (/.f64 x (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) 2) 1) (/.f64 (cbrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) 1) (/.f64 (sqrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (pow.f64 (cbrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) 2)) (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (cbrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (pow.f64 (cbrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) 2)) (/.f64 x (cbrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (cbrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) 2)) (/.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) (cbrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) 2) (pow.f64 (cbrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) 2)) (cbrt.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) (pow.f64 (cbrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) 2)) (/.f64 (sqrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) (cbrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x (sqrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))) (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (sqrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (sqrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))) (/.f64 x (sqrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))) (/.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) (sqrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) 2) (sqrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))) (/.f64 (cbrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) (sqrt.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) (fma.f64 1/8303765625 (pow.f64 (pow.f64 x 4) 3) (pow.f64 (fma.f64 (*.f64 x x) -1/135 1/9) 3))) (fma.f64 (fma.f64 (*.f64 x x) -1/135 1/9) (-.f64 (fma.f64 (*.f64 x x) -1/135 1/9) (*.f64 1/2025 (pow.f64 x 4))) (*.f64 1/4100625 (pow.f64 x 8))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) (fma.f64 1/4100625 (pow.f64 x 8) (neg.f64 (pow.f64 (fma.f64 (*.f64 x x) -1/135 1/9) 2)))) (+.f64 (fma.f64 1/2025 (pow.f64 x 4) -1/9) (*.f64 (*.f64 x x) 1/135)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)) (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) (neg.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) 3) (pow.f64 (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) (fma.f64 1/2025 (pow.f64 x 4) (fma.f64 (*.f64 x x) -1/135 1/9))) x)) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 1/27 x) (*.f64 (*.f64 (pow.f64 x 6) 1/91125) x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 (pow.f64 x 6) 1/91125) x) (*.f64 1/27 x))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x 1/27) (*.f64 x (*.f64 (pow.f64 x 6) 1/91125)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x (*.f64 (pow.f64 x 6) 1/91125)) (*.f64 x 1/27))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (+.f64 1/19683 (pow.f64 (*.f64 (pow.f64 x 6) 1/91125) 3)) x) (fma.f64 (*.f64 (pow.f64 x 6) 1/91125) (fma.f64 (pow.f64 x 6) 1/91125 -1/27) 1/729))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 (-.f64 1/729 (pow.f64 (*.f64 (pow.f64 x 6) 1/91125) 2)) x) (-.f64 1/27 (*.f64 (pow.f64 x 6) 1/91125)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (+.f64 1/19683 (pow.f64 (*.f64 (pow.f64 x 6) 1/91125) 3))) (fma.f64 (*.f64 (pow.f64 x 6) 1/91125) (fma.f64 (pow.f64 x 6) 1/91125 -1/27) 1/729))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (*.f64 x (-.f64 1/729 (pow.f64 (*.f64 (pow.f64 x 6) 1/91125) 2))) (-.f64 1/27 (*.f64 (pow.f64 x 6) 1/91125)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27)) x))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 3) (pow.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (fma.f64 (pow.f64 x 6) 1/91125 1/27) 3) (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x (fma.f64 (pow.f64 x 6) 1/91125 1/27))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1/27 x (*.f64 (*.f64 (pow.f64 x 6) 1/91125) x))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x 1/27 (*.f64 x (*.f64 (pow.f64 x 6) 1/91125)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x (*.f64 (pow.f64 x 6) 1/91125) (*.f64 x 1/27))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (pow.f64 x 6) 1/91125) x (*.f64 1/27 x))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x 1/45))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 1/45) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x 1/45)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x 1/45)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 1/91125 (pow.f64 x 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 1/2025 (*.f64 x x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 1/45) x))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x 1/45))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 1/91125 (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x 1/45)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x 1/45)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x 1/45)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x 1/45)) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (*.f64 x x) 1/135))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (*.f64 x x) 1/135) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (*.f64 x x) 1/135)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (sqrt.f64 1/135)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 1/2460375 (pow.f64 x 6)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 x 4) 1/18225))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (*.f64 x 1/135)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (*.f64 x x) 1/135))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 1/2460375 (pow.f64 x 6)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (*.f64 x x) 1/135)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (*.f64 x x) 1/135)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (*.f64 x x) 1/135)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (*.f64 x x) 1/135)) 1))))))

simplify154.0ms (0.8%)

Algorithm
egg-herbie
Rules
812×fma-def_binary64
602×unswap-sqr_binary64
559×associate-*l*_binary64
508×distribute-lft-in_binary64
508×distribute-rgt-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
021366
147366
289366
3197366
4525366
51942366
63298366
73554366
84009366
94787366
106078366
117957366
Stop Event
node limit
Counts
146 → 111
Calls
Call 1
Inputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/27 x)
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(*.f64 1/91125 (pow.f64 x 7))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(*.f64 1/91125 (pow.f64 x 7))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/45 x)
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (pow.f64 x 2))
Outputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 1/27 x)
(*.f64 x 1/27)
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(fma.f64 1/91125 (pow.f64 x 7) (*.f64 x 1/27))
(fma.f64 x 1/27 (*.f64 1/91125 (pow.f64 x 7)))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(fma.f64 1/91125 (pow.f64 x 7) (*.f64 x 1/27))
(fma.f64 x 1/27 (*.f64 1/91125 (pow.f64 x 7)))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(fma.f64 1/91125 (pow.f64 x 7) (*.f64 x 1/27))
(fma.f64 x 1/27 (*.f64 1/91125 (pow.f64 x 7)))
(*.f64 1/91125 (pow.f64 x 7))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(fma.f64 1/91125 (pow.f64 x 7) (*.f64 x 1/27))
(fma.f64 x 1/27 (*.f64 1/91125 (pow.f64 x 7)))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(fma.f64 1/91125 (pow.f64 x 7) (*.f64 x 1/27))
(fma.f64 x 1/27 (*.f64 1/91125 (pow.f64 x 7)))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(fma.f64 1/91125 (pow.f64 x 7) (*.f64 x 1/27))
(fma.f64 x 1/27 (*.f64 1/91125 (pow.f64 x 7)))
(*.f64 1/91125 (pow.f64 x 7))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(fma.f64 1/91125 (pow.f64 x 7) (*.f64 x 1/27))
(fma.f64 x 1/27 (*.f64 1/91125 (pow.f64 x 7)))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(fma.f64 1/91125 (pow.f64 x 7) (*.f64 x 1/27))
(fma.f64 x 1/27 (*.f64 1/91125 (pow.f64 x 7)))
(+.f64 (*.f64 1/91125 (pow.f64 x 7)) (*.f64 1/27 x))
(fma.f64 1/91125 (pow.f64 x 7) (*.f64 x 1/27))
(fma.f64 x 1/27 (*.f64 1/91125 (pow.f64 x 7)))
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/45 x)
(*.f64 x 1/45)
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))
(*.f64 1/135 (pow.f64 x 2))
(*.f64 1/135 (*.f64 x x))
(*.f64 x (*.f64 x 1/135))

localize11.0ms (0.1%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.3b
(*.f64 (pow.f64 1/27 1/3) x)
1.0b
(pow.f64 1/27 1/3)
Compiler

Compiled 12 to 10 computations (16.7% saved)

series3.0ms (0%)

Counts
2 → 12
Calls

3 calls:

TimeVariablePointExpression
2.0ms
x
@0
(*.f64 (pow.f64 1/27 1/3) x)
0.0ms
x
@-inf
(*.f64 (pow.f64 1/27 1/3) x)
0.0ms
x
@inf
(*.f64 (pow.f64 1/27 1/3) x)

rewrite109.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
421×pow1_binary64
416×add-sqr-sqrt_binary64
402×*-un-lft-identity_binary64
397×add-log-exp_binary64
397×log1p-expm1-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify7.0ms (0%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0448
1548
Stop Event
saturated
Counts
27 → 16
Calls
Call 1
Inputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
Outputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)

localize64.0ms (0.3%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f64 (*.f64 x 1/3))
0.3b
(pow.f64 (sqrt.f64 (*.f64 x 1/3)) 2)
0.3b
(*.f64 x 1/3)
Compiler

Compiled 17 to 13 computations (23.5% saved)

series7.0ms (0%)

Counts
3 → 12
Calls

9 calls:

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

rewrite61.0ms (0.3%)

Algorithm
batch-egg-rewrite
Rules
497×pow1_binary64
486×add-sqr-sqrt_binary64
464×add-log-exp_binary64
464×log1p-expm1-u_binary64
464×expm1-log1p-u_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify8.0ms (0%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0448
1548
Stop Event
saturated
Counts
71 → 52
Calls
Call 1
Inputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
Outputs
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)
(*.f64 1/3 x)

localize29.0ms (0.1%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.3b
(*.f64 (cbrt.f64 (*.f64 (*.f64 x x) 1/9)) (cbrt.f64 (*.f64 1/3 x)))
0.3b
(*.f64 1/3 x)
0.6b
(cbrt.f64 (*.f64 1/3 x))
28.7b
(cbrt.f64 (*.f64 (*.f64 x x) 1/9))
Compiler

Compiled 36 to 21 computations (41.7% saved)

series11.0ms (0.1%)

Counts
2 → 12
Calls

6 calls:

TimeVariablePointExpression
5.0ms
x
@0
(*.f64 (cbrt.f64 (*.f64 (*.f64 x x) 1/9)) (cbrt.f64 (*.f64 1/3 x)))
2.0ms
x
@-inf
(*.f64 (cbrt.f64 (*.f64 (*.f64 x x) 1/9)) (cbrt.f64 (*.f64 1/3 x)))
1.0ms
x
@inf
(*.f64 (cbrt.f64 (*.f64 (*.f64 x x) 1/9)) (cbrt.f64 (*.f64 1/3 x)))
1.0ms
x
@0
(cbrt.f64 (*.f64 (*.f64 x x) 1/9))
1.0ms
x
@inf
(cbrt.f64 (*.f64 (*.f64 x x) 1/9))

rewrite61.0ms (0.3%)

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

Useful iterations: 1 (0.0ms)

IterNodesCost
01024
119913
2221413
Stop Event
node limit
Counts
2 → 41
Calls
Call 1
Inputs
(cbrt.f64 (*.f64 (*.f64 x x) 1/9))
(*.f64 (cbrt.f64 (*.f64 (*.f64 x x) 1/9)) (cbrt.f64 (*.f64 1/3 x)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x 1/3)) (cbrt.f64 (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (cbrt.f64 (*.f64 x 1/9)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 x) (pow.f64 (*.f64 x 1/9) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)) (cbrt.f64 (cbrt.f64 (*.f64 (pow.f64 x 4) 1/81))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)) (*.f64 (cbrt.f64 (cbrt.f64 (*.f64 x 1/3))) (cbrt.f64 (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (cbrt.f64 (*.f64 (pow.f64 x 4) 1/81))) (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 x) 2) (cbrt.f64 1/9))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 1/3) (*.f64 (cbrt.f64 x) (cbrt.f64 (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 1/9) (pow.f64 (cbrt.f64 x) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 x 1/3)) (pow.f64 (*.f64 x 1/3) 1/6))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x 1/3) 1/6) (sqrt.f64 (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/3) (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 (pow.f64 x 4) 1/81)) 1/3) (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (*.f64 x 1/3)) (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2))) (cbrt.f64 (cbrt.f64 (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (cbrt.f64 (*.f64 x 1/3)) (cbrt.f64 1/3)) (cbrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 x 1/9)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 1/3) 2/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (cbrt.f64 (*.f64 (pow.f64 x 4) 1/81)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (pow.f64 (cbrt.f64 (*.f64 x 1/3)) 2)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (*.f64 x 1/3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 x 1/9)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 1/3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x 1/3)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 x 1/3)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x 1/3) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 x (*.f64 x 1/9)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 1/3) x))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x 1/3) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 x 1/3)))))))

simplify163.0ms (0.8%)

Algorithm
egg-herbie
Rules
276×fma-def_binary64
27×distribute-rgt-in_binary64
22×associate-*l*_binary64
22×distribute-lft-in_binary64
21×sub-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
014140
126140
264140
3110140
4125140
5173140
6245140
7282140
8338140
9555140
10583140
Stop Event
saturated
Counts
53 → 45
Calls
Call 1
Inputs
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 -1 (*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) x)))
(*.f64 -1 (*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) x)))
(*.f64 -1 (*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) x)))
(*.f64 -1 (*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) x)))
Outputs
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 x (*.f64 (cbrt.f64 1/3) (cbrt.f64 1/9)))
(*.f64 x (*.f64 (cbrt.f64 1/9) (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 x (*.f64 (cbrt.f64 1/3) (cbrt.f64 1/9)))
(*.f64 x (*.f64 (cbrt.f64 1/9) (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 x (*.f64 (cbrt.f64 1/3) (cbrt.f64 1/9)))
(*.f64 x (*.f64 (cbrt.f64 1/9) (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 x (*.f64 (cbrt.f64 1/3) (cbrt.f64 1/9)))
(*.f64 x (*.f64 (cbrt.f64 1/9) (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 x (*.f64 (cbrt.f64 1/3) (cbrt.f64 1/9)))
(*.f64 x (*.f64 (cbrt.f64 1/9) (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 x (*.f64 (cbrt.f64 1/3) (cbrt.f64 1/9)))
(*.f64 x (*.f64 (cbrt.f64 1/9) (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 x (*.f64 (cbrt.f64 1/3) (cbrt.f64 1/9)))
(*.f64 x (*.f64 (cbrt.f64 1/9) (cbrt.f64 1/3)))
(*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 1/3)))
(*.f64 x (*.f64 (cbrt.f64 1/3) (cbrt.f64 1/9)))
(*.f64 x (*.f64 (cbrt.f64 1/9) (cbrt.f64 1/3)))
(*.f64 -1 (*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) x)))
(neg.f64 (*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 -1/3))))
(*.f64 (*.f64 x (cbrt.f64 -1/3)) (neg.f64 (cbrt.f64 1/9)))
(*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) (neg.f64 x)))
(*.f64 -1 (*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) x)))
(neg.f64 (*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 -1/3))))
(*.f64 (*.f64 x (cbrt.f64 -1/3)) (neg.f64 (cbrt.f64 1/9)))
(*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) (neg.f64 x)))
(*.f64 -1 (*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) x)))
(neg.f64 (*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 -1/3))))
(*.f64 (*.f64 x (cbrt.f64 -1/3)) (neg.f64 (cbrt.f64 1/9)))
(*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) (neg.f64 x)))
(*.f64 -1 (*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) x)))
(neg.f64 (*.f64 (cbrt.f64 1/9) (*.f64 x (cbrt.f64 -1/3))))
(*.f64 (*.f64 x (cbrt.f64 -1/3)) (neg.f64 (cbrt.f64 1/9)))
(*.f64 (cbrt.f64 1/9) (*.f64 (cbrt.f64 -1/3) (neg.f64 x)))

localize35.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(*.f64 1/45 (pow.f64 x 3))
0.2b
(*.f64 (*.f64 x 1/3) (*.f64 x 1/3))
0.3b
(*.f64 x 1/3)
28.0b
(/.f64 (-.f64 (*.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/45 (pow.f64 x 3))) (*.f64 (*.f64 x 1/3) (*.f64 x 1/3))) (-.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3)))
Compiler

Compiled 91 to 71 computations (22% saved)

series3.0ms (0%)

Counts
2 → 24
Calls

6 calls:

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

rewrite94.0ms (0.5%)

Algorithm
batch-egg-rewrite
Rules
850×log-prod_binary64
466×fma-neg_binary64
261×expm1-udef_binary64
261×log1p-udef_binary64
209×log-pow_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01341
132718
2480318
Stop Event
node limit
Counts
2 → 99
Calls
Call 1
Inputs
(/.f64 (-.f64 (*.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/45 (pow.f64 x 3))) (*.f64 (*.f64 x 1/3) (*.f64 x 1/3))) (-.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3)))
(*.f64 (*.f64 x 1/3) (*.f64 x 1/3))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 x 1/3) (*.f64 1/45 (pow.f64 x 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 1/2025 (/.f64 (pow.f64 x 6) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (exp.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)))) (cbrt.f64 (exp.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)))))) (log.f64 (cbrt.f64 (exp.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))) (log.f64 (sqrt.f64 (exp.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (*.f64 1/2025 (/.f64 (pow.f64 x 6) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) (/.f64 1 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) 2)) (*.f64 (cbrt.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (/.f64 1 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))) (pow.f64 (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))) 2) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (*.f64 (sqrt.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (/.f64 1 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (/.f64 1 (neg.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))) (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)) (*.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) (/.f64 1 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 2))) (/.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (/.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) 2)) 1) (/.f64 (cbrt.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) 1) (/.f64 (sqrt.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)) 1) (/.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) 2)) (cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 2))) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 2))) (/.f64 (sqrt.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)) (cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 2))) (/.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (pow.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) 2)) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (/.f64 (cbrt.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (/.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) (-.f64 (*.f64 (pow.f64 (pow.f64 x 3) 3) 1/91125) (pow.f64 (*.f64 x 1/3) 3))) (fma.f64 1/2025 (pow.f64 x 6) (*.f64 (*.f64 x 1/3) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) (neg.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 1/45) (pow.f64 x 3)) (pow.f64 (exp.f64 1/3) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 1/45 (pow.f64 x 3)))) (pow.f64 (exp.f64 1/3) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 1/45) (pow.f64 x 3)) (+.f64 1 (expm1.f64 (*.f64 x 1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 1/45 (pow.f64 x 3)))) (+.f64 1 (expm1.f64 (*.f64 x 1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 1/3) x) (pow.f64 (exp.f64 1/45) (pow.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 x 1/3))) (pow.f64 (exp.f64 1/45) (pow.f64 x 3))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (pow.f64 (exp.f64 1/3) x) (+.f64 1 (expm1.f64 (*.f64 1/45 (pow.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (*.f64 (+.f64 1 (expm1.f64 (*.f64 x 1/3))) (+.f64 1 (expm1.f64 (*.f64 1/45 (pow.f64 x 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9)) 3) (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1/45 (/.f64 (*.f64 (pow.f64 x 6) 1/45) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 x 3) 1/45 (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (pow.f64 x 6) 1/2025) (/.f64 1 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 1/2025 (/.f64 (pow.f64 x 6) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1/2025 (/.f64 (pow.f64 x 6) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cbrt.f64 1/2025) (*.f64 x x)) (*.f64 x (cbrt.f64 1/45)) (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (sqrt.f64 1/45) (pow.f64 x 3/2)) (*.f64 (sqrt.f64 1/45) (pow.f64 x 3/2)) (*.f64 x 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cbrt.f64 (*.f64 1/2025 (/.f64 (pow.f64 x 6) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))))) (cbrt.f64 (*.f64 1/2025 (/.f64 (pow.f64 x 6) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))) (cbrt.f64 (*.f64 1/2025 (/.f64 (pow.f64 x 6) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 1/2025 (/.f64 (pow.f64 x 6) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))))) (sqrt.f64 (*.f64 1/2025 (/.f64 (pow.f64 x 6) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (*.f64 1/45 (pow.f64 x 3)) 1) (/.f64 (*.f64 1/45 (pow.f64 x 3)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (*.f64 (cbrt.f64 1/2025) (*.f64 x x)) 2) 1) (/.f64 (*.f64 (cbrt.f64 1/2025) (*.f64 x x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (*.f64 (pow.f64 x 3) 1/2025) 1) (/.f64 (pow.f64 x 3) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1/45 (cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 2))) (/.f64 (*.f64 (pow.f64 x 6) 1/45) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (*.f64 1/45 (pow.f64 x 3)) (cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 2))) (/.f64 (*.f64 1/45 (pow.f64 x 3)) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 (cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 2))) (/.f64 (*.f64 (pow.f64 x 6) 1/2025) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1/2025 (cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 2))) (/.f64 (pow.f64 x 6) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (*.f64 (cbrt.f64 1/2025) (*.f64 x x)) 2) (cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 2))) (/.f64 (*.f64 (cbrt.f64 1/2025) (*.f64 x x)) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (*.f64 (pow.f64 x 3) 1/2025) (cbrt.f64 (pow.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)) 2))) (/.f64 (pow.f64 x 3) (cbrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1/45 (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (/.f64 (*.f64 (pow.f64 x 6) 1/45) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (*.f64 1/45 (pow.f64 x 3)) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (/.f64 (*.f64 1/45 (pow.f64 x 3)) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1 (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (/.f64 (*.f64 (pow.f64 x 6) 1/2025) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 1/2025 (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (/.f64 (pow.f64 x 6) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (pow.f64 (*.f64 (cbrt.f64 1/2025) (*.f64 x x)) 2) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (/.f64 (*.f64 (cbrt.f64 1/2025) (*.f64 x x)) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (*.f64 (pow.f64 x 3) 1/2025) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (/.f64 (pow.f64 x 3) (sqrt.f64 (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (*.f64 (pow.f64 x 6) 1/2025) (fma.f64 (pow.f64 x 6) 1/2025 (*.f64 (*.f64 x x) -1/9))) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (/.f64 (*.f64 (pow.f64 x 6) 1/2025) (-.f64 (*.f64 (pow.f64 (pow.f64 x 3) 3) 1/91125) (pow.f64 (*.f64 x 1/3) 3))) (fma.f64 1/2025 (pow.f64 x 6) (*.f64 (*.f64 x 1/3) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x 1/3)))) (neg.f64 (/.f64 (*.f64 x (*.f64 1/9 x)) (fma.f64 1/45 (pow.f64 x 3) (*.f64 x -1/3)))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 x (*.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (*.f64 1/9 x))) (cbrt.f64 (pow.f64 (exp.f64 x) (*.f64 1/9 x))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 x) (*.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (*.f64 1/9 x)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 x) (*.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 x (*.f64 1/9 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 1/3) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x (*.f64 1/9 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 x (*.f64 1/9 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (pow.f64 x 6) 1/729) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x 1/3) 4))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 x) (*.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 x (*.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 x 6) 1/729))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 x (*.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 x (*.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 2 (log.f64 (*.f64 x 1/3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x 1/3)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 2 (log.f64 (*.f64 x 1/3))) 1))))))

simplify180.0ms (0.9%)

Algorithm
egg-herbie
Rules
944×sqr-pow_binary64
564×cube-prod_binary64
536×unswap-sqr_binary64
462×fabs-mul_binary64
460×*-commutative_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
013201
130201
262201
3146201
4402201
51579201
63011201
73197201
83447201
93734201
104113201
114629201
125232201
135942201
146411201
156730201
167002201
177172201
187266201
197943201
Stop Event
node limit
Counts
123 → 105
Calls
Call 1
Inputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (pow.f64 x 2))
Outputs
(*.f64 1/3 x)
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 1/45 (pow.f64 x 3))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(+.f64 (*.f64 1/3 x) (*.f64 1/45 (pow.f64 x 3)))
(fma.f64 1/3 x (*.f64 1/45 (pow.f64 x 3)))
(*.f64 x (fma.f64 x (*.f64 x 1/45) 1/3))
(fma.f64 1/45 (pow.f64 x 3) (*.f64 1/3 x))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))
(*.f64 1/9 (pow.f64 x 2))
(*.f64 1/9 (*.f64 x x))
(*.f64 x (*.f64 x 1/9))

eval520.0ms (2.6%)

Compiler

Compiled 10659 to 8253 computations (22.6% saved)

prune67.0ms (0.3%)

Pruning

15 alts after pruning (7 fresh and 8 done)

PrunedKeptTotal
New4645469
Fresh224
Picked101
Done3811
Total47015485
Error
0b
Counts
485 → 15
Alt Table
Click to see full alt table
StatusErrorProgram
1.0b
(*.f64 (pow.f64 1/27 1/3) x)
0.6b
(*.f64 1/3 x)
0.4b
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
0.3b
(/.f64 (*.f64 x 1/27) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
35.9b
(+.f64 (exp.f64 (log.f64 (*.f64 1/3 x))) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
33.5b
(pow.f64 (sqrt.f64 (*.f64 x 1/3)) 2)
1.6b
(*.f64 (*.f64 (pow.f64 (cbrt.f64 x) 2) (cbrt.f64 1/9)) (cbrt.f64 (*.f64 1/3 x)))
28.0b
(/.f64 (-.f64 (*.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/45 (pow.f64 x 3))) (*.f64 x (*.f64 x 1/9))) (-.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3)))
60.3b
(exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))
46.9b
(sqrt.f64 (*.f64 (*.f64 x x) 1/9))
33.4b
(*.f64 (*.f64 1/3 (sqrt.f64 x)) (sqrt.f64 x))
46.9b
(sqrt.f64 (*.f64 x (*.f64 x 1/9)))
0.4b
(/.f64 (*.f64 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) -1/9) x) (fma.f64 1/45 (*.f64 x x) -1/3))
0.4b
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
60.1b
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Compiler

Compiled 191 to 150 computations (21.5% saved)

regimes31.0ms (0.2%)

Counts
26 → 1
Calls
Call 1
Inputs
(*.f64 1/3 x)
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
(-.f64 (/.f64 1 x) (+.f64 (*.f64 -1/3 x) (/.f64 1 x)))
(*.f64 (pow.f64 1/27 1/3) x)
(sqrt.f64 (*.f64 x (*.f64 x 1/9)))
(sqrt.f64 (*.f64 x (*.f64 x 1/9)))
(sqrt.f64 (*.f64 (*.f64 x x) 1/9))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
(/.f64 (*.f64 x 1/27) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
(exp.f64 (log.f64 (*.f64 1/3 x)))
(pow.f64 (sqrt.f64 (*.f64 x 1/3)) 2)
(pow.f64 (cbrt.f64 (*.f64 1/3 x)) 3)
(pow.f64 (sqrt.f64 (*.f64 1/3 x)) 2)
(cbrt.f64 (pow.f64 (*.f64 1/3 x) 3))
(*.f64 (*.f64 1/3 (sqrt.f64 x)) (sqrt.f64 x))
(*.f64 (*.f64 1/3 (sqrt.f64 x)) (sqrt.f64 x))
(*.f64 (cbrt.f64 (*.f64 (*.f64 x x) 1/9)) (cbrt.f64 (*.f64 1/3 x)))
(/.f64 (*.f64 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) -1/9) x) (fma.f64 1/45 (*.f64 x x) -1/3))
(/.f64 (*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
(exp.f64 (log.f64 (-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))))
(+.f64 (*.f64 1/3 x) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
(/.f64 (-.f64 (*.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/45 (pow.f64 x 3))) (*.f64 x (*.f64 x 1/9))) (-.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3)))
(/.f64 (-.f64 (*.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/45 (pow.f64 x 3))) (*.f64 (*.f64 x 1/3) (*.f64 x 1/3))) (-.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 x 1/3)))
(*.f64 (*.f64 (pow.f64 (cbrt.f64 x) 2) (cbrt.f64 1/9)) (cbrt.f64 (*.f64 1/3 x)))
(+.f64 (exp.f64 (log.f64 (*.f64 1/3 x))) (+.f64 (*.f64 2/945 (pow.f64 x 5)) (+.f64 (*.f64 1/45 (pow.f64 x 3)) (*.f64 1/4725 (pow.f64 x 7)))))
Outputs
(/.f64 (*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
Calls

3 calls:

15.0ms
x
4.0ms
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
3.0ms
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Results
ErrorSegmentsBranch
0.3b1x
0.3b1(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
0.3b1(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Compiler

Compiled 317 to 233 computations (26.5% saved)

regimes33.0ms (0.2%)

Counts
19 → 1
Calls
Call 1
Inputs
(*.f64 1/3 x)
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
(-.f64 (/.f64 1 x) (+.f64 (*.f64 -1/3 x) (/.f64 1 x)))
(*.f64 (pow.f64 1/27 1/3) x)
(sqrt.f64 (*.f64 x (*.f64 x 1/9)))
(sqrt.f64 (*.f64 x (*.f64 x 1/9)))
(sqrt.f64 (*.f64 (*.f64 x x) 1/9))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
(/.f64 (*.f64 x 1/27) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
(exp.f64 (log.f64 (*.f64 1/3 x)))
(pow.f64 (sqrt.f64 (*.f64 x 1/3)) 2)
(pow.f64 (cbrt.f64 (*.f64 1/3 x)) 3)
(pow.f64 (sqrt.f64 (*.f64 1/3 x)) 2)
(cbrt.f64 (pow.f64 (*.f64 1/3 x) 3))
(*.f64 (*.f64 1/3 (sqrt.f64 x)) (sqrt.f64 x))
(*.f64 (*.f64 1/3 (sqrt.f64 x)) (sqrt.f64 x))
(*.f64 (cbrt.f64 (*.f64 (*.f64 x x) 1/9)) (cbrt.f64 (*.f64 1/3 x)))
(/.f64 (*.f64 (+.f64 (*.f64 1/2025 (pow.f64 x 4)) -1/9) x) (fma.f64 1/45 (*.f64 x x) -1/3))
Outputs
(/.f64 (*.f64 x 1/27) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
Calls

2 calls:

21.0ms
x
5.0ms
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Results
ErrorSegmentsBranch
0.3b1x
0.3b1(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Compiler

Compiled 161 to 111 computations (31.1% saved)

regimes21.0ms (0.1%)

Accuracy

Total -60.3b remaining (-13820.7%)

Threshold costs -60.3b (-13820.7%)

Counts
9 → 1
Calls
Call 1
Inputs
(*.f64 1/3 x)
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
(-.f64 (/.f64 1 x) (+.f64 (*.f64 -1/3 x) (/.f64 1 x)))
(*.f64 (pow.f64 1/27 1/3) x)
(sqrt.f64 (*.f64 x (*.f64 x 1/9)))
(sqrt.f64 (*.f64 x (*.f64 x 1/9)))
(sqrt.f64 (*.f64 (*.f64 x x) 1/9))
(*.f64 x (fma.f64 1/45 (*.f64 x x) 1/3))
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Outputs
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
Calls

2 calls:

11.0ms
x
5.0ms
(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Results
ErrorSegmentsBranch
0.4b1x
0.4b1(-.f64 (/.f64 1 x) (/.f64 1 (tan.f64 x)))
Compiler

Compiled 74 to 50 computations (32.4% saved)

simplify12.0ms (0.1%)

Algorithm
egg-herbie
Rules
12×*-commutative_binary64
+-commutative_binary64
sub-neg_binary64
distribute-rgt-neg-in_binary64
neg-sub0_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02879
14579
26179
36779
47179
57279
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(/.f64 (*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
(/.f64 (*.f64 x 1/27) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
(*.f64 1/3 x)
Outputs
(/.f64 (*.f64 (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3)) x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
(/.f64 (*.f64 x (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3))) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
(/.f64 (*.f64 x (+.f64 1/27 (pow.f64 (*.f64 x (*.f64 x 1/45)) 3))) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (+.f64 1/9 (*.f64 (*.f64 x x) -1/135))))
(/.f64 (*.f64 x 1/27) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
(/.f64 (*.f64 1/27 x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (-.f64 1/9 (*.f64 (*.f64 x x) 1/135))))
(/.f64 (*.f64 1/27 x) (+.f64 (*.f64 1/2025 (pow.f64 x 4)) (+.f64 1/9 (*.f64 (*.f64 x x) -1/135))))
(*.f64 x (+.f64 (*.f64 1/45 (*.f64 x x)) 1/3))
(*.f64 1/3 x)
(*.f64 x 1/3)
Compiler

Compiled 58 to 44 computations (24.1% saved)

soundness171.0ms (0.9%)

Algorithm
egg-herbie
Rules
855×fma-def_binary64
712×distribute-rgt-neg-in_binary64
624×unswap-sqr_binary64
603×distribute-lft-neg-in_binary64
438×associate-*l*_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
039281
196275
2220275
3570275
41053275
52194275
63053275
74079275
84575275
96502275
Stop Event
node limit
Compiler

Compiled 63 to 44 computations (30.2% saved)

end53.0ms (0.3%)

Compiler

Compiled 55 to 39 computations (29.1% saved)

Profiling

Loading profile data...