1 - \frac{\left(1 - x\right) \cdot y}{y + 1}\begin{array}{l}
\mathbf{if}\;y \le -4.67125714385780667 \cdot 10^{76} \lor \neg \left(y \le 1.64838597728570229 \cdot 10^{83}\right):\\
\;\;\;\;\mathsf{fma}\left(\frac{x}{y}, \frac{1}{y} - 1, x\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{y}{y + 1}, x - 1, 1\right)\\
\end{array}double f(double x, double y) {
double r702123 = 1.0;
double r702124 = x;
double r702125 = r702123 - r702124;
double r702126 = y;
double r702127 = r702125 * r702126;
double r702128 = r702126 + r702123;
double r702129 = r702127 / r702128;
double r702130 = r702123 - r702129;
return r702130;
}
double f(double x, double y) {
double r702131 = y;
double r702132 = -4.6712571438578067e+76;
bool r702133 = r702131 <= r702132;
double r702134 = 1.6483859772857023e+83;
bool r702135 = r702131 <= r702134;
double r702136 = !r702135;
bool r702137 = r702133 || r702136;
double r702138 = x;
double r702139 = r702138 / r702131;
double r702140 = 1.0;
double r702141 = r702140 / r702131;
double r702142 = r702141 - r702140;
double r702143 = fma(r702139, r702142, r702138);
double r702144 = r702131 + r702140;
double r702145 = r702131 / r702144;
double r702146 = r702138 - r702140;
double r702147 = fma(r702145, r702146, r702140);
double r702148 = r702137 ? r702143 : r702147;
return r702148;
}




Bits error versus x




Bits error versus y
| Original | 21.9 |
|---|---|
| Target | 0.2 |
| Herbie | 7.9 |
if y < -4.6712571438578067e+76 or 1.6483859772857023e+83 < y Initial program 49.8
Simplified29.8
Taylor expanded around inf 12.7
Simplified12.7
if -4.6712571438578067e+76 < y < 1.6483859772857023e+83Initial program 6.1
Simplified5.2
Final simplification7.9
herbie shell --seed 2020035 +o rules:numerics
(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))))