\frac{\left(x \cdot 2\right) \cdot y}{x - y}\begin{array}{l}
\mathbf{if}\;x \le -1.7538803200316063 \cdot 10^{49} \lor \neg \left(x \le 2.59687826800368321 \cdot 10^{-23}\right):\\
\;\;\;\;\frac{x}{x - y} \cdot \left(y \cdot 2\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{x \cdot 2}{\frac{x}{y} - 1}\\
\end{array}double f(double x, double y) {
double r521518 = x;
double r521519 = 2.0;
double r521520 = r521518 * r521519;
double r521521 = y;
double r521522 = r521520 * r521521;
double r521523 = r521518 - r521521;
double r521524 = r521522 / r521523;
return r521524;
}
double f(double x, double y) {
double r521525 = x;
double r521526 = -1.7538803200316063e+49;
bool r521527 = r521525 <= r521526;
double r521528 = 2.5968782680036832e-23;
bool r521529 = r521525 <= r521528;
double r521530 = !r521529;
bool r521531 = r521527 || r521530;
double r521532 = y;
double r521533 = r521525 - r521532;
double r521534 = r521525 / r521533;
double r521535 = 2.0;
double r521536 = r521532 * r521535;
double r521537 = r521534 * r521536;
double r521538 = r521525 * r521535;
double r521539 = r521525 / r521532;
double r521540 = 1.0;
double r521541 = r521539 - r521540;
double r521542 = r521538 / r521541;
double r521543 = r521531 ? r521537 : r521542;
return r521543;
}




Bits error versus x




Bits error versus y
Results
| Original | 15.2 |
|---|---|
| Target | 0.4 |
| Herbie | 0.2 |
if x < -1.7538803200316063e+49 or 2.5968782680036832e-23 < x Initial program 16.5
rmApplied associate-/l*15.6
rmApplied div-inv15.8
Applied times-frac0.3
Simplified0.1
if -1.7538803200316063e+49 < x < 2.5968782680036832e-23Initial program 13.9
rmApplied associate-/l*0.2
rmApplied div-sub0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2020064
(FPCore (x y)
:name "Linear.Projection:perspective from linear-1.19.1.3, B"
:precision binary64
:herbie-target
(if (< x -1.7210442634149447e+81) (* (/ (* 2 x) (- x y)) y) (if (< x 83645045635564432) (/ (* x 2) (/ (- x y) y)) (* (/ (* 2 x) (- x y)) y)))
(/ (* (* x 2) y) (- x y)))