\frac{x - y}{\left(x \cdot 2\right) \cdot y}\frac{-0.5}{x} + \frac{0.5}{y}(FPCore (x y) :precision binary64 (/ (- x y) (* (* x 2.0) y)))
(FPCore (x y) :precision binary64 (+ (/ -0.5 x) (/ 0.5 y)))
double code(double x, double y) {
return (x - y) / ((x * 2.0) * y);
}
double code(double x, double y) {
return (-0.5 / x) + (0.5 / y);
}







Bits error versus x







Bits error versus y
Results
| Original | 15.2 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
| Alternative 1 | |
|---|---|
| Error | 15.8 |
| Cost | 520 |
| Alternative 2 | |
|---|---|
| Error | 31.0 |
| Cost | 192 |
| Alternative 3 | |
|---|---|
| Error | 61.9 |
| Cost | 64 |

Initial program 15.2
Simplified0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2021044
(FPCore (x y)
:name "Linear.Projection:inversePerspective from linear-1.19.1.3, B"
:precision binary64
:herbie-target
(- (/ 0.5 y) (/ 0.5 x))
(/ (- x y) (* (* x 2.0) y)))