Details

Time bar (total: 4.4s)

analyze75.0ms (1.7%)

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
18.7%81.2%0.1%5
28.1%71.8%0.1%6
39%60.9%0.1%7
52.3%47.6%0.1%8
67.5%32.4%0.1%9
74.7%25.2%0.1%10
83.2%16.7%0.1%11
87%12.9%0.1%12
Compiler

Compiled 12 to 8 computations (33.3% saved)

sample1.1s (25.5%)

Results
1.1s8255×body256valid
0.0msbody1024valid

preprocess132.0ms (3%)

Algorithm
egg-herbie
Rules
1210×fma-neg_binary64
554×div-sub_binary64
400×sub-neg_binary64
367×associate-/l*_binary64
357×associate-/l/_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01226
13326
25426
310626
422826
546426
6125826
7357026
8599826
9687026
10740526
11760726
12771126
022
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(/.f64 (-.f64 x y) (-.f64 2 (+.f64 x y)))
(/.f64 (-.f64 y x) (-.f64 2 (+.f64 y x)))
Outputs
(/.f64 (-.f64 x y) (-.f64 2 (+.f64 x y)))
(/.f64 (-.f64 y x) (-.f64 2 (+.f64 y x)))
(/.f64 (-.f64 y x) (-.f64 2 (+.f64 x y)))
(/.f64 (-.f64 x y) (+.f64 x (+.f64 y -2)))
Compiler

Compiled 13 to 9 computations (30.8% saved)

simplify136.0ms (3.1%)

Algorithm
egg-herbie
Rules
1142×fma-neg_binary64
983×fma-def_binary64
651×div-sub_binary64
413×sub-neg_binary64
386×distribute-rgt-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0813
11813
23513
37713
418813
535713
688613
7239613
8474413
9656713
10714413
11752813
12759613
13761613
Stop Event
node limit
Counts
1 → 2
Calls
Call 1
Inputs
(/.f64 (-.f64 x y) (-.f64 2 (+.f64 x y)))
Outputs
(/.f64 (-.f64 x y) (-.f64 2 (+.f64 x y)))
(/.f64 (-.f64 x y) (-.f64 (-.f64 2 x) y))

eval1.0ms (0%)

Compiler

Compiled 20 to 11 computations (45% saved)

prune1.0ms (0%)

Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New112
Fresh101
Picked000
Done000
Total213
Error
0.0b
Counts
3 → 1
Alt Table
Click to see full alt table
StatusErrorProgram
0.0b
(/.f64 (-.f64 x y) (-.f64 (-.f64 2 x) y))
Compiler

Compiled 11 to 7 computations (36.4% saved)

localize10.0ms (0.2%)

Local error

Found 1 expressions with local error:

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

Compiled 25 to 13 computations (48% saved)

series5.0ms (0.1%)

Counts
1 → 24
Calls

6 calls:

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

rewrite67.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
520×log-prod_binary64
392×fma-def_binary64
334×pow-prod-down_binary64
289×pow2_binary64
199×pow1/3_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify71.0ms (1.6%)

Algorithm
egg-herbie
Rules
593×div-sub_binary64
464×fma-def_binary64
394×times-frac_binary64
305×associate-/l*_binary64
302×associate-*r*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
0109865
1343807
21252693
37180693
Stop Event
node limit
Counts
85 → 96
Calls
Call 1
Inputs
(*.f64 -1 (/.f64 y (-.f64 2 y)))
(+.f64 (*.f64 -1 (/.f64 y (-.f64 2 y))) (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x))
(+.f64 (*.f64 -1 (/.f64 y (-.f64 2 y))) (+.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x) (/.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (pow.f64 x 2)) (-.f64 2 y))))
(+.f64 (/.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (pow.f64 x 3)) (pow.f64 (-.f64 2 y) 2)) (+.f64 (*.f64 -1 (/.f64 y (-.f64 2 y))) (+.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x) (/.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (pow.f64 x 2)) (-.f64 2 y)))))
-1
(-.f64 (*.f64 2 (/.f64 y x)) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (-.f64 2 y)) (pow.f64 x 2)) (*.f64 2 (/.f64 y x))) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (-.f64 2 y)) (pow.f64 x 2)) (+.f64 (*.f64 2 (/.f64 y x)) (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (pow.f64 (-.f64 2 y) 2)) (pow.f64 x 3)))) (+.f64 1 (*.f64 2 (/.f64 1 x))))
-1
(-.f64 (*.f64 2 (/.f64 y x)) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (-.f64 2 y)) (pow.f64 x 2)) (*.f64 2 (/.f64 y x))) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(-.f64 (+.f64 (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (-.f64 2 y)) (pow.f64 x 2)) (+.f64 (*.f64 2 (/.f64 y x)) (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (pow.f64 (-.f64 2 y) 2)) (pow.f64 x 3)))) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(/.f64 x (-.f64 2 x))
(+.f64 (/.f64 x (-.f64 2 x)) (*.f64 -1 (*.f64 (+.f64 (/.f64 1 (-.f64 2 x)) (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 2)))) y)))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (/.f64 1 (pow.f64 (-.f64 2 x) 2)) (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 3)))) (pow.f64 y 2))) (+.f64 (/.f64 x (-.f64 2 x)) (*.f64 -1 (*.f64 (+.f64 (/.f64 1 (-.f64 2 x)) (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 2)))) y))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (/.f64 1 (pow.f64 (-.f64 2 x) 2)) (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 3)))) (pow.f64 y 2))) (+.f64 (/.f64 x (-.f64 2 x)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 y 3) (+.f64 (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 4))) (/.f64 1 (pow.f64 (-.f64 2 x) 3))))) (*.f64 -1 (*.f64 (+.f64 (/.f64 1 (-.f64 2 x)) (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 2)))) y)))))
1
(-.f64 (+.f64 1 (*.f64 -1 (/.f64 x y))) (*.f64 -1 (/.f64 (-.f64 2 x) y)))
(-.f64 (+.f64 1 (+.f64 (/.f64 (*.f64 (-.f64 (*.f64 -1 x) (*.f64 -1 (-.f64 2 x))) (-.f64 2 x)) (pow.f64 y 2)) (*.f64 -1 (/.f64 x y)))) (*.f64 -1 (/.f64 (-.f64 2 x) y)))
(-.f64 (+.f64 (/.f64 (*.f64 (-.f64 2 x) (-.f64 (*.f64 -1 x) (*.f64 -1 (-.f64 2 x)))) (pow.f64 y 2)) (+.f64 1 (+.f64 (*.f64 -1 (/.f64 x y)) (/.f64 (*.f64 (-.f64 (*.f64 -1 x) (*.f64 -1 (-.f64 2 x))) (pow.f64 (-.f64 2 x) 2)) (pow.f64 y 3))))) (*.f64 -1 (/.f64 (-.f64 2 x) y)))
1
(+.f64 1 (*.f64 -1 (/.f64 (-.f64 (*.f64 2 x) 2) y)))
(+.f64 1 (+.f64 (*.f64 -1 (/.f64 (-.f64 (*.f64 2 x) 2) y)) (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 2 x) 2) (-.f64 2 x)) (pow.f64 y 2)))))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 2 x) 2) (pow.f64 (-.f64 2 x) 2)) (pow.f64 y 3))) (+.f64 1 (+.f64 (*.f64 -1 (/.f64 (-.f64 (*.f64 2 x) 2) y)) (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 2 x) 2) (-.f64 2 x)) (pow.f64 y 2))))))
Outputs
(*.f64 -1 (/.f64 y (-.f64 2 y)))
(neg.f64 (/.f64 y (-.f64 2 y)))
(/.f64 (neg.f64 y) (-.f64 2 y))
(+.f64 (*.f64 -1 (/.f64 y (-.f64 2 y))) (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x))
(fma.f64 -1 (/.f64 y (-.f64 2 y)) (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x))
(-.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x) (/.f64 y (-.f64 2 y)))
(+.f64 (*.f64 -1 (/.f64 y (-.f64 2 y))) (+.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x) (/.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (pow.f64 x 2)) (-.f64 2 y))))
(fma.f64 -1 (/.f64 y (-.f64 2 y)) (fma.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x (/.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (/.f64 (-.f64 2 y) (*.f64 x x)))))
(-.f64 (fma.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x (*.f64 (/.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (-.f64 2 y)) (*.f64 x x))) (/.f64 y (-.f64 2 y)))
(fma.f64 (/.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (-.f64 2 y)) (*.f64 x x) (-.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x) (/.f64 y (-.f64 2 y))))
(+.f64 (/.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (pow.f64 x 3)) (pow.f64 (-.f64 2 y) 2)) (+.f64 (*.f64 -1 (/.f64 y (-.f64 2 y))) (+.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x) (/.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (pow.f64 x 2)) (-.f64 2 y)))))
(+.f64 (fma.f64 -1 (/.f64 y (-.f64 2 y)) (fma.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x (/.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (/.f64 (-.f64 2 y) (*.f64 x x))))) (/.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (/.f64 (pow.f64 (-.f64 2 y) 2) (pow.f64 x 3))))
(+.f64 (fma.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x (*.f64 (/.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (-.f64 2 y)) (*.f64 x x))) (-.f64 (/.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (/.f64 (pow.f64 (-.f64 2 y) 2) (pow.f64 x 3))) (/.f64 y (-.f64 2 y))))
(+.f64 (-.f64 (*.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) x) (/.f64 y (-.f64 2 y))) (*.f64 (/.f64 (-.f64 (/.f64 1 (-.f64 2 y)) (/.f64 y (pow.f64 (-.f64 2 y) 2))) (-.f64 2 y)) (+.f64 (*.f64 x x) (/.f64 (pow.f64 x 3) (-.f64 2 y)))))
-1
(-.f64 (*.f64 2 (/.f64 y x)) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(-.f64 (/.f64 (*.f64 y 2) x) (+.f64 1 (/.f64 2 x)))
(-.f64 (fma.f64 2 (/.f64 y x) -1) (/.f64 2 x))
(+.f64 (/.f64 (fma.f64 y 2 -2) x) -1)
(-.f64 (+.f64 (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (-.f64 2 y)) (pow.f64 x 2)) (*.f64 2 (/.f64 y x))) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 (fma.f64 2 y -2) (/.f64 (*.f64 x x) (-.f64 2 y))) (-.f64 (/.f64 (*.f64 y 2) x) (+.f64 1 (/.f64 2 x))))
(+.f64 (-.f64 (fma.f64 2 (/.f64 y x) -1) (/.f64 2 x)) (*.f64 (/.f64 (-.f64 2 y) x) (/.f64 (fma.f64 y 2 -2) x)))
(fma.f64 (/.f64 (-.f64 2 y) x) (/.f64 (fma.f64 y 2 -2) x) (+.f64 (/.f64 (fma.f64 y 2 -2) x) -1))
(-.f64 (+.f64 (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (-.f64 2 y)) (pow.f64 x 2)) (+.f64 (*.f64 2 (/.f64 y x)) (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (pow.f64 (-.f64 2 y) 2)) (pow.f64 x 3)))) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 (fma.f64 2 y -2) (/.f64 (*.f64 x x) (-.f64 2 y))) (-.f64 (fma.f64 2 (/.f64 y x) (/.f64 (fma.f64 2 y -2) (/.f64 (pow.f64 x 3) (pow.f64 (-.f64 2 y) 2)))) (+.f64 1 (/.f64 2 x))))
(+.f64 (*.f64 (/.f64 (-.f64 2 y) x) (/.f64 (fma.f64 y 2 -2) x)) (+.f64 (*.f64 (/.f64 (fma.f64 y 2 -2) (pow.f64 x 3)) (pow.f64 (-.f64 2 y) 2)) (-.f64 (fma.f64 2 (/.f64 y x) -1) (/.f64 2 x))))
(+.f64 (+.f64 (/.f64 (fma.f64 y 2 -2) x) -1) (*.f64 (/.f64 (fma.f64 y 2 -2) (*.f64 x x)) (+.f64 (-.f64 2 y) (/.f64 (pow.f64 (-.f64 2 y) 2) x))))
-1
(-.f64 (*.f64 2 (/.f64 y x)) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(-.f64 (/.f64 (*.f64 y 2) x) (+.f64 1 (/.f64 2 x)))
(-.f64 (fma.f64 2 (/.f64 y x) -1) (/.f64 2 x))
(+.f64 (/.f64 (fma.f64 y 2 -2) x) -1)
(-.f64 (+.f64 (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (-.f64 2 y)) (pow.f64 x 2)) (*.f64 2 (/.f64 y x))) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 (fma.f64 2 y -2) (/.f64 (*.f64 x x) (-.f64 2 y))) (-.f64 (/.f64 (*.f64 y 2) x) (+.f64 1 (/.f64 2 x))))
(+.f64 (-.f64 (fma.f64 2 (/.f64 y x) -1) (/.f64 2 x)) (*.f64 (/.f64 (-.f64 2 y) x) (/.f64 (fma.f64 y 2 -2) x)))
(fma.f64 (/.f64 (-.f64 2 y) x) (/.f64 (fma.f64 y 2 -2) x) (+.f64 (/.f64 (fma.f64 y 2 -2) x) -1))
(-.f64 (+.f64 (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (-.f64 2 y)) (pow.f64 x 2)) (+.f64 (*.f64 2 (/.f64 y x)) (/.f64 (*.f64 (-.f64 (*.f64 2 y) 2) (pow.f64 (-.f64 2 y) 2)) (pow.f64 x 3)))) (+.f64 1 (*.f64 2 (/.f64 1 x))))
(+.f64 (/.f64 (fma.f64 2 y -2) (/.f64 (*.f64 x x) (-.f64 2 y))) (-.f64 (fma.f64 2 (/.f64 y x) (/.f64 (fma.f64 2 y -2) (/.f64 (pow.f64 x 3) (pow.f64 (-.f64 2 y) 2)))) (+.f64 1 (/.f64 2 x))))
(+.f64 (*.f64 (/.f64 (-.f64 2 y) x) (/.f64 (fma.f64 y 2 -2) x)) (+.f64 (*.f64 (/.f64 (fma.f64 y 2 -2) (pow.f64 x 3)) (pow.f64 (-.f64 2 y) 2)) (-.f64 (fma.f64 2 (/.f64 y x) -1) (/.f64 2 x))))
(+.f64 (+.f64 (/.f64 (fma.f64 y 2 -2) x) -1) (*.f64 (/.f64 (fma.f64 y 2 -2) (*.f64 x x)) (+.f64 (-.f64 2 y) (/.f64 (pow.f64 (-.f64 2 y) 2) x))))
(/.f64 x (-.f64 2 x))
(+.f64 (/.f64 x (-.f64 2 x)) (*.f64 -1 (*.f64 (+.f64 (/.f64 1 (-.f64 2 x)) (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 2)))) y)))
(+.f64 (/.f64 x (-.f64 2 x)) (neg.f64 (*.f64 y (+.f64 (/.f64 1 (-.f64 2 x)) (/.f64 (neg.f64 x) (pow.f64 (-.f64 2 x) 2))))))
(-.f64 (/.f64 x (-.f64 2 x)) (*.f64 y (-.f64 (/.f64 1 (-.f64 2 x)) (/.f64 x (pow.f64 (-.f64 2 x) 2)))))
(fma.f64 y (+.f64 (/.f64 x (pow.f64 (-.f64 2 x) 2)) (/.f64 -1 (-.f64 2 x))) (/.f64 x (-.f64 2 x)))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (/.f64 1 (pow.f64 (-.f64 2 x) 2)) (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 3)))) (pow.f64 y 2))) (+.f64 (/.f64 x (-.f64 2 x)) (*.f64 -1 (*.f64 (+.f64 (/.f64 1 (-.f64 2 x)) (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 2)))) y))))
(fma.f64 -1 (*.f64 (+.f64 (/.f64 1 (pow.f64 (-.f64 2 x) 2)) (/.f64 (neg.f64 x) (pow.f64 (-.f64 2 x) 3))) (*.f64 y y)) (+.f64 (/.f64 x (-.f64 2 x)) (neg.f64 (*.f64 y (+.f64 (/.f64 1 (-.f64 2 x)) (/.f64 (neg.f64 x) (pow.f64 (-.f64 2 x) 2)))))))
(-.f64 (fma.f64 (neg.f64 (-.f64 (/.f64 1 (pow.f64 (-.f64 2 x) 2)) (/.f64 x (pow.f64 (-.f64 2 x) 3)))) (*.f64 y y) (/.f64 x (-.f64 2 x))) (*.f64 y (-.f64 (/.f64 1 (-.f64 2 x)) (/.f64 x (pow.f64 (-.f64 2 x) 2)))))
(fma.f64 y (+.f64 (/.f64 x (pow.f64 (-.f64 2 x) 2)) (/.f64 -1 (-.f64 2 x))) (fma.f64 (*.f64 y y) (+.f64 (/.f64 x (pow.f64 (-.f64 2 x) 3)) (/.f64 -1 (pow.f64 (-.f64 2 x) 2))) (/.f64 x (-.f64 2 x))))
(+.f64 (*.f64 -1 (*.f64 (+.f64 (/.f64 1 (pow.f64 (-.f64 2 x) 2)) (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 3)))) (pow.f64 y 2))) (+.f64 (/.f64 x (-.f64 2 x)) (+.f64 (*.f64 -1 (*.f64 (pow.f64 y 3) (+.f64 (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 4))) (/.f64 1 (pow.f64 (-.f64 2 x) 3))))) (*.f64 -1 (*.f64 (+.f64 (/.f64 1 (-.f64 2 x)) (*.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 2)))) y)))))
(fma.f64 -1 (*.f64 (+.f64 (/.f64 1 (pow.f64 (-.f64 2 x) 2)) (/.f64 (neg.f64 x) (pow.f64 (-.f64 2 x) 3))) (*.f64 y y)) (+.f64 (/.f64 x (-.f64 2 x)) (*.f64 -1 (+.f64 (*.f64 (pow.f64 y 3) (fma.f64 -1 (/.f64 x (pow.f64 (-.f64 2 x) 4)) (/.f64 1 (pow.f64 (-.f64 2 x) 3)))) (*.f64 y (+.f64 (/.f64 1 (-.f64 2 x)) (/.f64 (neg.f64 x) (pow.f64 (-.f64 2 x) 2))))))))
(-.f64 (fma.f64 -1 (fma.f64 (pow.f64 y 3) (-.f64 (/.f64 1 (pow.f64 (-.f64 2 x) 3)) (/.f64 x (pow.f64 (-.f64 2 x) 4))) (*.f64 y (-.f64 (/.f64 1 (-.f64 2 x)) (/.f64 x (pow.f64 (-.f64 2 x) 2))))) (/.f64 x (-.f64 2 x))) (*.f64 (-.f64 (/.f64 1 (pow.f64 (-.f64 2 x) 2)) (/.f64 x (pow.f64 (-.f64 2 x) 3))) (*.f64 y y)))
(-.f64 (fma.f64 y (+.f64 (/.f64 x (pow.f64 (-.f64 2 x) 2)) (/.f64 -1 (-.f64 2 x))) (fma.f64 (*.f64 y y) (+.f64 (/.f64 x (pow.f64 (-.f64 2 x) 3)) (/.f64 -1 (pow.f64 (-.f64 2 x) 2))) (/.f64 x (-.f64 2 x)))) (*.f64 (pow.f64 y 3) (-.f64 (/.f64 1 (pow.f64 (-.f64 2 x) 3)) (/.f64 x (pow.f64 (-.f64 2 x) 4)))))
1
(-.f64 (+.f64 1 (*.f64 -1 (/.f64 x y))) (*.f64 -1 (/.f64 (-.f64 2 x) y)))
(+.f64 1 (-.f64 (/.f64 (neg.f64 x) y) (/.f64 (neg.f64 (-.f64 2 x)) y)))
(+.f64 (-.f64 1 (/.f64 x y)) (/.f64 (-.f64 2 x) y))
(+.f64 1 (/.f64 (-.f64 (-.f64 2 x) x) y))
(-.f64 (+.f64 1 (+.f64 (/.f64 (*.f64 (-.f64 (*.f64 -1 x) (*.f64 -1 (-.f64 2 x))) (-.f64 2 x)) (pow.f64 y 2)) (*.f64 -1 (/.f64 x y)))) (*.f64 -1 (/.f64 (-.f64 2 x) y)))
(+.f64 1 (-.f64 (+.f64 (/.f64 (neg.f64 x) y) (/.f64 (*.f64 -1 (-.f64 x (-.f64 2 x))) (/.f64 (*.f64 y y) (-.f64 2 x)))) (/.f64 (neg.f64 (-.f64 2 x)) y)))
(+.f64 (/.f64 (-.f64 2 x) y) (+.f64 (-.f64 1 (/.f64 x y)) (*.f64 (/.f64 (-.f64 2 x) (*.f64 y y)) (fma.f64 -1 x (-.f64 2 x)))))
(+.f64 (-.f64 1 (/.f64 x y)) (*.f64 (/.f64 (-.f64 2 x) y) (-.f64 (/.f64 (-.f64 (-.f64 2 x) x) y) -1)))
(-.f64 (+.f64 (/.f64 (*.f64 (-.f64 2 x) (-.f64 (*.f64 -1 x) (*.f64 -1 (-.f64 2 x)))) (pow.f64 y 2)) (+.f64 1 (+.f64 (*.f64 -1 (/.f64 x y)) (/.f64 (*.f64 (-.f64 (*.f64 -1 x) (*.f64 -1 (-.f64 2 x))) (pow.f64 (-.f64 2 x) 2)) (pow.f64 y 3))))) (*.f64 -1 (/.f64 (-.f64 2 x) y)))
(-.f64 (+.f64 (+.f64 (/.f64 (*.f64 -1 (-.f64 x (-.f64 2 x))) (/.f64 (*.f64 y y) (-.f64 2 x))) 1) (fma.f64 -1 (/.f64 x y) (/.f64 (*.f64 -1 (-.f64 x (-.f64 2 x))) (/.f64 (pow.f64 y 3) (pow.f64 (-.f64 2 x) 2))))) (/.f64 (neg.f64 (-.f64 2 x)) y))
(+.f64 (+.f64 (-.f64 1 (/.f64 x y)) (*.f64 (/.f64 (fma.f64 -1 x (-.f64 2 x)) (pow.f64 y 3)) (pow.f64 (-.f64 2 x) 2))) (+.f64 (*.f64 (/.f64 (-.f64 2 x) (*.f64 y y)) (fma.f64 -1 x (-.f64 2 x))) (/.f64 (-.f64 2 x) y)))
(+.f64 (+.f64 1 (/.f64 (-.f64 (-.f64 2 x) x) y)) (*.f64 (/.f64 (-.f64 (-.f64 2 x) x) (*.f64 y y)) (+.f64 (/.f64 (pow.f64 (-.f64 2 x) 2) y) (-.f64 2 x))))
1
(+.f64 1 (*.f64 -1 (/.f64 (-.f64 (*.f64 2 x) 2) y)))
(+.f64 1 (neg.f64 (/.f64 (fma.f64 2 x -2) y)))
(-.f64 1 (/.f64 (fma.f64 2 x -2) y))
(+.f64 1 (+.f64 (*.f64 -1 (/.f64 (-.f64 (*.f64 2 x) 2) y)) (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 2 x) 2) (-.f64 2 x)) (pow.f64 y 2)))))
(+.f64 1 (*.f64 -1 (+.f64 (/.f64 (fma.f64 2 x -2) y) (/.f64 (fma.f64 2 x -2) (/.f64 (*.f64 y y) (-.f64 2 x))))))
(-.f64 (-.f64 1 (/.f64 (fma.f64 2 x -2) y)) (*.f64 (/.f64 (fma.f64 2 x -2) (*.f64 y y)) (-.f64 2 x)))
(-.f64 1 (*.f64 (+.f64 1 (/.f64 (-.f64 2 x) y)) (/.f64 (fma.f64 2 x -2) y)))
(+.f64 (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 2 x) 2) (pow.f64 (-.f64 2 x) 2)) (pow.f64 y 3))) (+.f64 1 (+.f64 (*.f64 -1 (/.f64 (-.f64 (*.f64 2 x) 2) y)) (*.f64 -1 (/.f64 (*.f64 (-.f64 (*.f64 2 x) 2) (-.f64 2 x)) (pow.f64 y 2))))))
(fma.f64 -1 (/.f64 (fma.f64 2 x -2) (/.f64 (pow.f64 y 3) (pow.f64 (-.f64 2 x) 2))) (+.f64 1 (*.f64 -1 (+.f64 (/.f64 (fma.f64 2 x -2) y) (/.f64 (fma.f64 2 x -2) (/.f64 (*.f64 y y) (-.f64 2 x)))))))
(-.f64 (-.f64 (-.f64 1 (/.f64 (fma.f64 2 x -2) y)) (*.f64 (/.f64 (fma.f64 2 x -2) (*.f64 y y)) (-.f64 2 x))) (*.f64 (/.f64 (fma.f64 2 x -2) (pow.f64 y 3)) (pow.f64 (-.f64 2 x) 2)))
(+.f64 1 (-.f64 (*.f64 (/.f64 (fma.f64 2 x -2) y) (-.f64 -1 (/.f64 (-.f64 2 x) y))) (*.f64 (pow.f64 (-.f64 2 x) 2) (/.f64 (fma.f64 2 x -2) (pow.f64 y 3)))))

eval45.0ms (1%)

Compiler

Compiled 2066 to 1291 computations (37.5% saved)

prune15.0ms (0.3%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New91596
Fresh000
Picked011
Done000
Total91697
Error
0b
Counts
97 → 6
Alt Table
Click to see full alt table
StatusErrorProgram
32.1b
(/.f64 (neg.f64 y) (-.f64 2 y))
30.7b
(/.f64 x (-.f64 2 x))
0.0b
(/.f64 (-.f64 x y) (-.f64 (-.f64 2 x) y))
38.5b
(-.f64 (*.f64 2 (/.f64 y x)) (+.f64 1 (*.f64 2 (/.f64 1 x))))
38.7b
-1
39.9b
1
Compiler

Compiled 47 to 36 computations (23.4% saved)

localize18.0ms (0.4%)

Local error

Found 3 expressions with local error:

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

Compiled 42 to 28 computations (33.3% saved)

series8.0ms (0.2%)

Counts
3 → 21
Calls

15 calls:

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

rewrite104.0ms (2.3%)

Algorithm
batch-egg-rewrite
Rules
592×log-prod_binary64
568×fma-def_binary64
312×pow2_binary64
280×fma-neg_binary64
217×pow1/3_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify70.0ms (1.6%)

Algorithm
egg-herbie
Rules
705×fma-def_binary64
637×fma-neg_binary64
283×cancel-sign-sub-inv_binary64
69×sub-neg_binary64
58×associate-/l*_binary64
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
023243
156205
2113169
3184169
4288169
5579169
61221169
71942169
82720169
92966169
102971169
Stop Event
saturated
Counts
237 → 227
Calls
Call 1
Inputs
(*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x))))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(*.f64 2 (/.f64 y x))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(*.f64 2 (/.f64 y x))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(/.f64 (-.f64 (*.f64 2 y) 2) x)
-1
-1
(-.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -2 y) 2) x)) 1)
(-.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -2 y) 2) x)) 1)
(-.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -2 y) 2) x)) 1)
(/.f64 2 x)
1
1
Outputs
(*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x))))
(neg.f64 (+.f64 1 (/.f64 2 x)))
(+.f64 -1 (/.f64 -2 x))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(*.f64 2 (/.f64 y x))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(*.f64 2 (/.f64 y x))
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(+.f64 (*.f64 -1 (+.f64 1 (*.f64 2 (/.f64 1 x)))) (*.f64 2 (/.f64 y x)))
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(/.f64 (-.f64 (*.f64 2 y) 2) x)
(/.f64 (fma.f64 2 y -2) x)
-1
-1
(-.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -2 y) 2) x)) 1)
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(-.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -2 y) 2) x)) 1)
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(-.f64 (*.f64 -1 (/.f64 (+.f64 (*.f64 -2 y) 2) x)) 1)
(fma.f64 -1 (+.f64 1 (/.f64 2 x)) (*.f64 2 (/.f64 y x)))
(fma.f64 2 (/.f64 y x) (+.f64 -1 (/.f64 -2 x)))
(+.f64 -1 (/.f64 (fma.f64 2 y -2) x))
(fma.f64 2 (/.f64 (-.f64 y 1) x) -1)
(/.f64 2 x)
1
1

localize5.0ms (0.1%)

Compiler

Compiled 12 to 8 computations (33.3% saved)

localize11.0ms (0.2%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(/.f64 (neg.f64 y) (-.f64 2 y))
Compiler

Compiled 15 to 9 computations (40% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
1.0ms
y
@0
(/.f64 (neg.f64 y) (-.f64 2 y))
0.0ms
y
@inf
(/.f64 (neg.f64 y) (-.f64 2 y))
0.0ms
y
@-inf
(/.f64 (neg.f64 y) (-.f64 2 y))

rewrite56.0ms (1.3%)

Algorithm
batch-egg-rewrite
Rules
671×pow1_binary64
631×add-log-exp_binary64
629×log1p-expm1-u_binary64
629×expm1-log1p-u_binary64
620×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

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

simplify64.0ms (1.4%)

Algorithm
egg-herbie
Rules
1033×fma-def_binary64
805×unswap-sqr_binary64
588×associate-/l*_binary64
545×distribute-lft-out_binary64
416×*-commutative_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
036156
195156
2213154
3550145
41648140
54578140
67882140
Stop Event
node limit
Counts
50 → 52
Calls
Call 1
Inputs
(*.f64 -1/2 y)
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (*.f64 -1/2 y))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (*.f64 -1/8 (pow.f64 y 3))))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (+.f64 (*.f64 -1/16 (pow.f64 y 4)) (*.f64 -1/8 (pow.f64 y 3)))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
Outputs
(*.f64 -1/2 y)
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (*.f64 -1/2 y))
(fma.f64 -1/4 (*.f64 y y) (*.f64 -1/2 y))
(fma.f64 -1/2 y (*.f64 y (*.f64 y -1/4)))
(*.f64 y (+.f64 -1/2 (*.f64 y -1/4)))
(*.f64 y (fma.f64 y -1/4 -1/2))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (*.f64 -1/8 (pow.f64 y 3))))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/2 y (*.f64 -1/8 (pow.f64 y 3))))
(fma.f64 -1/2 y (*.f64 (*.f64 y y) (+.f64 -1/4 (*.f64 y -1/8))))
(*.f64 y (+.f64 -1/2 (*.f64 y (fma.f64 y -1/8 -1/4))))
(*.f64 y (fma.f64 y (fma.f64 y -1/8 -1/4) -1/2))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (+.f64 (*.f64 -1/16 (pow.f64 y 4)) (*.f64 -1/8 (pow.f64 y 3)))))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/2 y (fma.f64 -1/16 (pow.f64 y 4) (*.f64 -1/8 (pow.f64 y 3)))))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/2 y (fma.f64 -1/8 (pow.f64 y 3) (*.f64 -1/16 (pow.f64 y 4)))))
(fma.f64 y (*.f64 y -1/4) (fma.f64 -1/8 (pow.f64 y 3) (fma.f64 -1/16 (pow.f64 y 4) (*.f64 -1/2 y))))
(fma.f64 -1/16 (pow.f64 y 4) (*.f64 y (+.f64 -1/2 (*.f64 y (fma.f64 y -1/8 -1/4)))))
(*.f64 y (+.f64 -1/2 (*.f64 y (fma.f64 y (fma.f64 y -1/16 -1/8) -1/4))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (/.f64 2 y))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))))
(+.f64 1 (+.f64 (/.f64 2 y) (/.f64 (/.f64 4 y) y)))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
(+.f64 1 (+.f64 (/.f64 4 (*.f64 y y)) (+.f64 (/.f64 2 y) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))) (/.f64 8 (pow.f64 y 3))))
(+.f64 1 (+.f64 (/.f64 2 y) (+.f64 (/.f64 4 (*.f64 y y)) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (/.f64 2 y) (+.f64 (/.f64 (/.f64 4 y) y) (/.f64 8 (pow.f64 y 3)))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (/.f64 2 y))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))))
(+.f64 1 (+.f64 (/.f64 2 y) (/.f64 (/.f64 4 y) y)))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
(+.f64 1 (+.f64 (/.f64 4 (*.f64 y y)) (+.f64 (/.f64 2 y) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))) (/.f64 8 (pow.f64 y 3))))
(+.f64 1 (+.f64 (/.f64 2 y) (+.f64 (/.f64 4 (*.f64 y y)) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (/.f64 2 y) (+.f64 (/.f64 (/.f64 4 y) y) (/.f64 8 (pow.f64 y 3)))))

eval122.0ms (2.7%)

Compiler

Compiled 5190 to 3902 computations (24.8% saved)

prune43.0ms (1%)

Pruning

9 alts after pruning (6 fresh and 3 done)

PrunedKeptTotal
New2736279
Fresh202
Picked011
Done123
Total2769285
Error
0b
Counts
285 → 9
Alt Table
Click to see full alt table
StatusErrorProgram
32.1b
(*.f64 y (/.f64 1 (+.f64 -2 y)))
38.7b
-1
38.4b
(-.f64 (*.f64 2 (/.f64 y x)) 1)
32.1b
(/.f64 (neg.f64 y) (-.f64 2 y))
30.7b
(/.f64 x (-.f64 2 x))
55.7b
(*.f64 -1/2 y)
0.0b
(/.f64 (-.f64 x y) (-.f64 (-.f64 2 x) y))
39.6b
(+.f64 1 (/.f64 2 y))
39.9b
1
Compiler

Compiled 62 to 48 computations (22.6% saved)

localize3.0ms (0.1%)

Compiler

Compiled 7 to 5 computations (28.6% saved)

localize9.0ms (0.2%)

Local error

Found 2 expressions with local error:

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

Compiled 20 to 15 computations (25% saved)

series2.0ms (0.1%)

Counts
2 → 24
Calls

6 calls:

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

rewrite66.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
754×pow1_binary64
705×add-log-exp_binary64
704×log1p-expm1-u_binary64
704×expm1-log1p-u_binary64
693×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify59.0ms (1.3%)

Algorithm
egg-herbie
Rules
623×associate-/r*_binary64
535×fma-def_binary64
499×distribute-lft-out_binary64
440×associate-/l/_binary64
345×times-frac_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
055337
1152335
2351326
3882312
42399310
56214310
Stop Event
node limit
Counts
70 → 74
Calls
Call 1
Inputs
(*.f64 -1/2 y)
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (*.f64 -1/2 y))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (*.f64 -1/8 (pow.f64 y 3))))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (+.f64 (*.f64 -1/16 (pow.f64 y 4)) (*.f64 -1/8 (pow.f64 y 3)))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
-1/2
(-.f64 (*.f64 -1/4 y) 1/2)
(-.f64 (+.f64 (*.f64 -1/4 y) (*.f64 -1/8 (pow.f64 y 2))) 1/2)
(-.f64 (+.f64 (*.f64 -1/4 y) (+.f64 (*.f64 -1/16 (pow.f64 y 3)) (*.f64 -1/8 (pow.f64 y 2)))) 1/2)
(/.f64 1 y)
(+.f64 (/.f64 1 y) (*.f64 2 (/.f64 1 (pow.f64 y 2))))
(+.f64 (/.f64 1 y) (+.f64 (*.f64 2 (/.f64 1 (pow.f64 y 2))) (*.f64 4 (/.f64 1 (pow.f64 y 3)))))
(+.f64 (/.f64 1 y) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 4))) (+.f64 (*.f64 2 (/.f64 1 (pow.f64 y 2))) (*.f64 4 (/.f64 1 (pow.f64 y 3))))))
(/.f64 1 y)
(+.f64 (/.f64 1 y) (*.f64 2 (/.f64 1 (pow.f64 y 2))))
(+.f64 (/.f64 1 y) (+.f64 (*.f64 2 (/.f64 1 (pow.f64 y 2))) (*.f64 4 (/.f64 1 (pow.f64 y 3)))))
(+.f64 (/.f64 1 y) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 4))) (+.f64 (*.f64 2 (/.f64 1 (pow.f64 y 2))) (*.f64 4 (/.f64 1 (pow.f64 y 3))))))
Outputs
(*.f64 -1/2 y)
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (*.f64 -1/2 y))
(fma.f64 -1/4 (*.f64 y y) (*.f64 -1/2 y))
(fma.f64 -1/2 y (*.f64 y (*.f64 y -1/4)))
(*.f64 y (fma.f64 y -1/4 -1/2))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (*.f64 -1/8 (pow.f64 y 3))))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/2 y (*.f64 -1/8 (pow.f64 y 3))))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/8 (pow.f64 y 3) (*.f64 -1/2 y)))
(fma.f64 -1/8 (pow.f64 y 3) (*.f64 y (fma.f64 y -1/4 -1/2)))
(*.f64 y (fma.f64 y (fma.f64 y -1/8 -1/4) -1/2))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (+.f64 (*.f64 -1/16 (pow.f64 y 4)) (*.f64 -1/8 (pow.f64 y 3)))))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/2 y (fma.f64 -1/16 (pow.f64 y 4) (*.f64 -1/8 (pow.f64 y 3)))))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/2 y (fma.f64 -1/8 (pow.f64 y 3) (*.f64 -1/16 (pow.f64 y 4)))))
(+.f64 (*.f64 y (fma.f64 y -1/4 -1/2)) (fma.f64 -1/8 (pow.f64 y 3) (*.f64 -1/16 (pow.f64 y 4))))
(fma.f64 y (fma.f64 y -1/4 -1/2) (*.f64 (pow.f64 y 3) (fma.f64 y -1/16 -1/8)))
(*.f64 y (fma.f64 y (+.f64 -1/4 (*.f64 y (fma.f64 y -1/16 -1/8))) -1/2))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (/.f64 2 y))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))))
(+.f64 (/.f64 2 y) (+.f64 1 (/.f64 4 (*.f64 y y))))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
(+.f64 1 (+.f64 (/.f64 4 (*.f64 y y)) (+.f64 (/.f64 2 y) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))) (/.f64 8 (pow.f64 y 3))))
(+.f64 1 (+.f64 (/.f64 2 y) (+.f64 (/.f64 4 (*.f64 y y)) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (/.f64 2 y) (*.f64 (/.f64 1 (*.f64 y y)) (+.f64 4 (/.f64 8 y)))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (/.f64 2 y))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))))
(+.f64 (/.f64 2 y) (+.f64 1 (/.f64 4 (*.f64 y y))))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
(+.f64 1 (+.f64 (/.f64 4 (*.f64 y y)) (+.f64 (/.f64 2 y) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))) (/.f64 8 (pow.f64 y 3))))
(+.f64 1 (+.f64 (/.f64 2 y) (+.f64 (/.f64 4 (*.f64 y y)) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (/.f64 2 y) (*.f64 (/.f64 1 (*.f64 y y)) (+.f64 4 (/.f64 8 y)))))
-1/2
(-.f64 (*.f64 -1/4 y) 1/2)
(fma.f64 -1/4 y -1/2)
(fma.f64 y -1/4 -1/2)
(-.f64 (+.f64 (*.f64 -1/4 y) (*.f64 -1/8 (pow.f64 y 2))) 1/2)
(+.f64 (fma.f64 -1/4 y (*.f64 (*.f64 y y) -1/8)) -1/2)
(fma.f64 y -1/4 (fma.f64 (*.f64 y y) -1/8 -1/2))
(fma.f64 y (fma.f64 y -1/8 -1/4) -1/2)
(-.f64 (+.f64 (*.f64 -1/4 y) (+.f64 (*.f64 -1/16 (pow.f64 y 3)) (*.f64 -1/8 (pow.f64 y 2)))) 1/2)
(+.f64 (fma.f64 -1/4 y (fma.f64 -1/16 (pow.f64 y 3) (*.f64 (*.f64 y y) -1/8))) -1/2)
(+.f64 (fma.f64 (*.f64 y y) -1/8 (*.f64 (pow.f64 y 3) -1/16)) (fma.f64 y -1/4 -1/2))
(fma.f64 y -1/4 (fma.f64 (pow.f64 y 3) -1/16 (fma.f64 (*.f64 y y) -1/8 -1/2)))
(fma.f64 y (*.f64 y (fma.f64 y -1/16 -1/8)) (fma.f64 y -1/4 -1/2))
(fma.f64 y (+.f64 -1/4 (*.f64 y (fma.f64 y -1/16 -1/8))) -1/2)
(/.f64 1 y)
(+.f64 (/.f64 1 y) (*.f64 2 (/.f64 1 (pow.f64 y 2))))
(+.f64 (/.f64 1 y) (/.f64 2 (*.f64 y y)))
(+.f64 (/.f64 1 y) (/.f64 (/.f64 2 y) y))
(+.f64 (/.f64 1 y) (+.f64 (*.f64 2 (/.f64 1 (pow.f64 y 2))) (*.f64 4 (/.f64 1 (pow.f64 y 3)))))
(+.f64 (/.f64 1 y) (+.f64 (/.f64 2 (*.f64 y y)) (/.f64 4 (pow.f64 y 3))))
(+.f64 (/.f64 (/.f64 2 y) y) (+.f64 (/.f64 1 y) (/.f64 4 (pow.f64 y 3))))
(+.f64 (/.f64 1 y) (*.f64 (/.f64 1 (*.f64 y y)) (+.f64 2 (/.f64 4 y))))
(+.f64 (/.f64 1 y) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 4))) (+.f64 (*.f64 2 (/.f64 1 (pow.f64 y 2))) (*.f64 4 (/.f64 1 (pow.f64 y 3))))))
(+.f64 (/.f64 1 y) (+.f64 (+.f64 (/.f64 2 (*.f64 y y)) (/.f64 4 (pow.f64 y 3))) (/.f64 8 (pow.f64 y 4))))
(+.f64 (+.f64 (/.f64 2 (*.f64 y y)) (/.f64 8 (pow.f64 y 4))) (+.f64 (/.f64 4 (pow.f64 y 3)) (/.f64 1 y)))
(+.f64 (/.f64 1 y) (+.f64 (/.f64 2 (*.f64 y y)) (+.f64 (/.f64 4 (pow.f64 y 3)) (/.f64 8 (pow.f64 y 4)))))
(+.f64 (/.f64 1 y) (+.f64 (/.f64 (/.f64 2 y) y) (+.f64 (/.f64 4 (pow.f64 y 3)) (/.f64 8 (pow.f64 y 4)))))
(+.f64 (/.f64 1 y) (+.f64 (/.f64 (/.f64 2 y) y) (*.f64 (/.f64 1 (pow.f64 y 3)) (+.f64 4 (/.f64 8 y)))))
(/.f64 1 y)
(+.f64 (/.f64 1 y) (*.f64 2 (/.f64 1 (pow.f64 y 2))))
(+.f64 (/.f64 1 y) (/.f64 2 (*.f64 y y)))
(+.f64 (/.f64 1 y) (/.f64 (/.f64 2 y) y))
(+.f64 (/.f64 1 y) (+.f64 (*.f64 2 (/.f64 1 (pow.f64 y 2))) (*.f64 4 (/.f64 1 (pow.f64 y 3)))))
(+.f64 (/.f64 1 y) (+.f64 (/.f64 2 (*.f64 y y)) (/.f64 4 (pow.f64 y 3))))
(+.f64 (/.f64 (/.f64 2 y) y) (+.f64 (/.f64 1 y) (/.f64 4 (pow.f64 y 3))))
(+.f64 (/.f64 1 y) (*.f64 (/.f64 1 (*.f64 y y)) (+.f64 2 (/.f64 4 y))))
(+.f64 (/.f64 1 y) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 4))) (+.f64 (*.f64 2 (/.f64 1 (pow.f64 y 2))) (*.f64 4 (/.f64 1 (pow.f64 y 3))))))
(+.f64 (/.f64 1 y) (+.f64 (+.f64 (/.f64 2 (*.f64 y y)) (/.f64 4 (pow.f64 y 3))) (/.f64 8 (pow.f64 y 4))))
(+.f64 (+.f64 (/.f64 2 (*.f64 y y)) (/.f64 8 (pow.f64 y 4))) (+.f64 (/.f64 4 (pow.f64 y 3)) (/.f64 1 y)))
(+.f64 (/.f64 1 y) (+.f64 (/.f64 2 (*.f64 y y)) (+.f64 (/.f64 4 (pow.f64 y 3)) (/.f64 8 (pow.f64 y 4)))))
(+.f64 (/.f64 1 y) (+.f64 (/.f64 (/.f64 2 y) y) (+.f64 (/.f64 4 (pow.f64 y 3)) (/.f64 8 (pow.f64 y 4)))))
(+.f64 (/.f64 1 y) (+.f64 (/.f64 (/.f64 2 y) y) (*.f64 (/.f64 1 (pow.f64 y 3)) (+.f64 4 (/.f64 8 y)))))

localize6.0ms (0.1%)

Compiler

Compiled 13 to 10 computations (23.1% saved)

localize8.0ms (0.2%)

Local error

Found 1 expressions with local error:

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

Compiled 21 to 11 computations (47.6% saved)

eval29.0ms (0.6%)

Compiler

Compiled 1084 to 812 computations (25.1% saved)

prune17.0ms (0.4%)

Pruning

8 alts after pruning (3 fresh and 5 done)

PrunedKeptTotal
New1011102
Fresh022
Picked011
Done246
Total1038111
Error
0b
Counts
111 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
32.1b
(*.f64 y (/.f64 1 (+.f64 -2 y)))
38.7b
-1
38.4b
(-.f64 (*.f64 2 (/.f64 y x)) 1)
30.7b
(/.f64 x (-.f64 2 x))
55.7b
(*.f64 -1/2 y)
0.0b
(/.f64 (-.f64 x y) (-.f64 (-.f64 2 x) y))
32.1b
(/.f64 y (+.f64 y -2))
39.9b
1
Compiler

Compiled 54 to 41 computations (24.1% saved)

localize6.0ms (0.1%)

Local error

Found 1 expressions with local error:

NewErrorProgram
0.0b
(/.f64 y (+.f64 y -2))
Compiler

Compiled 12 to 8 computations (33.3% saved)

series1.0ms (0%)

Counts
1 → 12
Calls

3 calls:

TimeVariablePointExpression
0.0ms
y
@0
(/.f64 y (+.f64 y -2))
0.0ms
y
@-inf
(/.f64 y (+.f64 y -2))
0.0ms
y
@inf
(/.f64 y (+.f64 y -2))

rewrite53.0ms (1.2%)

Algorithm
batch-egg-rewrite
Rules
674×pow1_binary64
634×add-log-exp_binary64
634×log1p-expm1-u_binary64
634×expm1-log1p-u_binary64
623×add-exp-log_binary64
Iterations

Useful iterations: 0 (0.0ms)

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

simplify59.0ms (1.3%)

Algorithm
egg-herbie
Rules
1033×fma-def_binary64
805×unswap-sqr_binary64
588×associate-/l*_binary64
545×distribute-lft-out_binary64
416×*-commutative_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
036156
195156
2213154
3550145
41648140
54578140
67882140
Stop Event
node limit
Counts
45 → 47
Calls
Call 1
Inputs
(*.f64 -1/2 y)
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (*.f64 -1/2 y))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (*.f64 -1/8 (pow.f64 y 3))))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (+.f64 (*.f64 -1/16 (pow.f64 y 4)) (*.f64 -1/8 (pow.f64 y 3)))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
Outputs
(*.f64 -1/2 y)
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (*.f64 -1/2 y))
(fma.f64 -1/4 (*.f64 y y) (*.f64 -1/2 y))
(fma.f64 -1/2 y (*.f64 y (*.f64 y -1/4)))
(*.f64 y (+.f64 -1/2 (*.f64 y -1/4)))
(*.f64 y (fma.f64 y -1/4 -1/2))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (*.f64 -1/8 (pow.f64 y 3))))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/2 y (*.f64 -1/8 (pow.f64 y 3))))
(fma.f64 -1/2 y (*.f64 (*.f64 y y) (+.f64 -1/4 (*.f64 y -1/8))))
(*.f64 y (+.f64 -1/2 (*.f64 y (fma.f64 y -1/8 -1/4))))
(*.f64 y (fma.f64 y (fma.f64 y -1/8 -1/4) -1/2))
(+.f64 (*.f64 -1/4 (pow.f64 y 2)) (+.f64 (*.f64 -1/2 y) (+.f64 (*.f64 -1/16 (pow.f64 y 4)) (*.f64 -1/8 (pow.f64 y 3)))))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/2 y (fma.f64 -1/16 (pow.f64 y 4) (*.f64 -1/8 (pow.f64 y 3)))))
(fma.f64 -1/4 (*.f64 y y) (fma.f64 -1/2 y (fma.f64 -1/8 (pow.f64 y 3) (*.f64 -1/16 (pow.f64 y 4)))))
(fma.f64 y (*.f64 y -1/4) (fma.f64 -1/8 (pow.f64 y 3) (fma.f64 -1/16 (pow.f64 y 4) (*.f64 -1/2 y))))
(fma.f64 -1/16 (pow.f64 y 4) (*.f64 y (+.f64 -1/2 (*.f64 y (fma.f64 y -1/8 -1/4)))))
(*.f64 y (+.f64 -1/2 (*.f64 y (fma.f64 y (fma.f64 y -1/16 -1/8) -1/4))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (/.f64 2 y))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))))
(+.f64 1 (+.f64 (/.f64 2 y) (/.f64 (/.f64 4 y) y)))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
(+.f64 1 (+.f64 (/.f64 4 (*.f64 y y)) (+.f64 (/.f64 2 y) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))) (/.f64 8 (pow.f64 y 3))))
(+.f64 1 (+.f64 (/.f64 2 y) (+.f64 (/.f64 4 (*.f64 y y)) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (/.f64 2 y) (+.f64 (/.f64 (/.f64 4 y) y) (/.f64 8 (pow.f64 y 3)))))
1
(+.f64 (*.f64 2 (/.f64 1 y)) 1)
(+.f64 1 (/.f64 2 y))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (*.f64 2 (/.f64 1 y))))
(+.f64 1 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))))
(+.f64 1 (+.f64 (/.f64 2 y) (/.f64 (/.f64 4 y) y)))
(+.f64 1 (+.f64 (*.f64 4 (/.f64 1 (pow.f64 y 2))) (+.f64 (*.f64 8 (/.f64 1 (pow.f64 y 3))) (*.f64 2 (/.f64 1 y)))))
(+.f64 1 (+.f64 (/.f64 4 (*.f64 y y)) (+.f64 (/.f64 2 y) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (+.f64 (/.f64 2 y) (/.f64 4 (*.f64 y y))) (/.f64 8 (pow.f64 y 3))))
(+.f64 1 (+.f64 (/.f64 2 y) (+.f64 (/.f64 4 (*.f64 y y)) (/.f64 8 (pow.f64 y 3)))))
(+.f64 1 (+.f64 (/.f64 2 y) (+.f64 (/.f64 (/.f64 4 y) y) (/.f64 8 (pow.f64 y 3)))))

eval21.0ms (0.5%)

Compiler

Compiled 500 to 365 computations (27% saved)

prune23.0ms (0.5%)

Pruning

8 alts after pruning (2 fresh and 6 done)

PrunedKeptTotal
New47047
Fresh022
Picked011
Done055
Total47855
Error
0b
Counts
55 → 8
Alt Table
Click to see full alt table
StatusErrorProgram
32.1b
(*.f64 y (/.f64 1 (+.f64 -2 y)))
38.7b
-1
38.4b
(-.f64 (*.f64 2 (/.f64 y x)) 1)
30.7b
(/.f64 x (-.f64 2 x))
55.7b
(*.f64 -1/2 y)
0.0b
(/.f64 (-.f64 x y) (-.f64 (-.f64 2 x) y))
32.1b
(/.f64 y (+.f64 y -2))
39.9b
1
Compiler

Compiled 54 to 41 computations (24.1% saved)

regimes73.0ms (1.6%)

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

4 calls:

29.0ms
x
16.0ms
y
13.0ms
(/.f64 (-.f64 x y) (-.f64 2 (+.f64 x y)))
8.0ms
(/.f64 (-.f64 x y) (-.f64 2 (+.f64 x y)))
Results
ErrorSegmentsBranch
0.0b1x
0.0b1y
0.0b1(/.f64 (-.f64 x y) (-.f64 2 (+.f64 x y)))
0.0b1(/.f64 (-.f64 x y) (-.f64 2 (+.f64 x y)))
Compiler

Compiled 103 to 68 computations (34% saved)

regimes175.0ms (3.9%)

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

2 calls:

93.0ms
y
77.0ms
x
Results
ErrorSegmentsBranch
13.4b5x
10.5b7y
Compiler

Compiled 50 to 36 computations (28% saved)

bsearch289.0ms (6.5%)

Algorithm
binary-search
Steps
TimeLeftRight
67.0ms
3.4004448633078727e+41
6.167303841317723e+41
30.0ms
1966594.4482695544
32230738555.429523
80.0ms
4.447487254923756e-46
7.702484349763126e-13
29.0ms
-5.338008206742224e-61
-3.774360431730058e-69
48.0ms
-530072407084116.56
-304127.62288789934
34.0ms
-2.790628277974997e+57
-1.0110838803573737e+56
Compiler

Compiled 16 to 11 computations (31.3% saved)

regimes214.0ms (4.8%)

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

2 calls:

105.0ms
y
104.0ms
x
Results
ErrorSegmentsBranch
13.4b5x
10.6b7y
Compiler

Compiled 43 to 31 computations (27.9% saved)

bsearch197.0ms (4.4%)

Algorithm
binary-search
Steps
TimeLeftRight
34.0ms
3.4004448633078727e+41
6.167303841317723e+41
32.0ms
1966594.4482695544
32230738555.429523
34.0ms
4.447487254923756e-46
7.702484349763126e-13
33.0ms
-5.338008206742224e-61
-3.774360431730058e-69
31.0ms
-530072407084116.56
-304127.62288789934
32.0ms
-1.5828282294461644e+51
-2.7283929530354504e+48
Compiler

Compiled 16 to 11 computations (31.3% saved)

regimes111.0ms (2.5%)

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

2 calls:

69.0ms
y
39.0ms
x
Results
ErrorSegmentsBranch
15.0b3x
18.2b7y
Compiler

Compiled 25 to 19 computations (24% saved)

bsearch82.0ms (1.8%)

Algorithm
binary-search
Steps
TimeLeftRight
48.0ms
1.4919194996068743e+78
1.0055473454000441e+79
34.0ms
-561953328597.0264
-2.650146347579874
Compiler

Compiled 16 to 11 computations (31.3% saved)

regimes115.0ms (2.6%)

Accuracy

Total -42.1b remaining (-201.5%)

Threshold costs -42.1b (-201.5%)

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

2 calls:

84.0ms
x
29.0ms
y
Results
ErrorSegmentsBranch
21.5b5x
20.9b3y
Compiler

Compiled 15 to 12 computations (20% saved)

bsearch63.0ms (1.4%)

Algorithm
binary-search
Steps
TimeLeftRight
31.0ms
3.4004448633078727e+41
6.167303841317723e+41
32.0ms
-1.5828282294461644e+51
-2.7283929530354504e+48
Compiler

Compiled 16 to 11 computations (31.3% saved)

simplify38.0ms (0.8%)

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

Useful iterations: 0 (0.0ms)

IterNodesCost
048199
159199
267199
371199
473199
Stop Event
fuel
saturated
Calls
Call 1
Inputs
(/.f64 (-.f64 x y) (-.f64 (-.f64 2 x) y))
(if (<=.f64 y -2790628277974996959225582979097975010642699321833777266688) 1 (if (<=.f64 y -8481158513345865/16) (-.f64 (*.f64 2 (/.f64 y x)) 1) (if (<=.f64 y -7726239032807773/14474011154664524427946373126085988481658748083205070504932198000989141204992) (/.f64 y (+.f64 y -2)) (if (<=.f64 y 5717469177035173/12855504354071922204335696738729300820177623950262342682411008) (/.f64 x (-.f64 2 x)) (if (<=.f64 y 2111614709953225/1073741824) (/.f64 y (+.f64 y -2)) (if (<=.f64 y 340044486330787265081162471835388719661056) (/.f64 x (-.f64 2 x)) 1))))))
(if (<=.f64 y -1582828229446164403334772254803617024141192478064640) 1 (if (<=.f64 y -8481158513345865/16) (/.f64 x (-.f64 2 x)) (if (<=.f64 y -7726239032807773/14474011154664524427946373126085988481658748083205070504932198000989141204992) (/.f64 y (+.f64 y -2)) (if (<=.f64 y 5717469177035173/12855504354071922204335696738729300820177623950262342682411008) (/.f64 x (-.f64 2 x)) (if (<=.f64 y 2111614709953225/1073741824) (/.f64 y (+.f64 y -2)) (if (<=.f64 y 340044486330787265081162471835388719661056) (/.f64 x (-.f64 2 x)) 1))))))
(if (<=.f64 x -575440208483355/1024) -1 (if (<=.f64 x 1491919499606874343719696195064914557462658484490418789955661815500905711140864) (/.f64 y (+.f64 y -2)) -1))
(if (<=.f64 y -1582828229446164403334772254803617024141192478064640) 1 (if (<=.f64 y 340044486330787265081162471835388719661056) -1 1))
-1
Outputs
(/.f64 (-.f64 x y) (-.f64 (-.f64 2 x) y))
(if (<=.f64 y -2790628277974996959225582979097975010642699321833777266688) 1 (if (<=.f64 y -8481158513345865/16) (-.f64 (*.f64 2 (/.f64 y x)) 1) (if (<=.f64 y -7726239032807773/14474011154664524427946373126085988481658748083205070504932198000989141204992) (/.f64 y (+.f64 y -2)) (if (<=.f64 y 5717469177035173/12855504354071922204335696738729300820177623950262342682411008) (/.f64 x (-.f64 2 x)) (if (<=.f64 y 2111614709953225/1073741824) (/.f64 y (+.f64 y -2)) (if (<=.f64 y 340044486330787265081162471835388719661056) (/.f64 x (-.f64 2 x)) 1))))))
(if (<=.f64 y -2790628277974996959225582979097975010642699321833777266688) 1 (if (<=.f64 y -8481158513345865/16) (+.f64 (*.f64 2 (/.f64 y x)) -1) (if (<=.f64 y -7726239032807773/14474011154664524427946373126085988481658748083205070504932198000989141204992) (/.f64 y (+.f64 y -2)) (if (<=.f64 y 5717469177035173/12855504354071922204335696738729300820177623950262342682411008) (/.f64 x (-.f64 2 x)) (if (<=.f64 y 2111614709953225/1073741824) (/.f64 y (+.f64 y -2)) (if (<=.f64 y 340044486330787265081162471835388719661056) (/.f64 x (-.f64 2 x)) 1))))))
(if (<=.f64 y -1582828229446164403334772254803617024141192478064640) 1 (if (<=.f64 y -8481158513345865/16) (/.f64 x (-.f64 2 x)) (if (<=.f64 y -7726239032807773/14474011154664524427946373126085988481658748083205070504932198000989141204992) (/.f64 y (+.f64 y -2)) (if (<=.f64 y 5717469177035173/12855504354071922204335696738729300820177623950262342682411008) (/.f64 x (-.f64 2 x)) (if (<=.f64 y 2111614709953225/1073741824) (/.f64 y (+.f64 y -2)) (if (<=.f64 y 340044486330787265081162471835388719661056) (/.f64 x (-.f64 2 x)) 1))))))
(if (<=.f64 x -575440208483355/1024) -1 (if (<=.f64 x 1491919499606874343719696195064914557462658484490418789955661815500905711140864) (/.f64 y (+.f64 y -2)) -1))
(if (<=.f64 y -1582828229446164403334772254803617024141192478064640) 1 (if (<=.f64 y 340044486330787265081162471835388719661056) -1 1))
-1
Compiler

Compiled 152 to 110 computations (27.6% saved)

soundness309.0ms (7%)

Algorithm
egg-herbie
Rules
1142×fma-neg_binary64
983×fma-def_binary64
651×div-sub_binary64
413×sub-neg_binary64
386×distribute-rgt-in_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0813
11813
23513
37713
418813
535713
688613
7239613
8474413
9656713
10714413
11752813
12759613
13761613
Stop Event
node limit
Compiler

Compiled 22 to 14 computations (36.4% saved)

end225.0ms (5.1%)

Compiler

Compiled 142 to 100 computations (29.6% saved)

Profiling

Loading profile data...