1 - \frac{\left(1 - x\right) \cdot y}{y + 1}\begin{array}{l}
\mathbf{if}\;y \le -378501471949656.688 \lor \neg \left(y \le 325972206.362031639\right):\\
\;\;\;\;1 \cdot \left(\frac{1}{y} - \frac{x}{y}\right) + x\\
\mathbf{else}:\\
\;\;\;\;1 - \left(1 - x\right) \cdot \frac{y}{y + 1}\\
\end{array}double f(double x, double y) {
double r690691 = 1.0;
double r690692 = x;
double r690693 = r690691 - r690692;
double r690694 = y;
double r690695 = r690693 * r690694;
double r690696 = r690694 + r690691;
double r690697 = r690695 / r690696;
double r690698 = r690691 - r690697;
return r690698;
}
double f(double x, double y) {
double r690699 = y;
double r690700 = -378501471949656.7;
bool r690701 = r690699 <= r690700;
double r690702 = 325972206.36203164;
bool r690703 = r690699 <= r690702;
double r690704 = !r690703;
bool r690705 = r690701 || r690704;
double r690706 = 1.0;
double r690707 = 1.0;
double r690708 = r690707 / r690699;
double r690709 = x;
double r690710 = r690709 / r690699;
double r690711 = r690708 - r690710;
double r690712 = r690706 * r690711;
double r690713 = r690712 + r690709;
double r690714 = r690706 - r690709;
double r690715 = r690699 + r690706;
double r690716 = r690699 / r690715;
double r690717 = r690714 * r690716;
double r690718 = r690706 - r690717;
double r690719 = r690705 ? r690713 : r690718;
return r690719;
}




Bits error versus x




Bits error versus y
Results
| Original | 22.9 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
if y < -378501471949656.7 or 325972206.36203164 < y Initial program 46.2
Taylor expanded around inf 0.1
Simplified0.1
if -378501471949656.7 < y < 325972206.36203164Initial program 0.3
rmApplied *-un-lft-identity0.3
Applied times-frac0.3
Simplified0.3
Final simplification0.2
herbie shell --seed 2020060
(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))))