1 - \frac{\left(1 - x\right) \cdot y}{y + 1}\begin{array}{l}
\mathbf{if}\;y \le -129624842.47456154 \lor \neg \left(y \le 184531412.18592519\right):\\
\;\;\;\;1 \cdot \left(\frac{1}{y} - \frac{x}{y}\right) + x\\
\mathbf{else}:\\
\;\;\;\;1 - \frac{1 - x}{y + 1} \cdot y\\
\end{array}double f(double x, double y) {
double r573037 = 1.0;
double r573038 = x;
double r573039 = r573037 - r573038;
double r573040 = y;
double r573041 = r573039 * r573040;
double r573042 = r573040 + r573037;
double r573043 = r573041 / r573042;
double r573044 = r573037 - r573043;
return r573044;
}
double f(double x, double y) {
double r573045 = y;
double r573046 = -129624842.47456154;
bool r573047 = r573045 <= r573046;
double r573048 = 184531412.1859252;
bool r573049 = r573045 <= r573048;
double r573050 = !r573049;
bool r573051 = r573047 || r573050;
double r573052 = 1.0;
double r573053 = 1.0;
double r573054 = r573053 / r573045;
double r573055 = x;
double r573056 = r573055 / r573045;
double r573057 = r573054 - r573056;
double r573058 = r573052 * r573057;
double r573059 = r573058 + r573055;
double r573060 = r573052 - r573055;
double r573061 = r573045 + r573052;
double r573062 = r573060 / r573061;
double r573063 = r573062 * r573045;
double r573064 = r573052 - r573063;
double r573065 = r573051 ? r573059 : r573064;
return r573065;
}




Bits error versus x




Bits error versus y
Results
| Original | 22.3 |
|---|---|
| Target | 0.3 |
| Herbie | 0.2 |
if y < -129624842.47456154 or 184531412.1859252 < y Initial program 45.2
rmApplied flip3--52.0
Simplified52.0
Taylor expanded around inf 0.3
Simplified0.3
if -129624842.47456154 < y < 184531412.1859252Initial program 0.2
rmApplied associate-/l*0.2
rmApplied associate-/r/0.2
Final simplification0.2
herbie shell --seed 2020045
(FPCore (x y)
:name "Diagrams.Trail:splitAtParam from diagrams-lib-1.3.0.3, D"
:precision binary64
:herbie-target
(if (< y -3693.8482788297247) (- (/ 1 y) (- (/ x y) x)) (if (< y 6799310503.41891) (- 1 (/ (* (- 1 x) y) (+ y 1))) (- (/ 1 y) (- (/ x y) x))))
(- 1 (/ (* (- 1 x) y) (+ y 1))))