\frac{\left(x \cdot 2.0\right) \cdot y}{x - y}\begin{array}{l}
\mathbf{if}\;y \le -3.0638957814586657 \cdot 10^{-28}:\\
\;\;\;\;\frac{y}{x - y} \cdot \left(2.0 \cdot x\right)\\
\mathbf{elif}\;y \le 1.3615474866246526 \cdot 10^{+17}:\\
\;\;\;\;\frac{x}{x - y} \cdot \left(2.0 \cdot y\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{y}{x - y} \cdot \left(2.0 \cdot x\right)\\
\end{array}double f(double x, double y) {
double r26337273 = x;
double r26337274 = 2.0;
double r26337275 = r26337273 * r26337274;
double r26337276 = y;
double r26337277 = r26337275 * r26337276;
double r26337278 = r26337273 - r26337276;
double r26337279 = r26337277 / r26337278;
return r26337279;
}
double f(double x, double y) {
double r26337280 = y;
double r26337281 = -3.0638957814586657e-28;
bool r26337282 = r26337280 <= r26337281;
double r26337283 = x;
double r26337284 = r26337283 - r26337280;
double r26337285 = r26337280 / r26337284;
double r26337286 = 2.0;
double r26337287 = r26337286 * r26337283;
double r26337288 = r26337285 * r26337287;
double r26337289 = 1.3615474866246526e+17;
bool r26337290 = r26337280 <= r26337289;
double r26337291 = r26337283 / r26337284;
double r26337292 = r26337286 * r26337280;
double r26337293 = r26337291 * r26337292;
double r26337294 = r26337290 ? r26337293 : r26337288;
double r26337295 = r26337282 ? r26337288 : r26337294;
return r26337295;
}




Bits error versus x




Bits error versus y
Results
| Original | 14.4 |
|---|---|
| Target | 0.3 |
| Herbie | 0.1 |
if y < -3.0638957814586657e-28 or 1.3615474866246526e+17 < y Initial program 14.9
rmApplied *-un-lft-identity14.9
Applied times-frac0.1
Simplified0.1
if -3.0638957814586657e-28 < y < 1.3615474866246526e+17Initial program 13.9
rmApplied associate-/l*15.0
rmApplied div-inv15.2
Applied times-frac0.3
Simplified0.1
Final simplification0.1
herbie shell --seed 2019162 +o rules:numerics
(FPCore (x y)
:name "Linear.Projection:perspective from linear-1.19.1.3, B"
: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)))