Details

Time bar (total: 3.0s)

analyze96.0ms (3.3%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%50%50%2
0%50%50%3
0%50%50%4
12.5%37.5%50%5
18.7%31.2%50%6
28.1%21.9%50%7
32.8%17.2%50%8
37.5%11.7%50.8%9
39.8%9%51.2%10
42.1%6%51.8%11
43.3%4.6%52.1%12
44.5%3.1%52.4%13
45.1%2.3%52.6%14
Compiler

Compiled 17 to 14 computations (17.6% saved)

sample1.0s (34.3%)

Results
989.0ms8256×body128valid
10.0ms89×body128invalid
Compiler

Compiled 34 to 28 computations (17.6% saved)

preprocess52.0ms (1.8%)

Algorithm
egg-herbie
Rules
980×fma-neg_binary64
456×cancel-sign-sub-inv_binary64
286×fma-def_binary64
206×div-sub_binary64
204×distribute-rgt-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02042
14636
210036
320936
444532
583432
6172932
7322832
8459532
9487232
022
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
(-.f64 (-.f64 1 (/.f64 1 (*.f64 y 9))) (/.f64 x (*.f64 3 (sqrt.f64 y))))
Outputs
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
(-.f64 1 (+.f64 (/.f64 1 (*.f64 x 9)) (/.f64 y (*.f64 3 (sqrt.f64 x)))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (/.f64 y (*.f64 3 (sqrt.f64 x))))
(+.f64 1 (-.f64 (/.f64 -1/9 x) (/.f64 y (*.f64 3 (sqrt.f64 x)))))
(-.f64 1 (-.f64 (/.f64 1/9 x) (*.f64 -1/3 (/.f64 y (sqrt.f64 x)))))
(+.f64 (/.f64 -1/9 x) (fma.f64 -1/3 (/.f64 y (sqrt.f64 x)) 1))
(+.f64 (/.f64 -1/9 x) (fma.f64 (/.f64 y (sqrt.f64 x)) -1/3 1))
(+.f64 1 (fma.f64 y (/.f64 -1/3 (sqrt.f64 x)) (/.f64 -1/9 x)))
(-.f64 (-.f64 1 (/.f64 1 (*.f64 y 9))) (/.f64 x (*.f64 3 (sqrt.f64 y))))
(-.f64 1 (+.f64 (/.f64 1 (*.f64 9 y)) (/.f64 x (*.f64 3 (sqrt.f64 y)))))
(-.f64 1 (+.f64 (/.f64 1/9 y) (/.f64 x (*.f64 3 (sqrt.f64 y)))))
(-.f64 (-.f64 1 (/.f64 1/9 y)) (/.f64 x (*.f64 3 (sqrt.f64 y))))
(+.f64 1 (+.f64 (/.f64 -1/9 y) (*.f64 -1/3 (/.f64 x (sqrt.f64 y)))))
(fma.f64 -1/3 (/.f64 x (sqrt.f64 y)) (-.f64 1 (/.f64 1/9 y)))
(-.f64 1 (fma.f64 1/3 (/.f64 x (sqrt.f64 y)) (/.f64 1/9 y)))
(fma.f64 (/.f64 x (sqrt.f64 y)) -1/3 (-.f64 1 (/.f64 1/9 y)))
Compiler

Compiled 16 to 13 computations (18.8% saved)

simplify29.0ms (1%)

Algorithm
egg-herbie
Rules
474×fma-neg_binary64
309×fma-def_binary64
228×cancel-sign-sub-inv_binary64
83×associate-/l*_binary64
72×distribute-rgt-in_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
01321
12718
25618
311418
423416
544016
686616
7156716
8233916
9237116
10239416
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
Outputs
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
(-.f64 1 (+.f64 (/.f64 1 (*.f64 x 9)) (/.f64 (/.f64 y 3) (sqrt.f64 x))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (/.f64 y (*.f64 3 (sqrt.f64 x))))
(+.f64 1 (-.f64 (/.f64 -1/9 x) (/.f64 y (*.f64 3 (sqrt.f64 x)))))
(+.f64 (/.f64 -1/9 x) (-.f64 1 (/.f64 y (*.f64 3 (sqrt.f64 x)))))
(fma.f64 -1/3 (/.f64 y (sqrt.f64 x)) (+.f64 1 (/.f64 -1/9 x)))
(+.f64 1 (fma.f64 (/.f64 y (sqrt.f64 x)) -1/3 (/.f64 -1/9 x)))
(+.f64 1 (fma.f64 y (/.f64 -1/3 (sqrt.f64 x)) (/.f64 -1/9 x)))

prune3.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.1b
Counts
3 → 2
Alt Table
StatusErrorProgram
0.3b
(+.f64 1 (fma.f64 y (/.f64 -1/3 (sqrt.f64 x)) (/.f64 -1/9 x)))
0.2b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
Compiler

Compiled 85 to 66 computations (22.4% saved)

localize8.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.3b
(/.f64 y (*.f64 3 (sqrt.f64 x)))
0.3b
(*.f64 3 (sqrt.f64 x))
0.4b
(/.f64 1 (*.f64 x 9))

series18.0ms (0.6%)

Counts
4 → 38
Calls

18 calls:

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

rewrite73.0ms (2.5%)

Algorithm
batch-egg-rewrite
Rules
240×expm1-udef_binary64
239×log1p-udef_binary64
185×fma-neg_binary64
144×add-sqr-sqrt_binary64
139×*-un-lft-identity_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01343
129037
2412537
Stop Event
node limit
Counts
4 → 136
Calls
Call 1
Inputs
(/.f64 1 (*.f64 x 9))
(*.f64 3 (sqrt.f64 x))
(/.f64 y (*.f64 3 (sqrt.f64 x)))
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (/.f64 1/9 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 1/9 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/9 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 1/9 x)) (pow.f64 (cbrt.f64 (/.f64 1/9 x)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (/.f64 1/9 x)) 2) (cbrt.f64 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (neg.f64 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/3 (sqrt.f64 x)) (/.f64 1/3 (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 x) 1/9)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/9 (/.f64 1 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 x 9)) 2) -1) (pow.f64 (cbrt.f64 (*.f64 x 9)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 9) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/9 x) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 1/9 x)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x 9) -3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1/3 (sqrt.f64 x)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 x 9) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x 9) -3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x 9)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 1/9 x)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (+.f64 1 (/.f64 1/9 x)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cbrt.f64 (+.f64 1 (/.f64 1/9 x))) (cbrt.f64 (+.f64 1 (/.f64 1/9 x)))) (cbrt.f64 (+.f64 1 (/.f64 1/9 x))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (+.f64 1 (/.f64 1/9 x))) (sqrt.f64 (+.f64 1 (/.f64 1/9 x))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 1/9 x)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 3 (sqrt.f64 x)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 9) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (sqrt.f64 x)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 3 (sqrt.f64 x)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 3 (sqrt.f64 x))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 3 (sqrt.f64 x))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 x 9))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 3 (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (sqrt.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 3 (sqrt.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 3 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 3 (sqrt.f64 x))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 3 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 3 (sqrt.f64 x))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 y (/.f64 1/3 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 y (/.f64 1/3 (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (cbrt.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 1/9 x)) (/.f64 y (cbrt.f64 (*.f64 3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (/.f64 1/3 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))) (sqrt.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) (/.f64 1/3 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 y) (/.f64 1 (*.f64 (sqrt.f64 x) -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1/3 (sqrt.f64 x)) y)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y 1/3) (/.f64 1 (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/3 (/.f64 y (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) 1) (/.f64 (cbrt.f64 y) (*.f64 3 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) 1) (/.f64 (sqrt.f64 y) (*.f64 3 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) 3) (/.f64 (cbrt.f64 y) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) 3) (/.f64 (sqrt.f64 y) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) (sqrt.f64 x)) (/.f64 (sqrt.f64 y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 x)) (*.f64 y 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (sqrt.f64 x)) (/.f64 (cbrt.f64 y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 (*.f64 x 9))) (cbrt.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) (cbrt.f64 (*.f64 x 9))) (/.f64 (sqrt.f64 y) (cbrt.f64 (*.f64 3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 (*.f64 3 (sqrt.f64 x)))) (/.f64 y (sqrt.f64 (*.f64 3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (sqrt.f64 (*.f64 3 (sqrt.f64 x)))) (/.f64 (cbrt.f64 y) (sqrt.f64 (*.f64 3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 3 (/.f64 (sqrt.f64 x) y)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 y (*.f64 (sqrt.f64 x) -3)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 y) (/.f64 1/3 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (neg.f64 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (-.f64 (neg.f64 (/.f64 1/9 x)) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (+.f64 (neg.f64 (/.f64 1/9 x)) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) (fma.f64 (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))) 1 (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) (fma.f64 (neg.f64 (/.f64 1/3 (sqrt.f64 x))) y (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) (fma.f64 (neg.f64 (cbrt.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) (+.f64 (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))) (pow.f64 (cbrt.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))) 2) (cbrt.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))) (sqrt.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) 3)) (/.f64 1 (+.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (+.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (-.f64 1 (/.f64 1/9 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 1 (+.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (-.f64 1 (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) (-.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (+.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (-.f64 1 (/.f64 1/9 x))))) (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (-.f64 1 (/.f64 1/9 x))) (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) 3)) (+.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (+.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (-.f64 1 (/.f64 1/9 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x))) (+.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (-.f64 1 (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) 3))) (neg.f64 (+.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (+.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (-.f64 1 (/.f64 1/9 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x)))) (neg.f64 (+.f64 (*.f64 y (/.f64 1/3 (sqrt.f64 x))) (-.f64 1 (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (*.f64 3 (/.f64 (sqrt.f64 x) y))) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) 1)) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) (*.f64 3 (/.f64 (sqrt.f64 x) y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (*.f64 3 (/.f64 (sqrt.f64 x) y))) (*.f64 (+.f64 1 (/.f64 1/9 x)) 1)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (*.f64 3 (/.f64 (sqrt.f64 x) y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (*.f64 3 (sqrt.f64 x))) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) y)) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) (*.f64 3 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (*.f64 3 (sqrt.f64 x))) (*.f64 (+.f64 1 (/.f64 1/9 x)) y)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (*.f64 3 (sqrt.f64 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (*.f64 (sqrt.f64 x) -3)) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) (neg.f64 y))) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) (*.f64 (sqrt.f64 x) -3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (*.f64 (sqrt.f64 x) -3)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (neg.f64 y))) (*.f64 (+.f64 1 (/.f64 1/9 x)) (*.f64 (sqrt.f64 x) -3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (sqrt.f64 x)) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) (*.f64 y 1/3))) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (sqrt.f64 x)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (*.f64 y 1/3))) (*.f64 (+.f64 1 (/.f64 1/9 x)) (sqrt.f64 x)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1 (pow.f64 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))) 3)) (+.f64 1 (+.f64 (*.f64 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))) (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))) 3)) (+.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (-.f64 (*.f64 (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x))))) (*.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x))))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1 (*.f64 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))) (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))) (+.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))))) (-.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x))))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (-.f64 1 (/.f64 1/9 x)) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (/.f64 1/9 x)) 1 (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) (pow.f64 (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) 2) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) 2) (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (/.f64 1 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2)))) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (/.f64 1 (+.f64 1 (/.f64 1/9 x))) (*.f64 y (neg.f64 (/.f64 1/3 (sqrt.f64 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (-.f64 1 (+.f64 (/.f64 1/9 x) (*.f64 y (/.f64 1/3 (sqrt.f64 x)))))))))))

simplify36.0ms (1.2%)

Algorithm
egg-herbie
Rules
341×fma-def_binary64
277×fma-neg_binary64
124×cancel-sign-sub-inv_binary64
55×distribute-rgt-neg-in_binary64
49×sub-neg_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
019417
140399
288399
3180399
4380399
5666399
61080399
71319399
81389399
91396399
Stop Event
saturated
Counts
174 → 147
Calls
Call 1
Inputs
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(/.f64 -1/9 x)
1
(-.f64 1 (*.f64 1/9 (/.f64 1 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(*.f64 -1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(*.f64 -1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
Outputs
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(/.f64 1/9 x)
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(/.f64 -1/9 x)
1
(-.f64 1 (*.f64 1/9 (/.f64 1 x)))
(-.f64 1 (/.f64 1/9 x))
(+.f64 1 (/.f64 -1/9 x))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 y (*.f64 1/3 (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 y (*.f64 1/3 (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 y (*.f64 1/3 (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3) (/.f64 -1/9 x)))
(*.f64 -1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 -1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3))
(*.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 y (*.f64 1/3 (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 y (*.f64 1/3 (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 y (*.f64 1/3 (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3) (/.f64 -1/9 x)))
(*.f64 -1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 -1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3))
(*.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 y (*.f64 1/3 (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 y (*.f64 1/3 (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)) (/.f64 1/9 x)))
(-.f64 1 (fma.f64 y (*.f64 1/3 (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3) (/.f64 -1/9 x)))

prune211.0ms (7.2%)

Pruning

11 alts after pruning (11 fresh and 0 done)

PrunedKeptTotal
New13710147
Fresh011
Picked101
Done000
Total13811149
Error
0.0b
Counts
149 → 11
Alt Table
StatusErrorProgram
20.5b
(/.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (*.f64 3 (sqrt.f64 x))) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) y)) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) (*.f64 3 (sqrt.f64 x))))
0.3b
(-.f64 (-.f64 1 (*.f64 (/.f64 1 x) 1/9)) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.3b
(+.f64 1 (fma.f64 y (/.f64 -1/3 (sqrt.f64 x)) (/.f64 -1/9 x)))
14.8b
(/.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (*.f64 3 (sqrt.f64 x))) (*.f64 (+.f64 1 (/.f64 1/9 x)) y)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (*.f64 3 (sqrt.f64 x))))
0.6b
(-.f64 (-.f64 1 (*.f64 (cbrt.f64 (/.f64 1/9 x)) (pow.f64 (cbrt.f64 (/.f64 1/9 x)) 2))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.4b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 (cbrt.f64 (/.f64 1/9 x)) (/.f64 y (cbrt.f64 (*.f64 3 (sqrt.f64 x))))))
0.2b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (sqrt.f64 (*.f64 x 9))))
0.3b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 (/.f64 1 (sqrt.f64 (*.f64 3 (sqrt.f64 x)))) (/.f64 y (sqrt.f64 (*.f64 3 (sqrt.f64 x))))))
0.4b
(-.f64 (-.f64 1 (fma.f64 (sqrt.f64 (+.f64 1 (/.f64 1/9 x))) (sqrt.f64 (+.f64 1 (/.f64 1/9 x))) -1)) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.3b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
0.3b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x)))))
Compiler

Compiled 3465 to 2558 computations (26.2% saved)

localize7.0ms (0.2%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (sqrt.f64 (*.f64 x 9))))
0.3b
(/.f64 y (sqrt.f64 (*.f64 x 9)))
0.4b
(sqrt.f64 (*.f64 x 9))
0.4b
(/.f64 1 (*.f64 x 9))

series6.0ms (0.2%)

Counts
3 → 26
Calls

15 calls:

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

rewrite75.0ms (2.5%)

Algorithm
batch-egg-rewrite
Rules
398×fma-def_binary64
215×expm1-udef_binary64
214×log1p-udef_binary64
178×fma-neg_binary64
125×add-sqr-sqrt_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01136
125133
2360631
Stop Event
node limit
Counts
3 → 166
Calls
Call 1
Inputs
(sqrt.f64 (*.f64 x 9))
(/.f64 y (sqrt.f64 (*.f64 x 9)))
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (sqrt.f64 (*.f64 x 9))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (sqrt.f64 x) 3))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 (sqrt.f64 x) 3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 (sqrt.f64 x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (sqrt.f64 x) 3)) (cbrt.f64 (*.f64 x 9)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 x 9)) (cbrt.f64 (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 x 9) 1/4) (pow.f64 (*.f64 x 9) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) 3)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 x) (pow.f64 9 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 3 (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cbrt.f64 (*.f64 (*.f64 x x) 81))) (sqrt.f64 (cbrt.f64 (*.f64 x 9))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 9 1/2) (sqrt.f64 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (*.f64 (sqrt.f64 x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 (*.f64 x x) 81)) 1/2) (pow.f64 (cbrt.f64 (*.f64 x 9)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 x 9) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 x) 3) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x 9) 3/2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 x) 3)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 x 9) 1/4) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (*.f64 (sqrt.f64 x) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (sqrt.f64 x)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 x 9) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 x 9)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (sqrt.f64 x) 3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (sqrt.f64 x) 3)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 y (sqrt.f64 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 y (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 1/9 x)) (/.f64 y (cbrt.f64 (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 y) 2) (*.f64 (cbrt.f64 y) (sqrt.f64 (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) (sqrt.f64 (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 y) (/.f64 1 (*.f64 (sqrt.f64 x) -3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 1/9 x)) y)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) 1) (/.f64 (cbrt.f64 y) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) 1) (/.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (cbrt.f64 (*.f64 x 9))) (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) (cbrt.f64 (*.f64 x 9))) (/.f64 (sqrt.f64 y) (cbrt.f64 (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (pow.f64 (*.f64 x 9) 1/4)) (/.f64 y (pow.f64 (*.f64 x 9) 1/4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (pow.f64 (*.f64 x 9) 1/4)) (/.f64 (cbrt.f64 y) (pow.f64 (*.f64 x 9) 1/4)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (sqrt.f64 x)) (/.f64 y 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (pow.f64 (cbrt.f64 y) 2) (sqrt.f64 x)) (/.f64 (cbrt.f64 y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) (sqrt.f64 x)) (/.f64 (sqrt.f64 y) 3))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (*.f64 (sqrt.f64 x) 3) y) -1)))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 y (*.f64 (sqrt.f64 x) -3)))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 y) (sqrt.f64 (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (neg.f64 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (-.f64 (neg.f64 (/.f64 1/9 x)) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (/.f64 1/9 x)) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) (fma.f64 (neg.f64 (sqrt.f64 (/.f64 1/9 x))) y (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) (fma.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) (+.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2) (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 3)) (/.f64 1 (fma.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x))) (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (-.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x))) (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2)) (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x))) (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 3)) (fma.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x))) (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x))) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 3))) (neg.f64 (fma.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x))) (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x)))) (neg.f64 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (*.f64 (sqrt.f64 x) 3)) (*.f64 (fma.f64 (/.f64 1/9 x) (+.f64 1 (/.f64 1/9 x)) 1) y)) (*.f64 (fma.f64 (/.f64 1/9 x) (+.f64 1 (/.f64 1/9 x)) 1) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (*.f64 (sqrt.f64 x) 3)) (*.f64 (+.f64 1 (/.f64 1/9 x)) y)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (/.f64 (*.f64 (sqrt.f64 x) 3) y)) (*.f64 (fma.f64 (/.f64 1/9 x) (+.f64 1 (/.f64 1/9 x)) 1) 1)) (*.f64 (fma.f64 (/.f64 1/9 x) (+.f64 1 (/.f64 1/9 x)) 1) (/.f64 (*.f64 (sqrt.f64 x) 3) y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (/.f64 (*.f64 (sqrt.f64 x) 3) y)) (*.f64 (+.f64 1 (/.f64 1/9 x)) 1)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (/.f64 (*.f64 (sqrt.f64 x) 3) y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (*.f64 (sqrt.f64 x) -3)) (*.f64 (fma.f64 (/.f64 1/9 x) (+.f64 1 (/.f64 1/9 x)) 1) (neg.f64 y))) (*.f64 (fma.f64 (/.f64 1/9 x) (+.f64 1 (/.f64 1/9 x)) 1) (*.f64 (sqrt.f64 x) -3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (*.f64 (sqrt.f64 x) -3)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (neg.f64 y))) (*.f64 (+.f64 1 (/.f64 1/9 x)) (*.f64 (sqrt.f64 x) -3)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1 (pow.f64 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)) 3)) (+.f64 1 (fma.f64 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 3)) (+.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (-.f64 (*.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3))) (*.f64 (-.f64 1 (/.f64 1/9 x)) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1 (*.f64 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (+.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)))) (-.f64 (-.f64 1 (/.f64 1/9 x)) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (+.f64 1 (expm1.f64 (-.f64 1 (/.f64 1/9 x)))) (pow.f64 (exp.f64 y) (sqrt.f64 (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (exp.f64 (-.f64 1 (/.f64 1/9 x))) (+.f64 1 (expm1.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (/.f64 (+.f64 1 (expm1.f64 (-.f64 1 (/.f64 1/9 x)))) (+.f64 1 (expm1.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log1p.f64 (neg.f64 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log1p.f64 (neg.f64 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 y (neg.f64 (sqrt.f64 (/.f64 1/9 x))) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (-.f64 1 (/.f64 1/9 x)) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (-.f64 1 (/.f64 1/9 x)) (*.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) (fma.f64 (neg.f64 (sqrt.f64 (/.f64 1/9 x))) y (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) (fma.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) (+.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (/.f64 1/9 x)) 1 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (/.f64 1/9 x)) 1 (*.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) 1 (fma.f64 (neg.f64 (sqrt.f64 (/.f64 1/9 x))) y (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) 1 (fma.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) 1 (fma.f64 (neg.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x))) 1 (+.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2) (fma.f64 (neg.f64 (sqrt.f64 (/.f64 1/9 x))) y (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2) (fma.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2) (+.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2) (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (fma.f64 (neg.f64 (sqrt.f64 (/.f64 1/9 x))) y (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2) (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (fma.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2) (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) 2) (cbrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (+.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) (pow.f64 (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) 2) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) (pow.f64 (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) 2) (*.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) 2) (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) 2) (cbrt.f64 (-.f64 1 (/.f64 1/9 x))) (*.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (neg.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (fma.f64 (neg.f64 (sqrt.f64 (/.f64 1/9 x))) y (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (fma.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (sqrt.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))) (+.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (*.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))) (neg.f64 (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -1 (/.f64 y (*.f64 (sqrt.f64 x) 3)) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 y) (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (/.f64 1 (fma.f64 (/.f64 1/9 x) (+.f64 1 (/.f64 1/9 x)) 1)) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (/.f64 1 (fma.f64 (/.f64 1/9 x) (+.f64 1 (/.f64 1/9 x)) 1)) (*.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 3)) (/.f64 1 (fma.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x))) (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2))) (fma.f64 (neg.f64 (sqrt.f64 (/.f64 1/9 x))) y (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 3)) (/.f64 1 (fma.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x))) (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2))) (fma.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 3)) (/.f64 1 (fma.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x))) (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 3) (pow.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) 3)) (/.f64 1 (fma.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)) (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x))) (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2))) (+.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (/.f64 1 (+.f64 1 (/.f64 1/9 x))) (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (/.f64 1 (+.f64 1 (/.f64 1/9 x))) (*.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x)))) (fma.f64 (neg.f64 (sqrt.f64 (/.f64 1/9 x))) y (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x)))) (fma.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x)))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 (pow.f64 (-.f64 1 (/.f64 1/9 x)) 2) (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (-.f64 1 (/.f64 1/9 x)))) (+.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 (cbrt.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3))) (cbrt.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)))) (cbrt.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3))) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3))) (sqrt.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3))) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (-.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (fma.f64 (neg.f64 (sqrt.f64 (/.f64 1/9 x))) y (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (-.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (fma.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) 1 (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (-.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (fma.f64 (neg.f64 (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x))) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (+.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (-.f64 (sqrt.f64 (-.f64 1 (/.f64 1/9 x))) (sqrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3)))) (+.f64 (/.f64 (neg.f64 y) (*.f64 (sqrt.f64 x) 3)) (/.f64 y (*.f64 (sqrt.f64 x) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (neg.f64 (cbrt.f64 (*.f64 (*.f64 y y) (/.f64 1/9 x)))) (cbrt.f64 (/.f64 y (*.f64 (sqrt.f64 x) 3))) (-.f64 1 (/.f64 1/9 x)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (-.f64 1 (fma.f64 y (sqrt.f64 (/.f64 1/9 x)) (/.f64 1/9 x)))))))))

simplify33.0ms (1.1%)

Algorithm
egg-herbie
Rules
341×fma-def_binary64
277×fma-neg_binary64
124×cancel-sign-sub-inv_binary64
54×distribute-rgt-neg-in_binary64
49×sub-neg_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
018369
140351
288351
3179351
4379351
5665351
61079351
71318351
81388351
91395351
Stop Event
saturated
Counts
192 → 176
Calls
Call 1
Inputs
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(/.f64 -1/9 x)
1
(-.f64 1 (*.f64 1/9 (/.f64 1 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(*.f64 -1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(*.f64 -1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
Outputs
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(/.f64 -1/9 x)
1
(-.f64 1 (*.f64 1/9 (/.f64 1 x)))
(-.f64 1 (/.f64 1/9 x))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (fma.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (fma.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (fma.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3) (/.f64 -1/9 x)))
(*.f64 -1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 -1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3))
(*.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (fma.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (fma.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (fma.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3) (/.f64 -1/9 x)))
(*.f64 -1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 -1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3))
(*.f64 y (*.f64 (sqrt.f64 (/.f64 1 x)) -1/3))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (fma.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (fma.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3) (/.f64 -1/9 x)))
(-.f64 1 (+.f64 (*.f64 1/9 (/.f64 1 x)) (*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))))
(-.f64 (-.f64 1 (/.f64 1/9 x)) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
(-.f64 1 (fma.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))) (/.f64 1/9 x)))
(+.f64 1 (fma.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 y -1/3) (/.f64 -1/9 x)))

prune309.0ms (10.5%)

Pruning

11 alts after pruning (10 fresh and 1 done)

PrunedKeptTotal
New2031204
Fresh1910
Picked011
Done000
Total20411215
Error
0.0b
Counts
215 → 11
Alt Table
StatusErrorProgram
20.5b
(/.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (*.f64 3 (sqrt.f64 x))) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) y)) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) (*.f64 3 (sqrt.f64 x))))
0.3b
(-.f64 (-.f64 1 (*.f64 (/.f64 1 x) 1/9)) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.3b
(+.f64 1 (fma.f64 y (/.f64 -1/3 (sqrt.f64 x)) (/.f64 -1/9 x)))
0.6b
(-.f64 (-.f64 1 (*.f64 (cbrt.f64 (/.f64 1/9 x)) (pow.f64 (cbrt.f64 (/.f64 1/9 x)) 2))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.2b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 y (sqrt.f64 (/.f64 1/9 x))))
14.8b
(/.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (*.f64 3 (sqrt.f64 x))) (*.f64 (+.f64 1 (/.f64 1/9 x)) y)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (*.f64 3 (sqrt.f64 x))))
0.4b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 (cbrt.f64 (/.f64 1/9 x)) (/.f64 y (cbrt.f64 (*.f64 3 (sqrt.f64 x))))))
0.2b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (sqrt.f64 (*.f64 x 9))))
0.3b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 (/.f64 1 (sqrt.f64 (*.f64 3 (sqrt.f64 x)))) (/.f64 y (sqrt.f64 (*.f64 3 (sqrt.f64 x))))))
0.4b
(-.f64 (-.f64 1 (fma.f64 (sqrt.f64 (+.f64 1 (/.f64 1/9 x))) (sqrt.f64 (+.f64 1 (/.f64 1/9 x))) -1)) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.3b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
Compiler

Compiled 5205 to 3802 computations (27% saved)

localize8.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f64 (/.f64 1/9 x))
0.3b
(*.f64 y (sqrt.f64 (/.f64 1/9 x)))
0.4b
(/.f64 1/9 x)
0.4b
(/.f64 1 (*.f64 x 9))

series10.0ms (0.3%)

Counts
3 → 12
Calls

12 calls:

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

rewrite42.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
673×pow1_binary64
631×add-log-exp_binary64
631×log1p-expm1-u_binary64
631×expm1-log1p-u_binary64
70×add-sqr-sqrt_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify10.0ms (0.3%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-*r*_binary64
associate-*l*_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
09144
115144
222144
324144
Stop Event
saturated
Counts
83 → 73
Calls
Call 1
Inputs
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
Outputs
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))

prune165.0ms (5.6%)

Pruning

10 alts after pruning (9 fresh and 1 done)

PrunedKeptTotal
New992101
Fresh279
Picked101
Done011
Total10210112
Error
0.0b
Counts
112 → 10
Alt Table
StatusErrorProgram
20.5b
(/.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (*.f64 3 (sqrt.f64 x))) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) y)) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) (*.f64 3 (sqrt.f64 x))))
0.3b
(+.f64 1 (fma.f64 y (/.f64 -1/3 (sqrt.f64 x)) (/.f64 -1/9 x)))
0.4b
(-.f64 (-.f64 1 (fma.f64 (sqrt.f64 (+.f64 1 (/.f64 1/9 x))) (sqrt.f64 (+.f64 1 (/.f64 1/9 x))) -1)) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.3b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 y (pow.f64 (pow.f64 (/.f64 1/9 x) 1/4) 2)))
14.8b
(/.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (*.f64 3 (sqrt.f64 x))) (*.f64 (+.f64 1 (/.f64 1/9 x)) y)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (*.f64 3 (sqrt.f64 x))))
0.6b
(-.f64 (-.f64 1 (*.f64 (cbrt.f64 (/.f64 1/9 x)) (pow.f64 (cbrt.f64 (/.f64 1/9 x)) 2))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.4b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 (cbrt.f64 (/.f64 1/9 x)) (/.f64 y (cbrt.f64 (*.f64 3 (sqrt.f64 x))))))
0.2b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (sqrt.f64 (*.f64 x 9))))
0.3b
(-.f64 (-.f64 1 (*.f64 1/9 (/.f64 1 x))) (*.f64 y (sqrt.f64 (/.f64 1/9 x))))
0.3b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
Compiler

Compiled 2187 to 1731 computations (20.9% saved)

localize9.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(sqrt.f64 (/.f64 1 x))
0.3b
(*.f64 1/3 y)
0.4b
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
0.4b
(/.f64 1 (*.f64 x 9))

series10.0ms (0.3%)

Counts
3 → 12
Calls

12 calls:

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

rewrite42.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
779×pow1_binary64
720×log1p-expm1-u_binary64
720×expm1-log1p-u_binary64
86×add-sqr-sqrt_binary64
81×*-un-lft-identity_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify10.0ms (0.3%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
associate-*r*_binary64
associate-*l*_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
09144
115144
222144
324144
Stop Event
saturated
Counts
70 → 60
Calls
Call 1
Inputs
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
Outputs
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))
(*.f64 1/3 (*.f64 y (sqrt.f64 (/.f64 1 x))))
(*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x)))
(*.f64 (sqrt.f64 (/.f64 1 x)) (*.f64 1/3 y))

prune125.0ms (4.2%)

Pruning

10 alts after pruning (8 fresh and 2 done)

PrunedKeptTotal
New88088
Fresh088
Picked011
Done011
Total881098
Error
0.0b
Counts
98 → 10
Alt Table
StatusErrorProgram
20.5b
(/.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -3)) (*.f64 3 (sqrt.f64 x))) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) y)) (*.f64 (+.f64 1 (+.f64 (/.f64 1/9 x) (pow.f64 (*.f64 x 9) -2))) (*.f64 3 (sqrt.f64 x))))
0.3b
(+.f64 1 (fma.f64 y (/.f64 -1/3 (sqrt.f64 x)) (/.f64 -1/9 x)))
0.4b
(-.f64 (-.f64 1 (fma.f64 (sqrt.f64 (+.f64 1 (/.f64 1/9 x))) (sqrt.f64 (+.f64 1 (/.f64 1/9 x))) -1)) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.3b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 y (pow.f64 (pow.f64 (/.f64 1/9 x) 1/4) 2)))
14.8b
(/.f64 (-.f64 (*.f64 (-.f64 1 (pow.f64 (*.f64 x 9) -2)) (*.f64 3 (sqrt.f64 x))) (*.f64 (+.f64 1 (/.f64 1/9 x)) y)) (*.f64 (+.f64 1 (/.f64 1/9 x)) (*.f64 3 (sqrt.f64 x))))
0.6b
(-.f64 (-.f64 1 (*.f64 (cbrt.f64 (/.f64 1/9 x)) (pow.f64 (cbrt.f64 (/.f64 1/9 x)) 2))) (/.f64 y (*.f64 3 (sqrt.f64 x))))
0.4b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 (cbrt.f64 (/.f64 1/9 x)) (/.f64 y (cbrt.f64 (*.f64 3 (sqrt.f64 x))))))
0.2b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (/.f64 y (sqrt.f64 (*.f64 x 9))))
0.3b
(-.f64 (-.f64 1 (*.f64 1/9 (/.f64 1 x))) (*.f64 y (sqrt.f64 (/.f64 1/9 x))))
0.3b
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 (*.f64 1/3 y) (sqrt.f64 (/.f64 1 x))))
Compiler

Compiled 1828 to 1481 computations (19% saved)

regimes369.0ms (12.5%)

Accuracy

Total 0.2b remaining (91.4%)

Threshold costs 0.2b (91.4%)

Counts
158 → 1
Compiler

Compiled 2731 to 2059 computations (24.6% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
+-commutative_binary64
sub-neg_binary64
neg-sub0_binary64
neg-mul-1_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01424
12624
24224
35024
45524
55624
Stop Event
saturated
Calls
Call 1
Inputs
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 y (sqrt.f64 (*.f64 (/.f64 1 x) 1/9))))
Outputs
(-.f64 (-.f64 1 (/.f64 1 (*.f64 x 9))) (*.f64 y (sqrt.f64 (*.f64 (/.f64 1 x) 1/9))))
(-.f64 (+.f64 1 (/.f64 -1 (*.f64 x 9))) (*.f64 y (sqrt.f64 (*.f64 (/.f64 1 x) 1/9))))

end180.0ms (6.1%)

Stop Event
fuel
Compiler

Compiled 265 to 216 computations (18.5% saved)

Profiling

Loading profile data...