\frac{\left(x \cdot 2\right) \cdot y}{x - y}\begin{array}{l}
\mathbf{if}\;\frac{\left(x \cdot 2\right) \cdot y}{x - y} \le -5.7247183736428316 \cdot 10^{-67} \lor \neg \left(\frac{\left(x \cdot 2\right) \cdot y}{x - y} \le -1.22106957429828852 \cdot 10^{-283} \lor \neg \left(\frac{\left(x \cdot 2\right) \cdot y}{x - y} \le 1.8415218432721044 \cdot 10^{-305}\right) \land \frac{\left(x \cdot 2\right) \cdot y}{x - y} \le 7.3297235194227525 \cdot 10^{-50}\right):\\
\;\;\;\;x \cdot \left(2 \cdot \frac{y}{x - y}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{\left(x \cdot 2\right) \cdot y}{x - y}\\
\end{array}double code(double x, double y) {
return ((double) (((double) (((double) (x * 2.0)) * y)) / ((double) (x - y))));
}
double code(double x, double y) {
double VAR;
if (((((double) (((double) (((double) (x * 2.0)) * y)) / ((double) (x - y)))) <= -5.7247183736428316e-67) || !((((double) (((double) (((double) (x * 2.0)) * y)) / ((double) (x - y)))) <= -1.2210695742982885e-283) || (!(((double) (((double) (((double) (x * 2.0)) * y)) / ((double) (x - y)))) <= 1.8415218432721044e-305) && (((double) (((double) (((double) (x * 2.0)) * y)) / ((double) (x - y)))) <= 7.3297235194227525e-50))))) {
VAR = ((double) (x * ((double) (2.0 * ((double) (y / ((double) (x - y))))))));
} else {
VAR = ((double) (((double) (((double) (x * 2.0)) * y)) / ((double) (x - y))));
}
return VAR;
}




Bits error versus x




Bits error versus y
Results
| Original | 15.1 |
|---|---|
| Target | 0.4 |
| Herbie | 1.1 |
if (/ (* (* x 2.0) y) (- x y)) < -5.7247183736428316e-67 or -1.22106957429828852e-283 < (/ (* (* x 2.0) y) (- x y)) < 1.8415218432721044e-305 or 7.3297235194227525e-50 < (/ (* (* x 2.0) y) (- x y)) Initial program 30.0
Simplified1.7
if -5.7247183736428316e-67 < (/ (* (* x 2.0) y) (- x y)) < -1.22106957429828852e-283 or 1.8415218432721044e-305 < (/ (* (* x 2.0) y) (- x y)) < 7.3297235194227525e-50Initial program 0.6
Final simplification1.1
herbie shell --seed 2020184
(FPCore (x y)
:name "Linear.Projection:perspective from linear-1.19.1.3, B"
:precision binary64
:herbie-target
(if (< x -1.7210442634149447e+81) (* (/ (* 2.0 x) (- x y)) y) (if (< x 8.364504563556443e+16) (/ (* x 2.0) (/ (- x y) y)) (* (/ (* 2.0 x) (- x y)) y)))
(/ (* (* x 2.0) y) (- x y)))