
Time bar (total: 3.6s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 0 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 1 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 2 |
| 50% | 50% | 50% | 0.1% | 0% | 0% | 0% | 3 |
| 50% | 50% | 50% | 0.1% | 0% | 0% | 0% | 4 |
| 62.5% | 62.4% | 37.5% | 0.1% | 0% | 0% | 0% | 5 |
| 68.8% | 68.7% | 31.2% | 0.1% | 0% | 0% | 0% | 6 |
| 78.1% | 78% | 21.9% | 0.1% | 0% | 0% | 0% | 7 |
| 82.8% | 82.7% | 17.2% | 0.1% | 0% | 0% | 0% | 8 |
| 88.3% | 88.2% | 11.7% | 0.1% | 0% | 0% | 0% | 9 |
| 91% | 90.9% | 9% | 0.1% | 0% | 0% | 0% | 10 |
| 93.9% | 93.9% | 6% | 0.1% | 0% | 0% | 0% | 11 |
| 95.4% | 95.3% | 4.6% | 0.1% | 0% | 0% | 0% | 12 |
Compiled 13 to 11 computations (15.4% saved)
| 453.0ms | 8 252× | 0 | valid |
| 2.0ms | 3× | 2 | valid |
| 0.0ms | 1× | 1 | valid |
ival-div!: 108.0ms (48.1% of total)ival-mult!: 74.0ms (33% of total)ival-add!: 22.0ms (9.8% of total)ival-sub!: 18.0ms (8% of total)adjust: 2.0ms (0.9% of total)Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 28 | 76 |
| 1 | 166 | 70 |
| 1× | iter-limit |
| 1× | node-limit |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
Compiled 22 to 18 computations (18.2% saved)
| Inputs |
|---|
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
x |
(/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64)))) |
y |
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))) |
#s(literal 1 binary64) |
(/.f64 (*.f64 x y) #s(literal 2 binary64)) |
(*.f64 x y) |
#s(literal 2 binary64) |
| Outputs |
|---|
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1/4 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)))))) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)) (*.f64 x (fma.f64 #s(literal -1/4 binary64) (pow.f64 y #s(literal 3 binary64)) (*.f64 #s(literal 1/8 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64))))))))) y)) |
#s(approx x x) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) y) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 #s(literal -1/2 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 x (-.f64 (*.f64 #s(literal 1/4 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64)))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 x (-.f64 (*.f64 x (-.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64)))) (*.f64 #s(literal -1/4 binary64) (pow.f64 y #s(literal 3 binary64))))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ 1 (/ (* x y) 2)) #s(literal 1 binary64)) |
#s(approx (+ 1 (/ (* x y) 2)) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))) |
#s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y))) |
#s(approx (* x y) (*.f64 x y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) (fma.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 2 binary64)))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 #s(literal 2 binary64) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x y)))) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 (+.f64 #s(literal 2 binary64) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64))))) (/.f64 #s(literal 4 binary64) (*.f64 x y))) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 (+.f64 #s(literal 2 binary64) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64)))))) (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 x y)))) x)) |
#s(approx (+ 1 (/ (* x y) 2)) (*.f64 x (fma.f64 #s(literal 1/2 binary64) y (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y)) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))))) (pow.f64 x #s(literal 3 binary64))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) #s(literal 1 binary64))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x y))) #s(literal 2 binary64)) x))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y))) x)) #s(literal 2 binary64)) x))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 2 binary64))))) x)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y))) x)) #s(literal 2 binary64)) x))) |
#s(approx (+ 1 (/ (* x y) 2)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1/2 binary64) y) (/.f64 #s(literal 1 binary64) x))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 #s(literal -1 binary64) y))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 y (-.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 x y)) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 y (-.f64 (*.f64 y (fma.f64 #s(literal -1/4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y) (*.f64 #s(literal 1/2 binary64) x))) #s(literal 1 binary64))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal 1/4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)) (*.f64 #s(literal 1/2 binary64) x)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y (-.f64 (*.f64 y (-.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) (*.f64 #s(literal -1/4 binary64) (pow.f64 x #s(literal 2 binary64))))) (*.f64 #s(literal 1/2 binary64) x)))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 x (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))) (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64)))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64)))))) (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (+ 1 (/ (* x y) 2)) (*.f64 y (fma.f64 #s(literal 1/2 binary64) x (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64))))) y)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) y) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (fma.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y)))) y) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (+ 1 (/ (* x y) 2)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1/2 binary64) x) (/.f64 #s(literal 1 binary64) y))))) |
6 calls:
| Time | Variable | Point |
|---|---|---|
| 2.0ms | y | inf |
| 2.0ms | x | inf |
| 2.0ms | y | 0 |
| 2.0ms | x | -inf |
| 2.0ms | y | -inf |
| Inputs |
|---|
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
x |
(/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64)))) |
y |
(+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))) |
#s(literal 1 binary64) |
(/.f64 (*.f64 x y) #s(literal 2 binary64)) |
(*.f64 x y) |
#s(literal 2 binary64) |
| Outputs |
|---|
(*.f64 (neg.f64 (fma.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) y (*.f64 x x))) (neg.f64 (-.f64 x (/.f64 y (fma.f64 y x #s(literal 1 binary64)))))) |
(*.f64 (-.f64 x (/.f64 y (fma.f64 y x #s(literal 1 binary64)))) (fma.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) y (*.f64 x x))) |
(*.f64 (fma.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) y (*.f64 x x)) (-.f64 x (/.f64 y (fma.f64 y x #s(literal 1 binary64))))) |
(*.f64 (fma.f64 (-.f64 x (/.f64 y (fma.f64 y x #s(literal 1 binary64)))) (/.f64 y (fma.f64 y x #s(literal 1 binary64))) (*.f64 x x)) (fma.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) y (*.f64 x x))) |
(*.f64 (fma.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) y (*.f64 x x)) (fma.f64 (-.f64 x (/.f64 y (fma.f64 y x #s(literal 1 binary64)))) (/.f64 y (fma.f64 y x #s(literal 1 binary64))) (*.f64 x x))) |
x |
(*.f64 x #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) x) |
(/.f64 x #s(literal 1 binary64)) |
(/.f64 (neg.f64 x) #s(literal 1 binary64)) |
(*.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) (fma.f64 y x #s(literal 1 binary64))) |
(*.f64 (fma.f64 y x #s(literal 1 binary64)) (/.f64 y (fma.f64 y x #s(literal 1 binary64)))) |
(+.f64 (*.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) #s(literal 1 binary64)) (*.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) (*.f64 (*.f64 x y) (fma.f64 y x #s(literal 1 binary64))))) |
(+.f64 (*.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) #s(literal 1 binary64)) (*.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) (*.f64 x y))) |
(+.f64 (*.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) (*.f64 (*.f64 x y) (fma.f64 y x #s(literal 1 binary64)))) (*.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) #s(literal 1 binary64))) |
y |
(neg.f64 (neg.f64 y)) |
(*.f64 (fma.f64 y x #s(literal 1 binary64)) (fma.f64 y x #s(literal 1 binary64))) |
(*.f64 (fma.f64 y x #s(literal 1 binary64)) #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) (fma.f64 y x #s(literal 1 binary64))) |
(*.f64 (fabs.f64 (fma.f64 y x #s(literal 1 binary64))) (fabs.f64 (fma.f64 y x #s(literal 1 binary64)))) |
(*.f64 (pow.f64 (fma.f64 y x #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 1 binary64))) (pow.f64 (fma.f64 y x #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 1 binary64)))) |
#s(literal 1 binary64) |
#s(literal 2 binary64) |
#s(literal 0 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 3 binary64)) |
(*.f64 #s(literal 3 binary64) #s(literal 1 binary64)) |
(*.f64 x y) |
(*.f64 y x) |
(*.f64 (*.f64 x y) #s(literal 1 binary64)) |
(*.f64 (*.f64 #s(literal 1 binary64) y) (neg.f64 x)) |
(*.f64 (*.f64 #s(literal 1 binary64) y) x) |
(*.f64 x y) |
(*.f64 y x) |
(*.f64 (*.f64 x y) #s(literal 1 binary64)) |
(*.f64 (*.f64 #s(literal 1 binary64) y) (neg.f64 x)) |
(*.f64 (*.f64 #s(literal 1 binary64) y) x) |
#s(literal 1 binary64) |
#s(literal 2 binary64) |
#s(literal 0 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 3 binary64)) |
(*.f64 #s(literal 3 binary64) #s(literal 1 binary64)) |
Compiled 1 842 to 431 computations (76.6% saved)
7 alts after pruning (7 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 69 | 7 | 76 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 70 | 7 | 77 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 92.6% | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y x)))) |
| ▶ | 100.0% | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))))) |
| ▶ | 64.7% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
| 62.4% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))))) | |
| ▶ | 75.7% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
| 59.8% | #s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y)) | |
| ▶ | 27.2% | #s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
Compiled 226 to 176 computations (22.1% saved)
| Inputs |
|---|
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))))) |
x |
(/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y))))) |
y |
(+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))) |
#s(literal 1 binary64) |
#s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y))) |
(*.f64 #s(literal 1/2 binary64) (*.f64 x y)) |
#s(literal 1/2 binary64) |
(*.f64 x y) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) y) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
(*.f64 #s(literal -1 binary64) y) |
#s(literal -1 binary64) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x)) |
(/.f64 #s(literal 2 binary64) x) |
#s(literal 2 binary64) |
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y x)))) |
(/.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y x))) |
(+.f64 #s(literal 1 binary64) (*.f64 y x)) |
(*.f64 y x) |
| Outputs |
|---|
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1/4 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)))))) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)) (*.f64 x (fma.f64 #s(literal -1/4 binary64) (pow.f64 y #s(literal 3 binary64)) (*.f64 #s(literal 1/8 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64))))))))) y)) |
#s(approx x x) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) y) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 #s(literal -1/2 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 x (-.f64 (*.f64 #s(literal 1/4 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64)))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 x (-.f64 (*.f64 x (-.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64)))) (*.f64 #s(literal -1/4 binary64) (pow.f64 y #s(literal 3 binary64))))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ 1 (/ (* x y) 2)) #s(literal 1 binary64)) |
#s(approx (+ 1 (/ (* x y) 2)) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))) |
#s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y))) |
#s(approx (* x y) (*.f64 x y)) |
#s(approx (/ 2 x) (/.f64 #s(literal 2 binary64) x)) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 2 binary64)))) y)) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))) (pow.f64 y #s(literal 2 binary64))))) y)) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 x (fma.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 3 binary64)) (*.f64 x (pow.f64 y #s(literal 4 binary64)))) (pow.f64 y #s(literal 2 binary64))))) y)) |
#s(approx (/ y (+ 1 (* y x))) (+.f64 y (*.f64 #s(literal -1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (/ y (+ 1 (* y x))) (+.f64 y (*.f64 x (-.f64 (*.f64 x (pow.f64 y #s(literal 3 binary64))) (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (/ y (+ 1 (* y x))) (+.f64 y (*.f64 x (-.f64 (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64)))) (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 3 binary64))))) (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (+ 1 (* y x)) (+.f64 #s(literal 1 binary64) (*.f64 x y))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) (fma.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 2 binary64)))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 #s(literal 2 binary64) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x y)))) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 (+.f64 #s(literal 2 binary64) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64))))) (/.f64 #s(literal 4 binary64) (*.f64 x y))) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 (+.f64 #s(literal 2 binary64) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64)))))) (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 x y)))) x)) |
#s(approx (+ 1 (/ (* x y) 2)) (*.f64 x (fma.f64 #s(literal 1/2 binary64) y (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 x (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (+.f64 (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 2 binary64)))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))))) |
#s(approx (/ y (+ 1 (* y x))) (/.f64 #s(literal 1 binary64) x)) |
#s(approx (/ y (+ 1 (* y x))) (/.f64 (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x y))) x)) |
#s(approx (/ y (+ 1 (* y x))) (/.f64 (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64))))) (/.f64 #s(literal 1 binary64) (*.f64 x y))) x)) |
#s(approx (/ y (+ 1 (* y x))) (/.f64 (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64))))) (+.f64 (/.f64 #s(literal 1 binary64) (*.f64 x y)) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))))) x)) |
#s(approx (+ 1 (* y x)) (*.f64 x (+.f64 y (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y)) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))))) (pow.f64 x #s(literal 3 binary64))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) #s(literal 1 binary64))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x y))) #s(literal 2 binary64)) x))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y))) x)) #s(literal 2 binary64)) x))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 2 binary64))))) x)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y))) x)) #s(literal 2 binary64)) x))) |
#s(approx (+ 1 (/ (* x y) 2)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1/2 binary64) y) (/.f64 #s(literal 1 binary64) x))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))) (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) y) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) (pow.f64 x #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 1 binary64))))) |
#s(approx (/ y (+ 1 (* y x))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 x y)) #s(literal 1 binary64)) x))) |
#s(approx (/ y (+ 1 (* y x))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))) (/.f64 #s(literal 1 binary64) y)) x)) #s(literal 1 binary64)) x))) |
#s(approx (/ y (+ 1 (* y x))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 2 binary64)))) x)) (/.f64 #s(literal 1 binary64) y)) x)) #s(literal 1 binary64)) x))) |
#s(approx (+ 1 (* y x)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) y) (/.f64 #s(literal 1 binary64) x))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 #s(literal -1 binary64) y))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 y (-.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 x y)) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 y (-.f64 (*.f64 y (fma.f64 #s(literal -1/4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y) (*.f64 #s(literal 1/2 binary64) x))) #s(literal 1 binary64))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal 1/4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)) (*.f64 #s(literal 1/2 binary64) x)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y (-.f64 (*.f64 y (-.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) (*.f64 #s(literal -1/4 binary64) (pow.f64 x #s(literal 2 binary64))))) (*.f64 #s(literal 1/2 binary64) x)))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 y (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) #s(literal 1 binary64))))) |
#s(approx (/ y (+ 1 (* y x))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (*.f64 x y))))) |
#s(approx (/ y (+ 1 (* y x))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y (-.f64 (*.f64 (pow.f64 x #s(literal 2 binary64)) y) x))))) |
#s(approx (/ y (+ 1 (* y x))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y (-.f64 (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) (*.f64 #s(literal -1 binary64) (pow.f64 x #s(literal 2 binary64))))) x))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 x (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))) (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64)))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64)))))) (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (+ 1 (/ (* x y) 2)) (*.f64 y (fma.f64 #s(literal 1/2 binary64) x (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 x (/.f64 #s(literal 1 binary64) x))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (+.f64 x (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (+.f64 x (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))) (+.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (+.f64 x (+.f64 (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))))) (+.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (/ y (+ 1 (* y x))) (-.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) |
#s(approx (/ y (+ 1 (* y x))) (-.f64 (+.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) |
#s(approx (/ y (+ 1 (* y x))) (-.f64 (+.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))) (+.f64 (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64))))))) |
#s(approx (+ 1 (* y x)) (*.f64 y (+.f64 x (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64))))) y)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) y) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (fma.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y)))) y) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (+ 1 (/ (* x y) 2)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1/2 binary64) x) (/.f64 #s(literal 1 binary64) y))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) y))) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) y)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) y))) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (/ y (+ 1 (* y x))) (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) y) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (/ y (+ 1 (* y x))) (fma.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y))) y) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) y) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (+ 1 (* y x)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) x) (/.f64 #s(literal 1 binary64) y))))) |
6 calls:
| Time | Variable | Point |
|---|---|---|
| 3.0ms | x | inf |
| 2.0ms | y | -inf |
| 2.0ms | x | -inf |
| 2.0ms | y | inf |
| 1.0ms | x | 0 |
| Inputs |
|---|
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))))) |
x |
(/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y))))) |
y |
(+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))) |
#s(literal 1 binary64) |
#s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y))) |
(*.f64 #s(literal 1/2 binary64) (*.f64 x y)) |
#s(literal 1/2 binary64) |
(*.f64 x y) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) y) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
(*.f64 #s(literal -1 binary64) y) |
#s(literal -1 binary64) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x)) |
(/.f64 #s(literal 2 binary64) x) |
#s(literal 2 binary64) |
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y x)))) |
(/.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y x))) |
(+.f64 #s(literal 1 binary64) (*.f64 y x)) |
(*.f64 y x) |
| Outputs |
|---|
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (* y x) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))))) |
x |
(*.f64 x #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) x) |
(/.f64 x #s(literal 1 binary64)) |
(/.f64 (neg.f64 x) #s(literal 1 binary64)) |
(/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (* y x) (*.f64 #s(literal 1/2 binary64) (*.f64 x y))))) |
y |
(*.f64 #s(literal -1 binary64) y) |
(*.f64 y #s(literal -1 binary64)) |
(*.f64 y #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) y) |
(+.f64 #s(literal 1 binary64) #s(approx (* y x) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))) |
#s(literal 1 binary64) |
#s(literal 2 binary64) |
#s(literal 0 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 3 binary64)) |
(*.f64 #s(literal 3 binary64) #s(literal 1 binary64)) |
#s(approx (* y x) (*.f64 #s(literal 1/2 binary64) (*.f64 x y))) |
(*.f64 #s(literal 1/2 binary64) (*.f64 x y)) |
(*.f64 (*.f64 x #s(literal 1/2 binary64)) y) |
(*.f64 (*.f64 y #s(literal 1/2 binary64)) x) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(literal 1 binary64)) (*.f64 x y)) |
(*.f64 (*.f64 x y) #s(literal 1/2 binary64)) |
#s(literal 1/2 binary64) |
(*.f64 x y) |
(*.f64 y x) |
(*.f64 (*.f64 #s(literal 1 binary64) #s(literal -1 binary64)) (*.f64 x y)) |
(*.f64 (neg.f64 x) y) |
(*.f64 (*.f64 #s(literal -1 binary64) #s(literal 1 binary64)) (*.f64 x y)) |
(-.f64 x #s(approx (/ y (+ 2 (* y x))) y)) |
#s(approx (/ y (+ 2 (* y x))) y) |
#s(approx (+ x (/ y (+ 2 (* y x)))) y) |
y |
(*.f64 #s(literal -1 binary64) y) |
(*.f64 y #s(literal -1 binary64)) |
(*.f64 y #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) y) |
#s(literal -1 binary64) |
(-.f64 x #s(approx (/ y (+ 2 (* y x))) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (/ y (+ 2 (* y x))) (/.f64 #s(literal 1 binary64) x)) |
(*.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) x)) |
(+.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 1 binary64) x)) |
(/.f64 #s(literal 1 binary64) x) |
(/.f64 (+.f64 x x) (*.f64 x x)) |
(/.f64 #s(literal 1 binary64) (neg.f64 x)) |
#s(literal 1 binary64) |
#s(literal 2 binary64) |
#s(literal 0 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 3 binary64)) |
(*.f64 #s(literal 3 binary64) #s(literal 1 binary64)) |
(*.f64 (fma.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) y (*.f64 x x)) (-.f64 x (/.f64 y (fma.f64 y x #s(literal 1 binary64))))) |
(*.f64 (-.f64 x (/.f64 y (fma.f64 y x #s(literal 1 binary64)))) (fma.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) y (*.f64 x x))) |
(*.f64 (neg.f64 (fma.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) y (*.f64 x x))) (neg.f64 (-.f64 x (/.f64 y (fma.f64 y x #s(literal 1 binary64)))))) |
(*.f64 (fma.f64 (-.f64 x (/.f64 y (fma.f64 y x #s(literal 1 binary64)))) (/.f64 y (fma.f64 y x #s(literal 1 binary64))) (*.f64 x x)) (fma.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) y (*.f64 x x))) |
(*.f64 (neg.f64 (fma.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) y (*.f64 x x))) (fma.f64 (-.f64 x (/.f64 y (fma.f64 y x #s(literal 1 binary64)))) (/.f64 y (fma.f64 y x #s(literal 1 binary64))) (neg.f64 (*.f64 x x)))) |
(*.f64 (/.f64 #s(literal -1 binary64) (fma.f64 y x #s(literal 1 binary64))) y) |
(*.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) #s(literal -1 binary64)) |
(*.f64 (/.f64 y (fma.f64 y x #s(literal 1 binary64))) (fma.f64 y x #s(literal 1 binary64))) |
(*.f64 #s(literal -1 binary64) (/.f64 y (fma.f64 y x #s(literal 1 binary64)))) |
(*.f64 y (/.f64 #s(literal -1 binary64) (fma.f64 y x #s(literal 1 binary64)))) |
(*.f64 (fma.f64 y x #s(literal 1 binary64)) (fma.f64 y x #s(literal 1 binary64))) |
(*.f64 (fma.f64 y x #s(literal 1 binary64)) #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) (fma.f64 y x #s(literal 1 binary64))) |
(*.f64 (fabs.f64 (fma.f64 y x #s(literal 1 binary64))) (fabs.f64 (fma.f64 y x #s(literal 1 binary64)))) |
(*.f64 (pow.f64 (fma.f64 y x #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 1 binary64))) (pow.f64 (fma.f64 y x #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 1 binary64)))) |
(*.f64 x y) |
(*.f64 y x) |
(*.f64 (*.f64 #s(literal 1 binary64) #s(literal -1 binary64)) (*.f64 x y)) |
(*.f64 (neg.f64 x) y) |
(*.f64 (*.f64 #s(literal -1 binary64) #s(literal 1 binary64)) (*.f64 x y)) |
Compiled 3 681 to 793 computations (78.5% saved)
8 alts after pruning (4 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 160 | 2 | 162 |
| Fresh | 0 | 2 | 2 |
| Picked | 1 | 4 | 5 |
| Done | 0 | 0 | 0 |
| Total | 161 | 8 | 169 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))))) |
| ✓ | 64.7% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
| ▶ | 62.4% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))))) |
| ✓ | 75.7% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
| ▶ | 59.8% | #s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y)) |
| ✓ | 27.2% | #s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
| ▶ | 62.3% | #s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))))) |
| ▶ | 3.1% | #s(approx (+ x (/ y (+ 2 (* y x)))) y) |
Compiled 134 to 102 computations (23.9% saved)
| Inputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) y) |
y |
#s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))))) |
(+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64)))) |
x |
(*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))) |
(-.f64 (*.f64 x y) #s(literal 1 binary64)) |
(*.f64 x y) |
#s(literal 1 binary64) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y)) |
(-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y) |
(*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)))) |
(*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))) |
#s(literal 1/2 binary64) |
(pow.f64 y #s(literal 2 binary64)) |
#s(literal 2 binary64) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y))))) |
(*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y))) |
(*.f64 #s(literal -1/2 binary64) (*.f64 x y)) |
#s(literal -1/2 binary64) |
| Outputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal 1/2 binary64) y)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fma.f64 #s(literal 1/2 binary64) y (*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/4 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fma.f64 #s(literal 1/2 binary64) y (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/8 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))))) (*.f64 #s(literal 1/4 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fma.f64 #s(literal 1/2 binary64) y (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1/16 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64)))) (*.f64 #s(literal -1/8 binary64) (pow.f64 y #s(literal 3 binary64)))))) (*.f64 #s(literal 1/4 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 #s(literal -1 binary64) y)) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 2 binary64)))) y)) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))) (pow.f64 y #s(literal 2 binary64))))) y)) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 x (fma.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 3 binary64)) (*.f64 x (pow.f64 y #s(literal 4 binary64)))) (pow.f64 y #s(literal 2 binary64))))) y)) |
#s(approx (+ x (* y (- (* x y) 1))) (fma.f64 #s(literal -1 binary64) y (*.f64 x (+.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx x x) |
#s(approx (* y (- (* x y) 1)) (fma.f64 #s(literal -1 binary64) y (*.f64 x (pow.f64 y #s(literal 2 binary64))))) |
#s(approx (- (* x y) 1) #s(literal -1 binary64)) |
#s(approx (- (* x y) 1) (-.f64 (*.f64 x y) #s(literal 1 binary64))) |
#s(approx (* x y) (*.f64 x y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1/4 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)))))) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)) (*.f64 x (fma.f64 #s(literal -1/4 binary64) (pow.f64 y #s(literal 3 binary64)) (*.f64 #s(literal 1/8 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64))))))))) y)) |
#s(approx (* x (+ 1 (* 1/2 (pow y 2)))) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) y) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 #s(literal -1/2 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 x (-.f64 (*.f64 #s(literal 1/4 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64)))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 x (-.f64 (*.f64 x (-.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64)))) (*.f64 #s(literal -1/4 binary64) (pow.f64 y #s(literal 3 binary64))))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ 1 (* -1/2 (* x y))) #s(literal 1 binary64)) |
#s(approx (+ 1 (* -1/2 (* x y))) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))) |
#s(approx (* -1/2 (* x y)) (*.f64 #s(literal -1/2 binary64) (*.f64 x y))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 x (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (/.f64 #s(literal 2 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 2 binary64)))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 x (-.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (+.f64 (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 2 binary64)))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))))) |
#s(approx (+ x (* y (- (* x y) 1))) (*.f64 x (+.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 2 binary64))))) |
#s(approx (+ x (* y (- (* x y) 1))) (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) (/.f64 y x) (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (* y (- (* x y) 1)) (*.f64 x (pow.f64 y #s(literal 2 binary64)))) |
#s(approx (* y (- (* x y) 1)) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 y x) (pow.f64 y #s(literal 2 binary64))))) |
#s(approx (- (* x y) 1) (*.f64 x (-.f64 y (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) (fma.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 2 binary64)))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))))) |
#s(approx (- (* x (+ 1 (* 1/2 (pow y 2)))) y) (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1 binary64) (/.f64 y x) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 #s(literal 2 binary64) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x y)))) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 (+.f64 #s(literal 2 binary64) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64))))) (/.f64 #s(literal 4 binary64) (*.f64 x y))) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 (+.f64 #s(literal 2 binary64) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64)))))) (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 x y)))) x)) |
#s(approx (* y (+ 1 (* -1/2 (* x y)))) (*.f64 #s(literal -1/2 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) |
#s(approx (* y (+ 1 (* -1/2 (* x y)))) (*.f64 x (fma.f64 #s(literal -1/2 binary64) (pow.f64 y #s(literal 2 binary64)) (/.f64 y x)))) |
#s(approx (+ 1 (* -1/2 (* x y))) (*.f64 x (fma.f64 #s(literal -1/2 binary64) y (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 #s(literal 2 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) y))) (pow.f64 x #s(literal 3 binary64)))) (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))) (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) y) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) (pow.f64 x #s(literal 3 binary64))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 1 binary64))))) |
#s(approx (+ x (* y (- (* x y) 1))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64))) #s(literal 1 binary64))))) |
#s(approx (+ x (* y (- (* x y) 1))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (fma.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)) (/.f64 y x)) #s(literal 1 binary64))))) |
#s(approx (* y (- (* x y) 1)) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (pow.f64 y #s(literal 2 binary64)) (/.f64 y x))))) |
#s(approx (- (* x y) 1) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) y (/.f64 #s(literal 1 binary64) x))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y)) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))))) (pow.f64 x #s(literal 3 binary64))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) #s(literal 1 binary64))))) |
#s(approx (- (* x (+ 1 (* 1/2 (pow y 2)))) y) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)))) (/.f64 y x))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x y))) #s(literal 2 binary64)) x))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y))) x)) #s(literal 2 binary64)) x))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 2 binary64))))) x)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y))) x)) #s(literal 2 binary64)) x))) |
#s(approx (* y (+ 1 (* -1/2 (* x y)))) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 y x) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ 1 (* -1/2 (* x y))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 1/2 binary64) y) (/.f64 #s(literal 1 binary64) x))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 #s(literal 1/2 binary64) y))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 y (+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 x y)))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 y (+.f64 #s(literal 1/2 binary64) (*.f64 y (-.f64 (*.f64 #s(literal 1/8 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)) (*.f64 #s(literal 1/4 binary64) x))))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 #s(literal -1 binary64) y))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 y (+.f64 x (*.f64 #s(literal -1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) #s(literal 1 binary64))))) |
#s(approx (* y (- (* x y) 1)) (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 y (-.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 x y)) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 y (-.f64 (*.f64 y (fma.f64 #s(literal -1/4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y) (*.f64 #s(literal 1/2 binary64) x))) #s(literal 1 binary64))))) |
#s(approx (* x (+ 1 (* 1/2 (pow y 2)))) (+.f64 x (*.f64 #s(literal 1/2 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (+ 1 (* 1/2 (pow y 2))) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) |
#s(approx (* 1/2 (pow y 2)) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)))) |
#s(approx (pow y 2) (pow.f64 y #s(literal 2 binary64))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal 1/4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)) (*.f64 #s(literal 1/2 binary64) x)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y (-.f64 (*.f64 y (-.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) (*.f64 #s(literal -1/4 binary64) (pow.f64 x #s(literal 2 binary64))))) (*.f64 #s(literal 1/2 binary64) x)))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (/.f64 #s(literal 1 binary64) x))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (-.f64 (+.f64 x (/.f64 #s(literal 1 binary64) x)) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (-.f64 (+.f64 x (+.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64)))))) (/.f64 #s(literal 2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (-.f64 (+.f64 x (+.f64 (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))))) (fma.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 x (/.f64 #s(literal 1 binary64) x))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (+.f64 x (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (+.f64 x (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))) (+.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (+.f64 x (+.f64 (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))))) (+.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ x (* y (- (* x y) 1))) (*.f64 (pow.f64 y #s(literal 2 binary64)) (-.f64 x (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (+ x (* y (- (* x y) 1))) (*.f64 (pow.f64 y #s(literal 2 binary64)) (-.f64 (+.f64 x (/.f64 x (pow.f64 y #s(literal 2 binary64)))) (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (- (* x y) 1) (*.f64 y (-.f64 x (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 x (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))) (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64)))))))) |
#s(approx (- (* x (+ 1 (* 1/2 (pow y 2)))) y) (*.f64 #s(literal 1/2 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) |
#s(approx (- (* x (+ 1 (* 1/2 (pow y 2)))) y) (*.f64 (pow.f64 y #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal 1/2 binary64) x) (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (- (* x (+ 1 (* 1/2 (pow y 2)))) y) (*.f64 (pow.f64 y #s(literal 2 binary64)) (-.f64 (fma.f64 #s(literal 1/2 binary64) x (/.f64 x (pow.f64 y #s(literal 2 binary64)))) (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (* x (+ 1 (* 1/2 (pow y 2)))) (*.f64 (pow.f64 y #s(literal 2 binary64)) (fma.f64 #s(literal 1/2 binary64) x (/.f64 x (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (+ 1 (* 1/2 (pow y 2))) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 #s(literal 1/2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64)))))) (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (* y (+ 1 (* -1/2 (* x y)))) (*.f64 (pow.f64 y #s(literal 2 binary64)) (fma.f64 #s(literal -1/2 binary64) x (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (+ 1 (* -1/2 (* x y))) (*.f64 y (fma.f64 #s(literal -1/2 binary64) x (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) y) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y)))) y) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) y))) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) y)) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) y))) (/.f64 #s(literal 1 binary64) x))) |
#s(approx (+ x (* y (- (* x y) 1))) (*.f64 (pow.f64 y #s(literal 2 binary64)) (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 x y))) y))))) |
#s(approx (- (* x y) 1) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (/.f64 #s(literal 1 binary64) y))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64))))) y)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- (* x (+ 1 (* 1/2 (pow y 2)))) y) (*.f64 (pow.f64 y #s(literal 2 binary64)) (fma.f64 #s(literal -1 binary64) (/.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1 binary64) (/.f64 x y))) y) (*.f64 #s(literal 1/2 binary64) x)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) y) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (fma.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y)))) y) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (+ 1 (* -1/2 (* x y))) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal 1/2 binary64) x) (/.f64 #s(literal 1 binary64) y))))) |
6 calls:
| Time | Variable | Point |
|---|---|---|
| 5.0ms | y | 0 |
| 5.0ms | y | inf |
| 4.0ms | y | -inf |
| 4.0ms | x | -inf |
| 4.0ms | x | inf |
| Inputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) y) |
y |
#s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))))) |
(+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64)))) |
x |
(*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))) |
(-.f64 (*.f64 x y) #s(literal 1 binary64)) |
(*.f64 x y) |
#s(literal 1 binary64) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y)) |
(-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y) |
(*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)))) |
(*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))) |
#s(literal 1/2 binary64) |
(pow.f64 y #s(literal 2 binary64)) |
#s(literal 2 binary64) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y))))) |
(*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y))) |
(*.f64 #s(literal -1/2 binary64) (*.f64 x y)) |
#s(literal -1/2 binary64) |
| Outputs |
|---|
#s(approx (+ x (* y x)) y) |
y |
(*.f64 y #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) y) |
(*.f64 y y) |
(fabs.f64 y) |
#s(approx (+ x (* y x)) (fma.f64 y x x)) |
(*.f64 (fma.f64 y x x) (fma.f64 y x x)) |
(*.f64 x (fma.f64 y x x)) |
(*.f64 (fma.f64 y x (fabs.f64 x)) (-.f64 (*.f64 x y) (fabs.f64 x))) |
(*.f64 (+.f64 (fabs.f64 x) (*.f64 x y)) (-.f64 (fabs.f64 x) (*.f64 x y))) |
(+.f64 x (*.f64 x y)) |
x |
(*.f64 x #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) x) |
(+.f64 x x) |
(/.f64 x #s(literal 1 binary64)) |
(*.f64 x y) |
(*.f64 y x) |
(*.f64 y (*.f64 x y)) |
(*.f64 (*.f64 x x) (*.f64 x y)) |
(*.f64 (*.f64 x x) y) |
(*.f64 x y) |
(*.f64 y x) |
(*.f64 y (*.f64 x y)) |
(*.f64 (*.f64 x x) (*.f64 x y)) |
(*.f64 (*.f64 x x) y) |
(*.f64 x y) |
(*.f64 y x) |
(*.f64 y (*.f64 x y)) |
(*.f64 (*.f64 x x) (*.f64 x y)) |
(*.f64 (*.f64 x x) y) |
#s(literal 1 binary64) |
#s(literal 2 binary64) |
#s(literal 0 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 3 binary64)) |
(*.f64 #s(literal 3 binary64) #s(literal 1 binary64)) |
#s(approx (+ x (* y x)) (fma.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) x y)) |
(*.f64 (fma.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) x y) (fma.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) x y)) |
(*.f64 (fma.f64 (fma.f64 (*.f64 x #s(literal 1/2 binary64)) y x) y (fma.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) x y)) (fma.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) x y)) |
(*.f64 (fma.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) x y) (fma.f64 (fma.f64 (*.f64 x #s(literal 1/2 binary64)) y x) y (fma.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) x y))) |
(*.f64 (fma.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) x y) (fma.f64 (fma.f64 (*.f64 x y) (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) y) (fma.f64 (fma.f64 (*.f64 x #s(literal 1/2 binary64)) y x) y (fma.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) x y)) (fma.f64 (*.f64 x #s(literal 1/2 binary64)) y x))) |
(+.f64 (*.f64 (*.f64 x #s(literal 1/2 binary64)) y) (+.f64 x y)) |
(*.f64 x (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64))) |
(*.f64 (*.f64 x x) (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64))) |
(*.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) x) |
(*.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) (*.f64 x x)) |
(*.f64 (fma.f64 (*.f64 x #s(literal 1/2 binary64)) y x) (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64))) |
(*.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64))) |
(*.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)) #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64))) |
(*.f64 (fabs.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64))) (fabs.f64 (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64)))) |
(*.f64 (fma.f64 #s(literal 1/2 binary64) (fma.f64 y #s(literal 1/2 binary64) y) #s(literal 1 binary64)) (fma.f64 y #s(literal 1/2 binary64) #s(literal 1 binary64))) |
(*.f64 #s(literal 1/2 binary64) y) |
(*.f64 y #s(literal 1/2 binary64)) |
(*.f64 (*.f64 #s(literal 1/2 binary64) y) #s(literal 1 binary64)) |
(*.f64 (*.f64 #s(literal 1/2 binary64) y) y) |
(*.f64 (neg.f64 #s(literal 1/2 binary64)) y) |
#s(literal 1/2 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 1/2 binary64)) |
(*.f64 #s(literal 1/2 binary64) #s(literal 1 binary64)) |
(/.f64 #s(literal 1/2 binary64) #s(literal 1 binary64)) |
(neg.f64 (neg.f64 #s(literal 1/2 binary64))) |
y |
(*.f64 y #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) y) |
(*.f64 y y) |
(fabs.f64 y) |
#s(literal 1 binary64) |
#s(literal 2 binary64) |
#s(literal 0 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 3 binary64)) |
(*.f64 #s(literal 3 binary64) #s(literal 1 binary64)) |
(-.f64 x #s(approx (* y x) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y y))) |
#s(approx (* y x) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y y)) |
(*.f64 y (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64))) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y y)) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y y) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y y)) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y y) #s(literal 1 binary64)) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64))) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64))) |
(*.f64 (fma.f64 #s(literal -1/2 binary64) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y (*.f64 x y)) #s(literal 1 binary64)) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64))) |
(*.f64 (+.f64 #s(literal 1 binary64) (fabs.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))) (-.f64 #s(literal 1 binary64) (fabs.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x y))))) |
(*.f64 #s(literal -1/2 binary64) (*.f64 x y)) |
(*.f64 (*.f64 x #s(literal -1/2 binary64)) (*.f64 x y)) |
(*.f64 (*.f64 x #s(literal -1/2 binary64)) y) |
(*.f64 (*.f64 y #s(literal -1/2 binary64)) (*.f64 x y)) |
(*.f64 (*.f64 y #s(literal -1/2 binary64)) x) |
#s(literal -1/2 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal -1/2 binary64)) |
(*.f64 #s(literal -1/2 binary64) #s(literal 1 binary64)) |
(/.f64 #s(literal -1/2 binary64) #s(literal 1 binary64)) |
(neg.f64 (neg.f64 #s(literal -1/2 binary64))) |
Compiled 5 757 to 1 094 computations (81% saved)
12 alts after pruning (6 fresh and 6 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 207 | 6 | 213 |
| Fresh | 0 | 0 | 0 |
| Picked | 2 | 2 | 4 |
| Done | 0 | 4 | 4 |
| Total | 209 | 12 | 221 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))))) |
| ✓ | 64.7% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
| ▶ | 62.4% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y))) |
| ✓ | 75.7% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
| 59.8% | #s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) y) y))) y)) | |
| ✓ | 27.2% | #s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
| ✓ | 62.3% | #s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))))) |
| ▶ | 49.8% | #s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 #s(literal 1/2 binary64) y))) |
| ▶ | 3.1% | #s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal 1/2 binary64) y)) |
| ▶ | 15.2% | #s(approx (+ x (/ y (+ 2 (* y x)))) (fabs.f64 y)) |
| ✓ | 3.1% | #s(approx (+ x (/ y (+ 2 (* y x)))) y) |
| ▶ | 36.3% | #s(approx (+ x (* y x)) (fma.f64 y x x)) |
Compiled 276 to 204 computations (26.1% saved)
| Inputs |
|---|
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y))) |
x |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y)) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y) |
(fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) |
(*.f64 x #s(literal -1/2 binary64)) |
#s(literal -1/2 binary64) |
y |
#s(literal 1 binary64) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fabs.f64 y)) |
(fabs.f64 y) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal 1/2 binary64) y)) |
(*.f64 #s(literal 1/2 binary64) y) |
#s(literal 1/2 binary64) |
#s(approx (+ x (* y x)) (fma.f64 y x x)) |
(fma.f64 y x x) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 #s(literal 1/2 binary64) y))) |
(+.f64 x (*.f64 #s(literal 1/2 binary64) y)) |
| Outputs |
|---|
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1/4 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)))))) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64)) (*.f64 x (fma.f64 #s(literal -1/4 binary64) (pow.f64 y #s(literal 3 binary64)) (*.f64 #s(literal 1/8 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64))))))))) y)) |
#s(approx x x) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) y) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 #s(literal -1/2 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 x (-.f64 (*.f64 #s(literal 1/4 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64)))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (+.f64 y (*.f64 x (-.f64 (*.f64 x (-.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64)))) (*.f64 #s(literal -1/4 binary64) (pow.f64 y #s(literal 3 binary64))))) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ (* (* x -1/2) y) 1) #s(literal 1 binary64)) |
#s(approx (+ (* (* x -1/2) y) 1) (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))) |
#s(approx (* x -1/2) (*.f64 #s(literal -1/2 binary64) x)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal 1/2 binary64) y)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fma.f64 #s(literal 1/2 binary64) y (*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/4 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fma.f64 #s(literal 1/2 binary64) y (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/8 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))))) (*.f64 #s(literal 1/4 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fma.f64 #s(literal 1/2 binary64) y (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1/16 binary64) (*.f64 x (pow.f64 y #s(literal 4 binary64)))) (*.f64 #s(literal -1/8 binary64) (pow.f64 y #s(literal 3 binary64)))))) (*.f64 #s(literal 1/4 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ x (* y x)) (*.f64 x (+.f64 #s(literal 1 binary64) y))) |
#s(approx (+ x (* 1/2 y)) (+.f64 x (*.f64 #s(literal 1/2 binary64) y))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) (fma.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 2 binary64)))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 #s(literal 2 binary64) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x y)))) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 (+.f64 #s(literal 2 binary64) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64))))) (/.f64 #s(literal 4 binary64) (*.f64 x y))) x)) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 (-.f64 (+.f64 #s(literal 2 binary64) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (pow.f64 y #s(literal 2 binary64)))))) (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 x y)))) x)) |
#s(approx (* (+ (* (* x -1/2) y) 1) y) (*.f64 #s(literal -1/2 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) |
#s(approx (* (+ (* (* x -1/2) y) 1) y) (*.f64 x (fma.f64 #s(literal -1/2 binary64) (pow.f64 y #s(literal 2 binary64)) (/.f64 y x)))) |
#s(approx (+ (* (* x -1/2) y) 1) (*.f64 #s(literal -1/2 binary64) (*.f64 x y))) |
#s(approx (+ (* (* x -1/2) y) 1) (*.f64 x (fma.f64 #s(literal -1/2 binary64) y (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 x (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (/.f64 #s(literal 2 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 x (-.f64 (+.f64 #s(literal 1 binary64) (fma.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 2 binary64)))) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))))) |
#s(approx (+ x (* 1/2 y)) (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (/.f64 y x))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y)) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64)))))) (pow.f64 x #s(literal 3 binary64))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) #s(literal 1 binary64))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x y))) #s(literal 2 binary64)) x))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y))) x)) #s(literal 2 binary64)) x))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 3 binary64))))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 2 binary64))))) x)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) y))) x)) #s(literal 2 binary64)) x))) |
#s(approx (* (+ (* (* x -1/2) y) 1) y) (*.f64 #s(literal -1 binary64) (*.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 y x) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (+ (* (* x -1/2) y) 1) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal 1/2 binary64) y) (/.f64 #s(literal 1 binary64) x))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (/.f64 #s(literal 2 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 x (pow.f64 y #s(literal 2 binary64))))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) y))) (pow.f64 x #s(literal 3 binary64)))) (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))))))) |
#s(approx (+ x (* y x)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1 binary64) y) #s(literal 1 binary64))))) |
#s(approx (+ x (* 1/2 y)) (*.f64 #s(literal -1 binary64) (*.f64 x (-.f64 (*.f64 #s(literal -1/2 binary64) (/.f64 y x)) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 #s(literal -1 binary64) y))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 y (-.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 x y)) #s(literal 1 binary64))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (+.f64 x (*.f64 y (-.f64 (*.f64 y (fma.f64 #s(literal -1/4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y) (*.f64 #s(literal 1/2 binary64) x))) #s(literal 1 binary64))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal 1/4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)) (*.f64 #s(literal 1/2 binary64) x)))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y (-.f64 (*.f64 y (-.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)) (*.f64 #s(literal -1/4 binary64) (pow.f64 x #s(literal 2 binary64))))) (*.f64 #s(literal 1/2 binary64) x)))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 y (+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 x y)))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 y (+.f64 #s(literal 1/2 binary64) (*.f64 y (-.f64 (*.f64 #s(literal 1/8 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)) (*.f64 #s(literal 1/4 binary64) x))))))) |
#s(approx (fabs y) (fabs.f64 y)) |
#s(approx (+ x (* y x)) (+.f64 x (*.f64 x y))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 x (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))) (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64)))))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 8 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (-.f64 (fma.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64)))))) (fma.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (* (+ (* (* x -1/2) y) 1) y) (*.f64 (pow.f64 y #s(literal 2 binary64)) (fma.f64 #s(literal -1/2 binary64) x (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (+ (* (* x -1/2) y) 1) (*.f64 y (fma.f64 #s(literal -1/2 binary64) x (/.f64 #s(literal 1 binary64) y)))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (/.f64 #s(literal 1 binary64) x))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (-.f64 (+.f64 x (/.f64 #s(literal 1 binary64) x)) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (-.f64 (+.f64 x (+.f64 (/.f64 #s(literal 1 binary64) x) (/.f64 #s(literal 4 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64)))))) (/.f64 #s(literal 2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y)))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (-.f64 (+.f64 x (+.f64 (/.f64 #s(literal 1 binary64) x) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) (pow.f64 y #s(literal 2 binary64))))))) (fma.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) (pow.f64 y #s(literal 3 binary64)))) (/.f64 #s(literal 2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) y))))) |
#s(approx (+ x (* y x)) (*.f64 x y)) |
#s(approx (+ x (* y x)) (*.f64 y (+.f64 x (/.f64 x y)))) |
#s(approx (+ x (* 1/2 y)) (*.f64 y (+.f64 #s(literal 1/2 binary64) (/.f64 x y)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y))) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (+.f64 x (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64))))) y)) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y))) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) y) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (fma.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) (*.f64 #s(literal 16 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y)))) y) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (+ (* (* x -1/2) y) 1) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal 1/2 binary64) x) (/.f64 #s(literal 1 binary64) y))))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64)))) (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 3 binary64)) y)))) y) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (fma.f64 #s(literal -1 binary64) (/.f64 (fma.f64 #s(literal -1 binary64) (/.f64 (-.f64 (*.f64 #s(literal 4 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 3 binary64)))) (*.f64 #s(literal 8 binary64) (/.f64 #s(literal 1 binary64) (*.f64 (pow.f64 x #s(literal 4 binary64)) y)))) y) (*.f64 #s(literal 2 binary64) (/.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 2 binary64))))) y) (/.f64 #s(literal 1 binary64) x)))) |
#s(approx (+ x (* y x)) (*.f64 #s(literal -1 binary64) (*.f64 y (fma.f64 #s(literal -1 binary64) x (*.f64 #s(literal -1 binary64) (/.f64 x y)))))) |
#s(approx (+ x (* 1/2 y)) (*.f64 #s(literal -1 binary64) (*.f64 y (-.f64 (*.f64 #s(literal -1 binary64) (/.f64 x y)) #s(literal 1/2 binary64))))) |
6 calls:
| Time | Variable | Point |
|---|---|---|
| 4.0ms | y | -inf |
| 3.0ms | x | -inf |
| 3.0ms | x | inf |
| 3.0ms | y | inf |
| 2.0ms | x | 0 |
| Inputs |
|---|
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y))) |
x |
#s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y)) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y) |
(fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) |
(*.f64 x #s(literal -1/2 binary64)) |
#s(literal -1/2 binary64) |
y |
#s(literal 1 binary64) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fabs.f64 y)) |
(fabs.f64 y) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal 1/2 binary64) y)) |
(*.f64 #s(literal 1/2 binary64) y) |
#s(literal 1/2 binary64) |
#s(approx (+ x (* y x)) (fma.f64 y x x)) |
(fma.f64 y x x) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 #s(literal 1/2 binary64) y))) |
(+.f64 x (*.f64 #s(literal 1/2 binary64) y)) |
| Outputs |
|---|
(-.f64 x #s(approx (* y x) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y y))) |
x |
(*.f64 x #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) x) |
(+.f64 x x) |
(/.f64 x #s(literal 1 binary64)) |
#s(approx (* y x) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y y)) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y) |
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) #s(literal -1/2 binary64)) (*.f64 y x) y) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64))) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y y) (fma.f64 (*.f64 #s(literal -1/2 binary64) #s(literal -1/2 binary64)) (*.f64 y x) #s(literal 1 binary64))) |
(*.f64 y (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64))) |
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) #s(literal -1/2 binary64)) (*.f64 y x) #s(literal 1 binary64)) (/.f64 y (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)))) |
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) #s(literal -1/2 binary64)) (*.f64 y x) #s(literal 1 binary64)) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64))) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) (fma.f64 (*.f64 #s(literal -1/2 binary64) #s(literal -1/2 binary64)) (*.f64 y x) #s(literal 1 binary64))) |
(*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64))) |
(*.f64 (pow.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 1 binary64))) (pow.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) (/.f64 #s(literal 3 binary64) #s(literal 1 binary64)))) |
(*.f64 x #s(literal -1/2 binary64)) |
(*.f64 #s(literal -1/2 binary64) x) |
(*.f64 (*.f64 x #s(literal -1/2 binary64)) #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) (*.f64 x #s(literal -1/2 binary64))) |
(*.f64 x (*.f64 #s(literal -1/2 binary64) #s(literal 1 binary64))) |
#s(literal -1/2 binary64) |
y |
(*.f64 y #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) y) |
(*.f64 y y) |
(*.f64 (pow.f64 y (/.f64 #s(literal 3 binary64) #s(literal 1 binary64))) (pow.f64 y (/.f64 #s(literal 3 binary64) #s(literal 1 binary64)))) |
#s(literal 1 binary64) |
#s(literal 2 binary64) |
#s(literal 0 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 3 binary64)) |
(*.f64 #s(literal 3 binary64) #s(literal 1 binary64)) |
#s(approx (+ (* y x) x) y) |
y |
(*.f64 y #s(literal 1 binary64)) |
(*.f64 #s(literal 1 binary64) y) |
(*.f64 y y) |
(*.f64 (pow.f64 y (/.f64 #s(literal 3 binary64) #s(literal 1 binary64))) (pow.f64 y (/.f64 #s(literal 3 binary64) #s(literal 1 binary64)))) |
#s(approx (+ (* y x) x) (*.f64 #s(literal 1/2 binary64) y)) |
(*.f64 #s(literal 1/2 binary64) y) |
(*.f64 y #s(literal 1/2 binary64)) |
(*.f64 (*.f64 #s(literal 1/2 binary64) y) y) |
(*.f64 (neg.f64 #s(literal 1/2 binary64)) y) |
(*.f64 y (*.f64 #s(literal 1/2 binary64) y)) |
#s(literal 1/2 binary64) |
(neg.f64 (neg.f64 #s(literal 1/2 binary64))) |
#s(approx (+ (* y x) x) (fma.f64 y x x)) |
(*.f64 (*.f64 x x) (fma.f64 y x x)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) (fma.f64 y x x)) |
(*.f64 (-.f64 y #s(literal 1 binary64)) x) |
(*.f64 (-.f64 y #s(literal 1 binary64)) (*.f64 x x)) |
(*.f64 (fma.f64 y x x) (fma.f64 y x x)) |
#s(approx (+ (* y x) x) (fma.f64 y #s(literal 1/2 binary64) x)) |
(*.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) #s(literal 1/2 binary64)) y (*.f64 x x)) (fma.f64 y #s(literal 1/2 binary64) x)) |
(*.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) #s(literal 1/2 binary64)) y (*.f64 x x)) (fma.f64 (*.f64 #s(literal 1/2 binary64) y) (fma.f64 y #s(literal 1/2 binary64) x) (*.f64 x x))) |
(*.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) y) (fma.f64 y #s(literal 1/2 binary64) x) (*.f64 x x)) (fma.f64 (*.f64 #s(literal 1/2 binary64) #s(literal 1/2 binary64)) y (*.f64 x x))) |
(*.f64 (fma.f64 y #s(literal 1/2 binary64) x) (fma.f64 (*.f64 #s(literal 1/2 binary64) #s(literal 1/2 binary64)) y (*.f64 x x))) |
(*.f64 (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) #s(literal 1/2 binary64)) y) (*.f64 x x)) (neg.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) y) (fma.f64 y #s(literal 1/2 binary64) x) (*.f64 x x)))) |
Compiled 3 720 to 723 computations (80.6% saved)
13 alts after pruning (4 fresh and 9 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 150 | 3 | 153 |
| Fresh | 0 | 1 | 1 |
| Picked | 2 | 3 | 5 |
| Done | 0 | 6 | 6 |
| Total | 152 | 13 | 165 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))))) |
| ✓ | 64.7% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
| ✓ | 62.4% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y))) |
| ✓ | 75.7% | (-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
| 59.8% | #s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) y) y))) y)) | |
| ✓ | 27.2% | #s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
| ✓ | 62.3% | #s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))))) |
| 49.8% | #s(approx (+ (* y x) x) (fma.f64 y #s(literal 1/2 binary64) x)) | |
| 7.3% | #s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 (neg.f64 #s(literal 1/2 binary64)) y)) | |
| ✓ | 3.1% | #s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal 1/2 binary64) y)) |
| ✓ | 15.2% | #s(approx (+ x (/ y (+ 2 (* y x)))) (fabs.f64 y)) |
| ✓ | 3.1% | #s(approx (+ x (/ y (+ 2 (* y x)))) y) |
| 3.7% | #s(approx (+ x (* y x)) (*.f64 x y)) |
Compiled 191 to 143 computations (25.1% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) y) |
| Outputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) y) |
| Inputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) y) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fabs.f64 y)) |
| Outputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) (fabs.f64 y)) |
| Inputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) y) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fabs.f64 y)) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
#s(approx (+ x (* y x)) (*.f64 x y)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal 1/2 binary64) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 (neg.f64 #s(literal 1/2 binary64)) y)) |
#s(approx (+ x (* y x)) (fma.f64 y x x)) |
#s(approx (+ (* y x) x) (fma.f64 y #s(literal 1/2 binary64) x)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 #s(literal 1/2 binary64) y))) |
| Outputs |
|---|
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
| Inputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) y) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fabs.f64 y)) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
#s(approx (+ x (* y x)) (*.f64 x y)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal 1/2 binary64) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 (neg.f64 #s(literal 1/2 binary64)) y)) |
#s(approx (+ x (* y x)) (fma.f64 y x x)) |
#s(approx (+ (* y x) x) (fma.f64 y #s(literal 1/2 binary64) x)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 #s(literal 1/2 binary64) y))) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))))) |
| Outputs |
|---|
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
| Inputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) y) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fabs.f64 y)) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
#s(approx (+ x (* y x)) (*.f64 x y)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal 1/2 binary64) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 (neg.f64 #s(literal 1/2 binary64)) y)) |
#s(approx (+ x (* y x)) (fma.f64 y x x)) |
#s(approx (+ (* y x) x) (fma.f64 y #s(literal 1/2 binary64) x)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 #s(literal 1/2 binary64) y))) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))))) |
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y x)))) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) y) y))) y)) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))))) |
| Outputs |
|---|
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y x)))) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
| Inputs |
|---|
#s(approx (+ x (/ y (+ 2 (* y x)))) y) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (fabs.f64 y)) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) y)) |
#s(approx (+ x (* y x)) (*.f64 x y)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 #s(literal 1/2 binary64) y)) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (*.f64 #s(literal -1 binary64) y)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (*.f64 (neg.f64 #s(literal 1/2 binary64)) y)) |
#s(approx (+ x (* y x)) (fma.f64 y x x)) |
#s(approx (+ (* y x) x) (fma.f64 y #s(literal 1/2 binary64) x)) |
#s(approx (+ x (/ y (+ 2 (* y x)))) (+.f64 x (*.f64 #s(literal 1/2 binary64) y))) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (/.f64 #s(literal 2 binary64) x))) |
#s(approx (- x (/ y (+ 1 (* y x)))) (+.f64 x (*.f64 y (-.f64 (*.f64 x y) #s(literal 1 binary64))))) |
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (*.f64 y x)))) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 (fma.f64 (*.f64 x #s(literal -1/2 binary64)) y #s(literal 1 binary64)) y))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) y) y))) y)) |
(-.f64 x #s(approx (/ y (+ 1 (/ (* x y) 2))) (*.f64 y (+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 x y)))))) |
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))))) |
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
#s(approx (- x (/ y (+ 1 (/ (* x y) 2)))) (-.f64 (*.f64 x (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (pow.f64 y #s(literal 2 binary64))))) y)) |
| Outputs |
|---|
(-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) #s(approx (/ (* x y) 2) (*.f64 #s(literal 1/2 binary64) (*.f64 x y)))))) |
18 calls:
| 16.0ms | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
| 12.0ms | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
| 10.0ms | x |
| 9.0ms | y |
| 7.0ms | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 3.1% | 1 | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
| 3.1% | 1 | y |
| 3.1% | 1 | x |
| 15.2% | 1 | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
| 15.2% | 1 | x |
| 15.2% | 1 | y |
| 75.7% | 1 | x |
| 75.7% | 1 | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
| 75.7% | 1 | y |
| 91.5% | 3 | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
| 91.2% | 3 | x |
| 93.7% | 3 | y |
| 92.6% | 1 | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
| 92.6% | 1 | x |
| 97.2% | 3 | y |
| 100.0% | 1 | (-.f64 x (/.f64 y (+.f64 #s(literal 1 binary64) (/.f64 (*.f64 x y) #s(literal 2 binary64))))) |
| 100.0% | 1 | x |
| 100.0% | 1 | y |
Compiled 358 to 162 computations (54.7% saved)
| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 15.0ms | 3.159640360695602e+184 | 9.37156653232565e+187 |
| 12.0ms | -5.33534508583671e+176 | -2.0110149973941473e+159 |
| 11.0ms | 288× | 0 | valid |
Compiled 446 to 392 computations (12.1% saved)
ival-div!: 3.0ms (52.5% of total)ival-mult!: 2.0ms (35% of total)ival-sub!: 1.0ms (17.5% of total)ival-add!: 1.0ms (17.5% of total)adjust: 0.0ms (0% of total)| 2× | binary-search |
| 1× | narrow-enough |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 9.0ms | 1.7230152996067986e+123 | 3.6113855909463286e+127 |
| 9.0ms | -2.1768432430988128e+99 | -1.2041816829531046e+95 |
| 10.0ms | 256× | 0 | valid |
Compiled 462 to 398 computations (13.9% saved)
ival-div!: 2.0ms (41% of total)ival-sub!: 1.0ms (20.5% of total)ival-add!: 1.0ms (20.5% of total)ival-mult!: 1.0ms (20.5% of total)adjust: 0.0ms (0% of total)| 1× | fuel |
Compiled 151 to 45 computations (70.2% saved)
Compiled 162 to 54 computations (66.7% saved)
Loading profile data...