Details

Time bar (total: 3.2s)

analyze112.0ms (3.5%)

Algorithm
search
Search
TrueOtherFalseIter
0%99.9%0.1%0
0%99.9%0.1%1
0%99.9%0.1%2
0%99.9%0.1%3
0%99.9%0.1%4
12.5%87.4%0.1%5
25%74.9%0.1%6
40.6%59.3%0.1%7
53.1%46.8%0.1%8
66.3%33.6%0.1%9
74.1%25.8%0.1%10
82.1%17.8%0.1%11
86.4%13.5%0.1%12
Compiler

Compiled 14 to 10 computations (28.6% saved)

sample1.2s (37.5%)

Results
1.2s8255×body256valid
0.0msbody2048valid

preprocess116.0ms (3.6%)

Algorithm
egg-herbie
Rules
1208×fma-neg_binary64
549×fma-def_binary64
520×div-sub_binary64
492×associate-/r/_binary64
385×sub-neg_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01532
12832
24328
36528
49528
516528
629228
755728
8117528
9191228
10308428
11552028
12648228
13666028
14676028
15676028
022
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
(-.f64 y (/.f64 x (+.f64 1 (/.f64 (*.f64 y x) 2))))
Outputs
(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
(-.f64 x (/.f64 y (+.f64 1 (/.f64 x (/.f64 2 y)))))
(-.f64 x (/.f64 y (+.f64 1 (*.f64 (/.f64 y 2) x))))
(-.f64 x (/.f64 y (fma.f64 (/.f64 x 2) y 1)))
(-.f64 x (/.f64 y (fma.f64 x (/.f64 y 2) 1)))
(-.f64 x (/.f64 y (fma.f64 x (*.f64 1/2 y) 1)))
(-.f64 x (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))
(+.f64 x (/.f64 y (fma.f64 x (*.f64 y -1/2) -1)))
(+.f64 x (/.f64 1 (fma.f64 x -1/2 (/.f64 -1 y))))
(-.f64 y (/.f64 x (+.f64 1 (/.f64 (*.f64 y x) 2))))
(-.f64 y (/.f64 x (+.f64 1 (/.f64 x (/.f64 2 y)))))
(-.f64 y (/.f64 x (+.f64 1 (*.f64 (/.f64 y 2) x))))
(-.f64 y (/.f64 x (fma.f64 (/.f64 x 2) y 1)))
(-.f64 y (/.f64 x (fma.f64 x (/.f64 y 2) 1)))
(-.f64 y (/.f64 x (fma.f64 x (*.f64 1/2 y) 1)))
(-.f64 y (/.f64 x (fma.f64 x (*.f64 y 1/2) 1)))
(+.f64 y (/.f64 x (fma.f64 x (*.f64 y -1/2) -1)))
Compiler

Compiled 15 to 11 computations (26.7% saved)

simplify144.0ms (4.4%)

Algorithm
egg-herbie
Rules
1478×fma-neg_binary64
989×div-sub_binary64
824×associate-/l/_binary64
519×fma-def_binary64
450×associate-/l*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01016
11816
22814
34114
46014
59614
617214
725414
849714
9105614
10177114
11387814
12639314
13695014
14711614
15714614
16715214
17715214
18777514
19788714
20788714
Stop Event
node limit
Counts
1 → 2
Calls
Call 1
Inputs
(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
Outputs
(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
(-.f64 x (/.f64 y (+.f64 1 (/.f64 x (/.f64 2 y)))))
(-.f64 x (/.f64 y (+.f64 1 (*.f64 (/.f64 x 2) y))))
(-.f64 x (/.f64 y (fma.f64 (/.f64 x 2) y 1)))
(-.f64 x (/.f64 y (fma.f64 y (/.f64 x 2) 1)))
(-.f64 x (/.f64 y (fma.f64 x (/.f64 y 2) 1)))
(-.f64 x (/.f64 y (fma.f64 x (*.f64 1/2 y) 1)))
(+.f64 x (/.f64 y (fma.f64 x (/.f64 y -2) -1)))
(+.f64 x (/.f64 y (fma.f64 x (*.f64 y -1/2) -1)))
(+.f64 x (/.f64 1 (fma.f64 x -1/2 (/.f64 -1 y))))

eval1.0ms (0%)

Compiler

Compiled 23 to 16 computations (30.4% saved)

prune1.0ms (0%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.0b
Counts
3 → 2
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 x (/.f64 1 (fma.f64 x -1/2 (/.f64 -1 y))))
0.0b
(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
Compiler

Compiled 25 to 18 computations (28% saved)

localize15.0ms (0.5%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(fma.f64 x -1/2 (/.f64 -1 y))
0.1b
(/.f64 1 (fma.f64 x -1/2 (/.f64 -1 y)))
Compiler

Compiled 34 to 24 computations (29.4% saved)

series6.0ms (0.2%)

Counts
2 → 48
Calls

12 calls:

TimeVariablePointExpression
1.0ms
x
@0
(/.f64 1 (fma.f64 x -1/2 (/.f64 -1 y)))
1.0ms
x
@inf
(/.f64 1 (fma.f64 x -1/2 (/.f64 -1 y)))
1.0ms
y
@inf
(/.f64 1 (fma.f64 x -1/2 (/.f64 -1 y)))
1.0ms
y
@-inf
(/.f64 1 (fma.f64 x -1/2 (/.f64 -1 y)))
1.0ms
x
@-inf
(/.f64 1 (fma.f64 x -1/2 (/.f64 -1 y)))

rewrite61.0ms (1.9%)

Algorithm
batch-egg-rewrite
Rules
777×pow1_binary64
715×add-log-exp_binary64
714×log1p-expm1-u_binary64
714×expm1-log1p-u_binary64
701×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify62.0ms (1.9%)

Algorithm
egg-herbie
Rules
878×fma-def_binary64
668×distribute-rgt-neg-in_binary64
567×distribute-lft-neg-in_binary64
414×distribute-neg-frac_binary64
414×unswap-sqr_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
053754
1146718
2429714
31735706
45854706
Stop Event
node limit
Counts
94 → 66
Calls
Call 1
Inputs
(*.f64 -1 y)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1 y))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y)))
(+.f64 (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(*.f64 -1 y)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1 y))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y)))
(+.f64 (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(/.f64 -1 y)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(*.f64 -1/2 x)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(*.f64 -1/2 x)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(/.f64 -1 y)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(*.f64 -1/2 x)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(*.f64 -1/2 x)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
Outputs
(*.f64 -1 y)
(neg.f64 y)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1 y))
(fma.f64 1/2 (*.f64 (*.f64 y y) x) (neg.f64 y))
(fma.f64 1/2 (*.f64 y (*.f64 y x)) (neg.f64 y))
(fma.f64 (*.f64 y y) (*.f64 1/2 x) (neg.f64 y))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y)))
(fma.f64 1/2 (*.f64 (*.f64 y y) x) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y)))
(-.f64 (fma.f64 1/2 (*.f64 y (*.f64 y x)) (*.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)))) y)
(-.f64 (*.f64 x (+.f64 (*.f64 y (*.f64 y 1/2)) (*.f64 (pow.f64 y 3) (*.f64 -1/4 x)))) y)
(fma.f64 x (fma.f64 y (*.f64 y 1/2) (*.f64 x (*.f64 -1/4 (pow.f64 y 3)))) (neg.f64 y))
(+.f64 (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y))))
(fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (fma.f64 1/2 (*.f64 (*.f64 y y) x) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y))))
(fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (-.f64 (fma.f64 1/2 (*.f64 y (*.f64 y x)) (*.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)))) y))
(-.f64 (fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (*.f64 x (+.f64 (*.f64 y (*.f64 y 1/2)) (*.f64 (pow.f64 y 3) (*.f64 -1/4 x))))) y)
(-.f64 (fma.f64 x (fma.f64 y (*.f64 y 1/2) (*.f64 x (*.f64 -1/4 (pow.f64 y 3)))) (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)))) y)
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 2 x))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 y (*.f64 y (pow.f64 x 3))))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 y (*.f64 y (pow.f64 x 3)))))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 2 x))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 y (*.f64 y (pow.f64 x 3))))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 y (*.f64 y (pow.f64 x 3)))))))
(*.f64 -1 y)
(neg.f64 y)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1 y))
(fma.f64 1/2 (*.f64 (*.f64 y y) x) (neg.f64 y))
(fma.f64 1/2 (*.f64 y (*.f64 y x)) (neg.f64 y))
(fma.f64 (*.f64 y y) (*.f64 1/2 x) (neg.f64 y))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y)))
(fma.f64 1/2 (*.f64 (*.f64 y y) x) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y)))
(-.f64 (fma.f64 1/2 (*.f64 y (*.f64 y x)) (*.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)))) y)
(-.f64 (*.f64 x (+.f64 (*.f64 y (*.f64 y 1/2)) (*.f64 (pow.f64 y 3) (*.f64 -1/4 x)))) y)
(fma.f64 x (fma.f64 y (*.f64 y 1/2) (*.f64 x (*.f64 -1/4 (pow.f64 y 3)))) (neg.f64 y))
(+.f64 (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y))))
(fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (fma.f64 1/2 (*.f64 (*.f64 y y) x) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y))))
(fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (-.f64 (fma.f64 1/2 (*.f64 y (*.f64 y x)) (*.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)))) y))
(-.f64 (fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (*.f64 x (+.f64 (*.f64 y (*.f64 y 1/2)) (*.f64 (pow.f64 y 3) (*.f64 -1/4 x))))) y)
(-.f64 (fma.f64 x (fma.f64 y (*.f64 y 1/2) (*.f64 x (*.f64 -1/4 (pow.f64 y 3)))) (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)))) y)
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 2 x))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 y (*.f64 y (pow.f64 x 3))))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 y (*.f64 y (pow.f64 x 3)))))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 2 x))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 y (*.f64 y (pow.f64 x 3))))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 y (*.f64 y (pow.f64 x 3)))))))
(/.f64 -1 y)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(*.f64 -1/2 x)
(*.f64 x -1/2)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(*.f64 -1/2 x)
(*.f64 x -1/2)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(/.f64 -1 y)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(*.f64 -1/2 x)
(*.f64 x -1/2)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(*.f64 -1/2 x)
(*.f64 x -1/2)
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
(-.f64 (*.f64 x -1/2) (/.f64 1 y))
(fma.f64 x -1/2 (/.f64 -1 y))

localize22.0ms (0.7%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(/.f64 (*.f64 x y) 2)
7.5b
(/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2)))
Compiler

Compiled 41 to 22 computations (46.3% saved)

series15.0ms (0.5%)

Counts
2 → 48
Calls

12 calls:

TimeVariablePointExpression
2.0ms
y
@inf
(/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2)))
2.0ms
y
@-inf
(/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2)))
1.0ms
x
@inf
(/.f64 (*.f64 x y) 2)
1.0ms
y
@0
(/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2)))
1.0ms
y
@0
(/.f64 (*.f64 x y) 2)

rewrite104.0ms (3.2%)

Algorithm
batch-egg-rewrite
Rules
460×log-prod_binary64
347×exp-prod_binary64
283×pow-prod-down_binary64
265×prod-diff_binary64
245×pow2_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0920
119818
2265118
Stop Event
node limit
Counts
2 → 104
Calls
Call 1
Inputs
(/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2)))
(/.f64 (*.f64 x y) 2)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))) 2)) (log.f64 (cbrt.f64 (exp.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (exp.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))) (log.f64 (sqrt.f64 (exp.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 y (/.f64 1 (fma.f64 x (*.f64 y 1/2) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 y y)) (*.f64 (cbrt.f64 y) (/.f64 1 (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))) (cbrt.f64 (pow.f64 (/.f64 (fma.f64 x (*.f64 y 1/2) 1) y) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (fma.f64 x (*.f64 y 1/2) 1) y) -2)) (cbrt.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 y) (*.f64 (sqrt.f64 y) (/.f64 1 (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))) (sqrt.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (neg.f64 y) (/.f64 1 (neg.f64 (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 x (*.f64 y 1/2) 1)) y)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 y y)) 1) (/.f64 (cbrt.f64 y) (fma.f64 x (*.f64 y 1/2) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) 1) (/.f64 (sqrt.f64 y) (fma.f64 x (*.f64 y 1/2) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 x (*.f64 y 1/2) 1)) -2) (/.f64 y (cbrt.f64 (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 y y)) (pow.f64 (cbrt.f64 (fma.f64 x (*.f64 y 1/2) 1)) 2)) (cbrt.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (sqrt.f64 y) (pow.f64 (cbrt.f64 (fma.f64 x (*.f64 y 1/2) 1)) 2)) (/.f64 (sqrt.f64 y) (cbrt.f64 (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (fma.f64 x (*.f64 y 1/2) 1) -1/2) (/.f64 y (sqrt.f64 (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 (cbrt.f64 (*.f64 y y)) (sqrt.f64 (fma.f64 x (*.f64 y 1/2) 1))) (/.f64 (cbrt.f64 y) (sqrt.f64 (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 y (fma.f64 (pow.f64 (*.f64 y x) 3) 1/8 1)) (fma.f64 (*.f64 y (*.f64 x 1/2)) (fma.f64 (/.f64 x 2) y -1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 y (-.f64 1 (pow.f64 (/.f64 (/.f64 2 y) x) -2))) (-.f64 1 (*.f64 y (*.f64 x 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (fma.f64 x (*.f64 y 1/2) 1) y) -2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (fma.f64 x (*.f64 y 1/2) 1) y) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (pow.f64 y 3) (pow.f64 (fma.f64 x (*.f64 y 1/2) 1) 3)) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (fma.f64 x (*.f64 y 1/2) 1) y) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))) 2)) (cbrt.f64 (log.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))) (sqrt.f64 (log.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 y (neg.f64 (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (fma.f64 x (*.f64 y 1/2) 1) y) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (/.f64 (pow.f64 y 3) (pow.f64 (fma.f64 x (*.f64 y 1/2) 1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)) 3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (fma.f64 x (*.f64 y 1/2) 1) y)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (/.f64 y (fma.f64 x (*.f64 y 1/2) 1))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log.f64 y) 1) (log1p.f64 (*.f64 y (*.f64 x 1/2)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (log.f64 y) (*.f64 (log1p.f64 (*.f64 y (*.f64 x 1/2))) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log.f64 y) 1) (*.f64 (log1p.f64 (*.f64 y (*.f64 x 1/2))) 1)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (*.f64 y (*.f64 x 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (sqrt.f64 (pow.f64 (exp.f64 y) x))) 2)) (log.f64 (cbrt.f64 (sqrt.f64 (pow.f64 (exp.f64 y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (sqrt.f64 (pow.f64 (exp.f64 y) x)))) (log.f64 (sqrt.f64 (sqrt.f64 (pow.f64 (exp.f64 y) x)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (fma.f64 x (*.f64 y 1/2) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 y (*.f64 x 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (*.f64 y (*.f64 x 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (/.f64 1 (/.f64 2 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 x (*.f64 y 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y x) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y (*.f64 x 1/2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (*.f64 y x)) 2) (*.f64 (cbrt.f64 (*.f64 y x)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 y (*.f64 x 1/2))) (cbrt.f64 (pow.f64 (/.f64 (/.f64 2 y) x) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (/.f64 (/.f64 2 y) x) -2)) (cbrt.f64 (*.f64 y (*.f64 x 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 y x)) (*.f64 (sqrt.f64 (*.f64 y x)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 y (*.f64 x 1/2))) (sqrt.f64 (*.f64 y (*.f64 x 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (*.f64 y (neg.f64 x)) -1/2)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/2 (*.f64 y x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 x 2) y)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 y (*.f64 x 1/2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (E.f64) (log.f64 (*.f64 y (*.f64 x 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (/.f64 2 y) x) -2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 y (*.f64 x 1/2))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 y (*.f64 x 1/2))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 (/.f64 2 y) x) -3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 2 y) x) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 (/.f64 (/.f64 2 y) x) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (*.f64 y (*.f64 x 1/2)))) 2)) (cbrt.f64 (log.f64 (*.f64 y (*.f64 x 1/2)))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log.f64 (*.f64 y (*.f64 x 1/2))))) (sqrt.f64 (log.f64 (*.f64 y (*.f64 x 1/2)))))))) (#(struct:change #<rule egg-rr> (2) ((x neg.f64 (/.f64 (*.f64 y x) -2))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (/.f64 (/.f64 2 y) x) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (sqrt.f64 (pow.f64 (exp.f64 y) x)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 y (*.f64 x 1/2)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 (/.f64 2 y) x) -3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 y (*.f64 x 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (*.f64 (log1p.f64 (*.f64 y (*.f64 x 1/2))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 y (*.f64 x 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 y (*.f64 x 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 y (*.f64 x 1/2))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (cbrt.f64 (*.f64 y (*.f64 x 1/2)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 y (*.f64 x 1/2)))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (pow.f64 (/.f64 (/.f64 2 y) x) -3)) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (/.f64 (/.f64 2 y) x)) -1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 y (*.f64 x 1/2))) 1) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (*.f64 (log.f64 (*.f64 y (*.f64 x 1/2))) 3) 1/3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (-.f64 (*.f64 (log.f64 x) 1) (log.f64 (/.f64 2 y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (fma.f64 x (*.f64 y 1/2) 1) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 x (*.f64 y 1/2) 1) 1 -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (fma.f64 x (*.f64 y 1/2) 1)) (pow.f64 (cbrt.f64 (fma.f64 x (*.f64 y 1/2) 1)) 2) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (fma.f64 x (*.f64 y 1/2) 1)) 2) (cbrt.f64 (fma.f64 x (*.f64 y 1/2) 1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (fma.f64 x (*.f64 y 1/2) 1)) (sqrt.f64 (fma.f64 x (*.f64 y 1/2) 1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (fma.f64 (pow.f64 (*.f64 y x) 3) 1/8 1) (/.f64 1 (fma.f64 (*.f64 y (*.f64 x 1/2)) (fma.f64 (/.f64 x 2) y -1) 1)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (-.f64 1 (pow.f64 (/.f64 (/.f64 2 y) x) -2)) (/.f64 1 (-.f64 1 (*.f64 y (*.f64 x 1/2)))) -1)))))

simplify84.0ms (2.6%)

Algorithm
egg-herbie
Rules
780×fma-def_binary64
675×fma-neg_binary64
673×cancel-sign-sub-inv_binary64
526×distribute-neg-frac_binary64
414×unswap-sqr_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
049714
1142706
2429702
31719690
45293690
Stop Event
node limit
Counts
152 → 118
Calls
Call 1
Inputs
y
(+.f64 y (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (+.f64 y (*.f64 -1/2 (*.f64 (pow.f64 y 2) x))))
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (+.f64 y (+.f64 (*.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))))
(/.f64 2 x)
(-.f64 (*.f64 2 (/.f64 1 x)) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))))
(/.f64 2 x)
(-.f64 (*.f64 2 (/.f64 1 x)) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))))
y
(+.f64 y (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (+.f64 y (*.f64 -1/2 (*.f64 (pow.f64 y 2) x))))
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (+.f64 y (+.f64 (*.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))))
(/.f64 2 x)
(-.f64 (*.f64 2 (/.f64 1 x)) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))))
(/.f64 2 x)
(-.f64 (*.f64 2 (/.f64 1 x)) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
(*.f64 1/2 (*.f64 y x))
Outputs
y
(+.f64 y (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))
(+.f64 y (*.f64 -1/2 (*.f64 (*.f64 y y) x)))
(fma.f64 -1/2 (*.f64 y (*.f64 y x)) y)
(fma.f64 x (*.f64 y (*.f64 y -1/2)) y)
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (+.f64 y (*.f64 -1/2 (*.f64 (pow.f64 y 2) x))))
(fma.f64 1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (+.f64 y (*.f64 -1/2 (*.f64 (*.f64 y y) x))))
(fma.f64 1/4 (*.f64 x (*.f64 x (pow.f64 y 3))) (fma.f64 -1/2 (*.f64 y (*.f64 y x)) y))
(fma.f64 -1/2 (*.f64 y (*.f64 y x)) (fma.f64 1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) y))
(fma.f64 x (fma.f64 y (*.f64 y -1/2) (*.f64 1/4 (*.f64 x (pow.f64 y 3)))) y)
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (+.f64 y (+.f64 (*.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))))
(fma.f64 1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (+.f64 y (fma.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (*.f64 -1/2 (*.f64 (*.f64 y y) x)))))
(+.f64 (fma.f64 1/4 (*.f64 x (*.f64 x (pow.f64 y 3))) (fma.f64 -1/2 (*.f64 y (*.f64 y x)) y)) (*.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))))
(fma.f64 1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (fma.f64 -1/2 (*.f64 y (*.f64 y x)) (fma.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) y)))
(fma.f64 x (fma.f64 y (*.f64 y -1/2) (*.f64 1/4 (*.f64 x (pow.f64 y 3)))) (fma.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) y))
(/.f64 2 x)
(-.f64 (*.f64 2 (/.f64 1 x)) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (/.f64 2 x) (/.f64 4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (/.f64 -4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (/.f64 (/.f64 -4 y) (*.f64 x x)))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (-.f64 (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))) (/.f64 4 (*.f64 y (*.f64 x x)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 -4 y) (*.f64 x x))) (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3))) (/.f64 -4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (+.f64 (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3)) (/.f64 -4 (*.f64 y (*.f64 x x)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))))
(-.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(+.f64 (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))) (-.f64 (-.f64 (/.f64 2 x) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (/.f64 4 (*.f64 y (*.f64 x x)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3))))) (-.f64 (/.f64 (/.f64 -4 y) (*.f64 x x)) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3))) (-.f64 (/.f64 -4 (*.f64 y (*.f64 x x))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(/.f64 2 x)
(-.f64 (*.f64 2 (/.f64 1 x)) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (/.f64 2 x) (/.f64 4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (/.f64 -4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (/.f64 (/.f64 -4 y) (*.f64 x x)))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (-.f64 (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))) (/.f64 4 (*.f64 y (*.f64 x x)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 -4 y) (*.f64 x x))) (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3))) (/.f64 -4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (+.f64 (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3)) (/.f64 -4 (*.f64 y (*.f64 x x)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))))
(-.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(+.f64 (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))) (-.f64 (-.f64 (/.f64 2 x) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (/.f64 4 (*.f64 y (*.f64 x x)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3))))) (-.f64 (/.f64 (/.f64 -4 y) (*.f64 x x)) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3))) (-.f64 (/.f64 -4 (*.f64 y (*.f64 x x))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
y
(+.f64 y (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))
(+.f64 y (*.f64 -1/2 (*.f64 (*.f64 y y) x)))
(fma.f64 -1/2 (*.f64 y (*.f64 y x)) y)
(fma.f64 x (*.f64 y (*.f64 y -1/2)) y)
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (+.f64 y (*.f64 -1/2 (*.f64 (pow.f64 y 2) x))))
(fma.f64 1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (+.f64 y (*.f64 -1/2 (*.f64 (*.f64 y y) x))))
(fma.f64 1/4 (*.f64 x (*.f64 x (pow.f64 y 3))) (fma.f64 -1/2 (*.f64 y (*.f64 y x)) y))
(fma.f64 -1/2 (*.f64 y (*.f64 y x)) (fma.f64 1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) y))
(fma.f64 x (fma.f64 y (*.f64 y -1/2) (*.f64 1/4 (*.f64 x (pow.f64 y 3)))) y)
(+.f64 (*.f64 1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (+.f64 y (+.f64 (*.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (*.f64 -1/2 (*.f64 (pow.f64 y 2) x)))))
(fma.f64 1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (+.f64 y (fma.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (*.f64 -1/2 (*.f64 (*.f64 y y) x)))))
(+.f64 (fma.f64 1/4 (*.f64 x (*.f64 x (pow.f64 y 3))) (fma.f64 -1/2 (*.f64 y (*.f64 y x)) y)) (*.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))))
(fma.f64 1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (fma.f64 -1/2 (*.f64 y (*.f64 y x)) (fma.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) y)))
(fma.f64 x (fma.f64 y (*.f64 y -1/2) (*.f64 1/4 (*.f64 x (pow.f64 y 3)))) (fma.f64 -1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) y))
(/.f64 2 x)
(-.f64 (*.f64 2 (/.f64 1 x)) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (/.f64 2 x) (/.f64 4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (/.f64 -4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (/.f64 (/.f64 -4 y) (*.f64 x x)))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (-.f64 (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))) (/.f64 4 (*.f64 y (*.f64 x x)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 -4 y) (*.f64 x x))) (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3))) (/.f64 -4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (+.f64 (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3)) (/.f64 -4 (*.f64 y (*.f64 x x)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))))
(-.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(+.f64 (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))) (-.f64 (-.f64 (/.f64 2 x) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (/.f64 4 (*.f64 y (*.f64 x x)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3))))) (-.f64 (/.f64 (/.f64 -4 y) (*.f64 x x)) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3))) (-.f64 (/.f64 -4 (*.f64 y (*.f64 x x))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(/.f64 2 x)
(-.f64 (*.f64 2 (/.f64 1 x)) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (/.f64 2 x) (/.f64 4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (/.f64 -4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (/.f64 (/.f64 -4 y) (*.f64 x x)))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))))
(-.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (-.f64 (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))) (/.f64 4 (*.f64 y (*.f64 x x)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 -4 y) (*.f64 x x))) (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3))) (/.f64 -4 (*.f64 y (*.f64 x x))))
(+.f64 (/.f64 2 x) (+.f64 (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3)) (/.f64 -4 (*.f64 y (*.f64 x x)))))
(-.f64 (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))) (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))))
(-.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(+.f64 (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3)))) (-.f64 (-.f64 (/.f64 2 x) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (/.f64 4 (*.f64 y (*.f64 x x)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 y (*.f64 y (pow.f64 x 3))))) (-.f64 (/.f64 (/.f64 -4 y) (*.f64 x x)) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(+.f64 (+.f64 (/.f64 2 x) (/.f64 (/.f64 8 (*.f64 y y)) (pow.f64 x 3))) (-.f64 (/.f64 -4 (*.f64 y (*.f64 x x))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))
(*.f64 1/2 (*.f64 y x))
(*.f64 y (*.f64 x 1/2))
(*.f64 x (*.f64 y 1/2))

eval98.0ms (3%)

Compiler

Compiled 3010 to 2108 computations (30% saved)

prune43.0ms (1.3%)

Pruning

5 alts after pruning (4 fresh and 1 done)

PrunedKeptTotal
New1804184
Fresh000
Picked011
Done101
Total1815186
Error
0.0b
Counts
186 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 x (/.f64 1 (-.f64 (*.f64 -1/2 x) (/.f64 1 y))))
0.1b
(-.f64 x (/.f64 y (+.f64 1 (pow.f64 (cbrt.f64 (*.f64 y (*.f64 x 1/2))) 3))))
23.2b
(-.f64 x (/.f64 2 x))
0.0b
(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
17.2b
(-.f64 x y)
Compiler

Compiled 54 to 39 computations (27.8% saved)

localize27.0ms (0.8%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
0.1b
(/.f64 1 (-.f64 (*.f64 -1/2 x) (/.f64 1 y)))
Compiler

Compiled 39 to 28 computations (28.2% saved)

series9.0ms (0.3%)

Counts
2 → 30
Calls

12 calls:

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

rewrite96.0ms (3%)

Algorithm
batch-egg-rewrite
Rules
964×pow1_binary64
895×add-log-exp_binary64
895×log1p-expm1-u_binary64
895×expm1-log1p-u_binary64
98×add-sqr-sqrt_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0923
119519
2251319
Stop Event
node limit
Counts
2 → 66
Calls
Call 1
Inputs
(/.f64 1 (-.f64 (*.f64 -1/2 x) (/.f64 1 y)))
(-.f64 (*.f64 -1/2 x) (/.f64 1 y))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y)))) (cbrt.f64 (pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) -2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) -2)) (/.f64 1 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) -1/2) (pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 -1 (/.f64 1 (neg.f64 (fma.f64 -1/2 x (/.f64 -1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) 2) -1) (pow.f64 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (sqrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) -1) (pow.f64 (sqrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) -1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (-.f64 (*.f64 -1/8 (pow.f64 x 3)) (pow.f64 y -3))) (+.f64 (+.f64 (*.f64 1/4 (*.f64 x x)) (pow.f64 y -2)) (/.f64 (*.f64 -1/2 x) y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (/.f64 1 (-.f64 (*.f64 1/4 (*.f64 x x)) (pow.f64 y -2))) (fma.f64 -1/2 x (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) -1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (/.f64 1 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) -1/2) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) -2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (neg.f64 (log.f64 (fma.f64 -1/2 x (/.f64 -1 y)))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 -1/2 x) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 -1/2 x) (*.f64 (/.f64 -1 y) 1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 -1/2 x (/.f64 -1 y)) (fma.f64 (/.f64 -1 y) 1 (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 -1/2 x (/.f64 -1 y)) (fma.f64 (neg.f64 (/.f64 1 (cbrt.f64 y))) (cbrt.f64 (pow.f64 y -2)) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (fma.f64 -1/2 x (/.f64 -1 y)) (fma.f64 (neg.f64 (pow.f64 y -1/2)) (pow.f64 y -1/2) (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (/.f64 -1 y) (*.f64 -1/2 x))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 -1/2 x (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 -1/2 x (/.f64 -1 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) (pow.f64 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) 2) (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) (sqrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 -1/8 (pow.f64 x 3)) (pow.f64 y -3)) (/.f64 1 (+.f64 (+.f64 (*.f64 1/4 (*.f64 x x)) (pow.f64 y -2)) (/.f64 (*.f64 -1/2 x) y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (-.f64 (*.f64 1/4 (*.f64 x x)) (pow.f64 y -2)) (/.f64 1 (fma.f64 -1/2 x (/.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (sqrt.f64 (*.f64 -1/2 x)) (pow.f64 y -1/2)) (-.f64 (sqrt.f64 (*.f64 -1/2 x)) (pow.f64 y -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 1 (fma.f64 -1/2 x (/.f64 -1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (+.f64 (*.f64 1/4 (*.f64 x x)) (pow.f64 y -2)) (/.f64 (*.f64 -1/2 x) y)) (-.f64 (*.f64 -1/8 (pow.f64 x 3)) (pow.f64 y -3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 -1/2 x (/.f64 1 y)) (-.f64 (*.f64 1/4 (*.f64 x x)) (pow.f64 y -2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (fma.f64 -1/2 x (/.f64 -1 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (pow.f64 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) 2) (/.f64 1 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (sqrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) (pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (fma.f64 -1/2 x (/.f64 -1 y))) -1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 -1/8 (pow.f64 x 3)) (pow.f64 y -3)) (+.f64 (+.f64 (*.f64 1/4 (*.f64 x x)) (pow.f64 y -2)) (/.f64 (*.f64 -1/2 x) y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 1/4 (*.f64 x x)) (pow.f64 y -2)) (fma.f64 -1/2 x (/.f64 1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (*.f64 -1/8 (pow.f64 x 3)) (pow.f64 y -3))) (neg.f64 (+.f64 (+.f64 (*.f64 1/4 (*.f64 x x)) (pow.f64 y -2)) (/.f64 (*.f64 -1/2 x) y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (-.f64 (*.f64 1/4 (*.f64 x x)) (pow.f64 y -2))) (neg.f64 (fma.f64 -1/2 x (/.f64 1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 -1/8 (pow.f64 x 3)) (pow.f64 (/.f64 -1 y) 3)) (+.f64 (*.f64 1/4 (*.f64 x x)) (-.f64 (*.f64 (/.f64 -1 y) (/.f64 -1 y)) (*.f64 (*.f64 -1/2 x) (/.f64 -1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 1/4 (*.f64 x x)) (*.f64 (/.f64 -1 y) (/.f64 -1 y))) (-.f64 (*.f64 -1/2 x) (/.f64 -1 y)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 -1/2 x (/.f64 -1 y))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 -1/2 x (/.f64 -1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 -1/2 x (/.f64 -1 y)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 -1/2 x (/.f64 -1 y)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 -1/2 x (/.f64 -1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 -1/2 x (/.f64 -1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 -1/2 x (/.f64 -1 y))))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 -1/2 x) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 -1/2 x (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 x -1/2 (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (pow.f64 (cbrt.f64 (*.f64 -1/2 x)) 2) (cbrt.f64 (*.f64 -1/2 x)) (/.f64 -1 y))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 -1/2 x)) (sqrt.f64 (*.f64 -1/2 x)) (/.f64 -1 y))))))

simplify86.0ms (2.7%)

Algorithm
egg-herbie
Rules
872×fma-def_binary64
663×distribute-rgt-neg-in_binary64
565×distribute-lft-neg-in_binary64
415×distribute-neg-frac_binary64
414×unswap-sqr_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
051574
1142574
2420570
31718562
45795562
Stop Event
node limit
Counts
96 → 84
Calls
Call 1
Inputs
(*.f64 -1 y)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1 y))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y)))
(+.f64 (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(*.f64 -1 y)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1 y))
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y)))
(+.f64 (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(/.f64 -1 y)
(*.f64 -1/2 x)
(*.f64 -1/2 x)
(/.f64 -1 y)
(*.f64 -1/2 x)
(*.f64 -1/2 x)
Outputs
(*.f64 -1 y)
(neg.f64 y)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1 y))
(fma.f64 1/2 (*.f64 (*.f64 y y) x) (neg.f64 y))
(fma.f64 1/2 (*.f64 y (*.f64 y x)) (neg.f64 y))
(-.f64 (*.f64 y (*.f64 x (*.f64 y 1/2))) y)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y)))
(fma.f64 1/2 (*.f64 (*.f64 y y) x) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y)))
(fma.f64 1/2 (*.f64 y (*.f64 y x)) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y)))
(-.f64 (*.f64 x (+.f64 (*.f64 y (*.f64 y 1/2)) (*.f64 x (*.f64 -1/4 (pow.f64 y 3))))) y)
(-.f64 (*.f64 x (fma.f64 y (*.f64 y 1/2) (*.f64 x (*.f64 -1/4 (pow.f64 y 3))))) y)
(+.f64 (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y))))
(fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (fma.f64 1/2 (*.f64 (*.f64 y y) x) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y))))
(fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (fma.f64 1/2 (*.f64 y (*.f64 y x)) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y))))
(fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (-.f64 (*.f64 x (+.f64 (*.f64 y (*.f64 y 1/2)) (*.f64 x (*.f64 -1/4 (pow.f64 y 3))))) y))
(fma.f64 x (fma.f64 y (*.f64 y 1/2) (*.f64 x (*.f64 -1/4 (pow.f64 y 3)))) (-.f64 (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) y))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 2 x))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (/.f64 -2 x))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (+.f64 (/.f64 -2 x) (/.f64 (/.f64 -8 (*.f64 y y)) (pow.f64 x 3))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (+.f64 (/.f64 (/.f64 16 (pow.f64 x 4)) (pow.f64 y 3)) (+.f64 (/.f64 -2 x) (/.f64 (/.f64 -8 (*.f64 y y)) (pow.f64 x 3)))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 2 x))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (/.f64 -2 x))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (+.f64 (/.f64 -2 x) (/.f64 (/.f64 -8 (*.f64 y y)) (pow.f64 x 3))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (+.f64 (/.f64 (/.f64 16 (pow.f64 x 4)) (pow.f64 y 3)) (+.f64 (/.f64 -2 x) (/.f64 (/.f64 -8 (*.f64 y y)) (pow.f64 x 3)))))
(*.f64 -1 y)
(neg.f64 y)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (*.f64 -1 y))
(fma.f64 1/2 (*.f64 (*.f64 y y) x) (neg.f64 y))
(fma.f64 1/2 (*.f64 y (*.f64 y x)) (neg.f64 y))
(-.f64 (*.f64 y (*.f64 x (*.f64 y 1/2))) y)
(+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y)))
(fma.f64 1/2 (*.f64 (*.f64 y y) x) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y)))
(fma.f64 1/2 (*.f64 y (*.f64 y x)) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y)))
(-.f64 (*.f64 x (+.f64 (*.f64 y (*.f64 y 1/2)) (*.f64 x (*.f64 -1/4 (pow.f64 y 3))))) y)
(-.f64 (*.f64 x (fma.f64 y (*.f64 y 1/2) (*.f64 x (*.f64 -1/4 (pow.f64 y 3))))) y)
(+.f64 (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) (+.f64 (*.f64 1/2 (*.f64 (pow.f64 y 2) x)) (+.f64 (*.f64 -1/4 (*.f64 (pow.f64 y 3) (pow.f64 x 2))) (*.f64 -1 y))))
(fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (fma.f64 1/2 (*.f64 (*.f64 y y) x) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y))))
(fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (fma.f64 1/2 (*.f64 y (*.f64 y x)) (fma.f64 -1/4 (*.f64 (pow.f64 y 3) (*.f64 x x)) (neg.f64 y))))
(fma.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3)) (-.f64 (*.f64 x (+.f64 (*.f64 y (*.f64 y 1/2)) (*.f64 x (*.f64 -1/4 (pow.f64 y 3))))) y))
(fma.f64 x (fma.f64 y (*.f64 y 1/2) (*.f64 x (*.f64 -1/4 (pow.f64 y 3)))) (-.f64 (*.f64 1/8 (*.f64 (pow.f64 y 4) (pow.f64 x 3))) y))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 2 x))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (/.f64 -2 x))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (+.f64 (/.f64 -2 x) (/.f64 (/.f64 -8 (*.f64 y y)) (pow.f64 x 3))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (+.f64 (/.f64 (/.f64 16 (pow.f64 x 4)) (pow.f64 y 3)) (+.f64 (/.f64 -2 x) (/.f64 (/.f64 -8 (*.f64 y y)) (pow.f64 x 3)))))
(/.f64 -2 x)
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (*.f64 2 (/.f64 1 x)))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 2 x))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (/.f64 -2 x))
(-.f64 (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2)))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3)))))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (+.f64 (/.f64 -2 x) (/.f64 (/.f64 -8 (*.f64 y y)) (pow.f64 x 3))))
(-.f64 (+.f64 (*.f64 16 (/.f64 1 (*.f64 (pow.f64 y 3) (pow.f64 x 4)))) (*.f64 4 (/.f64 1 (*.f64 y (pow.f64 x 2))))) (+.f64 (*.f64 8 (/.f64 1 (*.f64 (pow.f64 y 2) (pow.f64 x 3)))) (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (-.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 2 x) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (-.f64 (+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (/.f64 -2 x)) (/.f64 8 (*.f64 (*.f64 y y) (pow.f64 x 3)))) (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))))
(+.f64 (/.f64 4 (*.f64 y (*.f64 x x))) (+.f64 (/.f64 16 (*.f64 (pow.f64 y 3) (pow.f64 x 4))) (+.f64 (/.f64 -2 x) (/.f64 -8 (*.f64 (*.f64 y y) (pow.f64 x 3))))))
(+.f64 (/.f64 (/.f64 4 y) (*.f64 x x)) (+.f64 (/.f64 (/.f64 16 (pow.f64 x 4)) (pow.f64 y 3)) (+.f64 (/.f64 -2 x) (/.f64 (/.f64 -8 (*.f64 y y)) (pow.f64 x 3)))))
(/.f64 -1 y)
(*.f64 -1/2 x)
(*.f64 x -1/2)
(*.f64 -1/2 x)
(*.f64 x -1/2)
(/.f64 -1 y)
(*.f64 -1/2 x)
(*.f64 x -1/2)
(*.f64 -1/2 x)
(*.f64 x -1/2)

localize5.0ms (0.2%)

Compiler

Compiled 7 to 3 computations (57.1% saved)

localize10.0ms (0.3%)

Compiler

Compiled 12 to 8 computations (33.3% saved)

localize50.0ms (1.5%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.5b
(pow.f64 (cbrt.f64 (*.f64 y (*.f64 x 1/2))) 3)
7.5b
(/.f64 y (+.f64 1 (pow.f64 (cbrt.f64 (*.f64 y (*.f64 x 1/2))) 3)))
14.6b
(cbrt.f64 (*.f64 y (*.f64 x 1/2)))
Compiler

Compiled 65 to 47 computations (27.7% saved)

series27.0ms (0.8%)

Counts
3 → 6
Calls

18 calls:

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

rewrite115.0ms (3.5%)

Algorithm
batch-egg-rewrite
Rules
928×prod-diff_binary64
544×log-prod_binary64
381×fma-def_binary64
283×pow2_binary64
195×expm1-udef_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify13.0ms (0.4%)

Algorithm
egg-herbie
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
016
Stop Event
saturated
Counts
119 → 114
Calls
Call 1
Inputs
y
y
y
y
y
y
Outputs
y
y
y
y
y
y

eval112.0ms (3.4%)

Compiler

Compiled 3422 to 2364 computations (30.9% saved)

prune46.0ms (1.4%)

Pruning

5 alts after pruning (0 fresh and 5 done)

PrunedKeptTotal
New1980198
Fresh000
Picked011
Done044
Total1985203
Error
0.0b
Counts
203 → 5
Alt Table
Click to see full alt table
StatusErrorProgram
0.1b
(+.f64 x (/.f64 1 (-.f64 (*.f64 -1/2 x) (/.f64 1 y))))
0.1b
(-.f64 x (/.f64 y (+.f64 1 (pow.f64 (cbrt.f64 (*.f64 y (*.f64 x 1/2))) 3))))
23.2b
(-.f64 x (/.f64 2 x))
0.0b
(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
17.2b
(-.f64 x y)
Compiler

Compiled 54 to 39 computations (27.8% saved)

regimes30.0ms (0.9%)

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

3 calls:

9.0ms
(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
9.0ms
y
8.0ms
x
Results
ErrorSegmentsBranch
0.0b1x
0.0b1y
0.0b1(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
Compiler

Compiled 75 to 51 computations (32% saved)

regimes34.0ms (1%)

Counts
3 → 1
Calls
Call 1
Inputs
(-.f64 x y)
(-.f64 x (/.f64 2 x))
(+.f64 x (/.f64 1 (-.f64 (*.f64 -1/2 x) (/.f64 1 y))))
Outputs
(+.f64 x (/.f64 1 (-.f64 (*.f64 -1/2 x) (/.f64 1 y))))
Calls

2 calls:

26.0ms
y
6.0ms
x
Results
ErrorSegmentsBranch
0.1b1x
0.1b1y
Compiler

Compiled 27 to 18 computations (33.3% saved)

regimes186.0ms (5.7%)

Accuracy

Total -34.3b remaining (-687.9%)

Threshold costs -34.3b (-687.9%)

Counts
2 → 3
Calls
Call 1
Inputs
(-.f64 x y)
(-.f64 x (/.f64 2 x))
Outputs
(-.f64 x (/.f64 2 x))
(-.f64 x y)
(-.f64 x (/.f64 2 x))
Calls

2 calls:

168.0ms
x
15.0ms
y
Results
ErrorSegmentsBranch
7.1b3x
5.0b3y
Compiler

Compiled 16 to 10 computations (37.5% saved)

bsearch78.0ms (2.4%)

Algorithm
binary-search
Steps
TimeLeftRight
48.0ms
7.311240477678702e+125
5.442935445952627e+129
30.0ms
-2.555489753483215e+105
-3.768947900436278e+102
Compiler

Compiled 18 to 13 computations (27.8% saved)

simplify10.0ms (0.3%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
02666
14066
25966
36766
47166
Stop Event
done
saturated
Calls
Call 1
Inputs
(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
(+.f64 x (/.f64 1 (-.f64 (*.f64 -1/2 x) (/.f64 1 y))))
(if (<=.f64 y -2555489753483215224182715441191640616188263760224286004705176019693357190010578681050586604441217636761600) (-.f64 x (/.f64 2 x)) (if (<=.f64 y 731124047767870166823165564739759513065183449471097802737749120347865980396104245945739694777395665471156384315199045448499200) (-.f64 x y) (-.f64 x (/.f64 2 x))))
(-.f64 x y)
Outputs
(-.f64 x (/.f64 y (+.f64 1 (/.f64 (*.f64 x y) 2))))
(+.f64 x (/.f64 1 (-.f64 (*.f64 -1/2 x) (/.f64 1 y))))
(+.f64 x (/.f64 1 (-.f64 (*.f64 x -1/2) (/.f64 1 y))))
(+.f64 x (/.f64 1 (+.f64 (*.f64 x -1/2) (/.f64 -1 y))))
(if (<=.f64 y -2555489753483215224182715441191640616188263760224286004705176019693357190010578681050586604441217636761600) (-.f64 x (/.f64 2 x)) (if (<=.f64 y 731124047767870166823165564739759513065183449471097802737749120347865980396104245945739694777395665471156384315199045448499200) (-.f64 x y) (-.f64 x (/.f64 2 x))))
(if (<=.f64 y -2555489753483215224182715441191640616188263760224286004705176019693357190010578681050586604441217636761600) (+.f64 x (/.f64 -2 x)) (if (<=.f64 y 731124047767870166823165564739759513065183449471097802737749120347865980396104245945739694777395665471156384315199045448499200) (-.f64 x y) (+.f64 x (/.f64 -2 x))))
(-.f64 x y)
Compiler

Compiled 54 to 37 computations (31.5% saved)

soundness0.0ms (0%)

end206.0ms (6.4%)

Compiler

Compiled 48 to 30 computations (37.5% saved)

Profiling

Loading profile data...