1 - \frac{\left(1 - x\right) \cdot y}{y + 1}\begin{array}{l}
\mathbf{if}\;y \le -42972738058162806784:\\
\;\;\;\;x - \left(\frac{x \cdot 1}{y} - \frac{\frac{x \cdot 1}{y}}{y}\right)\\
\mathbf{elif}\;y \le 2375613545737851462610892407037814112256:\\
\;\;\;\;\mathsf{fma}\left(\frac{\frac{y}{\frac{\sqrt[3]{y \cdot y - 1 \cdot 1} \cdot \sqrt[3]{y + 1}}{\sqrt[3]{y - 1}}}}{\sqrt[3]{y + 1}}, x - 1, 1\right)\\
\mathbf{else}:\\
\;\;\;\;x - \left(\frac{x \cdot 1}{y} - \frac{\frac{x \cdot 1}{y}}{y}\right)\\
\end{array}double f(double x, double y) {
double r27082045 = 1.0;
double r27082046 = x;
double r27082047 = r27082045 - r27082046;
double r27082048 = y;
double r27082049 = r27082047 * r27082048;
double r27082050 = r27082048 + r27082045;
double r27082051 = r27082049 / r27082050;
double r27082052 = r27082045 - r27082051;
return r27082052;
}
double f(double x, double y) {
double r27082053 = y;
double r27082054 = -4.297273805816281e+19;
bool r27082055 = r27082053 <= r27082054;
double r27082056 = x;
double r27082057 = 1.0;
double r27082058 = r27082056 * r27082057;
double r27082059 = r27082058 / r27082053;
double r27082060 = r27082059 / r27082053;
double r27082061 = r27082059 - r27082060;
double r27082062 = r27082056 - r27082061;
double r27082063 = 2.3756135457378515e+39;
bool r27082064 = r27082053 <= r27082063;
double r27082065 = r27082053 * r27082053;
double r27082066 = r27082057 * r27082057;
double r27082067 = r27082065 - r27082066;
double r27082068 = cbrt(r27082067);
double r27082069 = r27082053 + r27082057;
double r27082070 = cbrt(r27082069);
double r27082071 = r27082068 * r27082070;
double r27082072 = r27082053 - r27082057;
double r27082073 = cbrt(r27082072);
double r27082074 = r27082071 / r27082073;
double r27082075 = r27082053 / r27082074;
double r27082076 = r27082075 / r27082070;
double r27082077 = r27082056 - r27082057;
double r27082078 = fma(r27082076, r27082077, r27082057);
double r27082079 = r27082064 ? r27082078 : r27082062;
double r27082080 = r27082055 ? r27082062 : r27082079;
return r27082080;
}




Bits error versus x




Bits error versus y
| Original | 22.5 |
|---|---|
| Target | 0.2 |
| Herbie | 7.7 |
if y < -4.297273805816281e+19 or 2.3756135457378515e+39 < y Initial program 47.6
Simplified29.7
rmApplied add-cube-cbrt30.5
Applied associate-/l*30.5
Taylor expanded around inf 14.7
Simplified14.7
if -4.297273805816281e+19 < y < 2.3756135457378515e+39Initial program 1.9
Simplified1.7
rmApplied add-cube-cbrt1.8
Applied associate-/r*1.8
rmApplied flip-+1.8
Applied cbrt-div1.8
Applied associate-*l/1.8
Final simplification7.7
herbie shell --seed 2019171 +o rules:numerics
(FPCore (x y)
:name "Diagrams.Trail:splitAtParam from diagrams-lib-1.3.0.3, D"
:herbie-target
(if (< y -3693.8482788297247) (- (/ 1.0 y) (- (/ x y) x)) (if (< y 6799310503.41891) (- 1.0 (/ (* (- 1.0 x) y) (+ y 1.0))) (- (/ 1.0 y) (- (/ x y) x))))
(- 1.0 (/ (* (- 1.0 x) y) (+ y 1.0))))