\frac{\left(x \cdot 2\right) \cdot y}{x - y}\begin{array}{l}
\mathbf{if}\;x \le -3.849631356825476242761920153389444366702 \cdot 10^{75} \lor \neg \left(x \le 46.00635378919195517255502636544406414032\right):\\
\;\;\;\;\frac{x \cdot 2}{x - y} \cdot y\\
\mathbf{else}:\\
\;\;\;\;\left(x \cdot 2\right) \cdot \frac{y}{x - y}\\
\end{array}double f(double x, double y) {
double r303874 = x;
double r303875 = 2.0;
double r303876 = r303874 * r303875;
double r303877 = y;
double r303878 = r303876 * r303877;
double r303879 = r303874 - r303877;
double r303880 = r303878 / r303879;
return r303880;
}
double f(double x, double y) {
double r303881 = x;
double r303882 = -3.849631356825476e+75;
bool r303883 = r303881 <= r303882;
double r303884 = 46.006353789191955;
bool r303885 = r303881 <= r303884;
double r303886 = !r303885;
bool r303887 = r303883 || r303886;
double r303888 = 2.0;
double r303889 = r303881 * r303888;
double r303890 = y;
double r303891 = r303881 - r303890;
double r303892 = r303889 / r303891;
double r303893 = r303892 * r303890;
double r303894 = r303890 / r303891;
double r303895 = r303889 * r303894;
double r303896 = r303887 ? r303893 : r303895;
return r303896;
}




Bits error versus x




Bits error versus y
Results
| Original | 14.9 |
|---|---|
| Target | 0.3 |
| Herbie | 0.2 |
if x < -3.849631356825476e+75 or 46.006353789191955 < x Initial program 17.8
rmApplied associate-/l*16.7
rmApplied associate-/r/0.1
if -3.849631356825476e+75 < x < 46.006353789191955Initial program 12.7
rmApplied *-un-lft-identity12.7
Applied times-frac0.4
Simplified0.4
Final simplification0.2
herbie shell --seed 2019325 +o rules:numerics
(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)))