\frac{1}{x + 1} - \frac{1}{x}\begin{array}{l}
\mathbf{if}\;x \le -1.9941623063372853 \cdot 10^{+44}:\\
\;\;\;\;\frac{1}{\left(x \cdot x\right) \cdot x} - \left(\frac{1}{\left(x \cdot x\right) \cdot \left(x \cdot x\right)} + \frac{\frac{1}{x}}{x}\right)\\
\mathbf{elif}\;x \le 158565.28261171645:\\
\;\;\;\;\frac{-\left(\left(x \cdot x\right) \cdot \left(x \cdot x\right) - \left(1 - x\right) \cdot \left(1 - x\right)\right)}{\mathsf{fma}\left(x \cdot x, x \cdot x, x\right) \cdot \left(x + \mathsf{fma}\left(x, x, -1\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\left(x \cdot x\right) \cdot x} - \left(\frac{1}{\left(x \cdot x\right) \cdot \left(x \cdot x\right)} + \frac{\frac{1}{x}}{x}\right)\\
\end{array}double f(double x) {
double r1770788 = 1.0;
double r1770789 = x;
double r1770790 = r1770789 + r1770788;
double r1770791 = r1770788 / r1770790;
double r1770792 = r1770788 / r1770789;
double r1770793 = r1770791 - r1770792;
return r1770793;
}
double f(double x) {
double r1770794 = x;
double r1770795 = -1.9941623063372853e+44;
bool r1770796 = r1770794 <= r1770795;
double r1770797 = 1.0;
double r1770798 = r1770794 * r1770794;
double r1770799 = r1770798 * r1770794;
double r1770800 = r1770797 / r1770799;
double r1770801 = r1770798 * r1770798;
double r1770802 = r1770797 / r1770801;
double r1770803 = r1770797 / r1770794;
double r1770804 = r1770803 / r1770794;
double r1770805 = r1770802 + r1770804;
double r1770806 = r1770800 - r1770805;
double r1770807 = 158565.28261171645;
bool r1770808 = r1770794 <= r1770807;
double r1770809 = r1770797 - r1770794;
double r1770810 = r1770809 * r1770809;
double r1770811 = r1770801 - r1770810;
double r1770812 = -r1770811;
double r1770813 = fma(r1770798, r1770798, r1770794);
double r1770814 = -1.0;
double r1770815 = fma(r1770794, r1770794, r1770814);
double r1770816 = r1770794 + r1770815;
double r1770817 = r1770813 * r1770816;
double r1770818 = r1770812 / r1770817;
double r1770819 = r1770808 ? r1770818 : r1770806;
double r1770820 = r1770796 ? r1770806 : r1770819;
return r1770820;
}



Bits error versus x
if x < -1.9941623063372853e+44 or 158565.28261171645 < x Initial program 27.7
rmApplied frac-sub27.1
Simplified27.1
rmApplied flip3-+60.7
Applied associate-*l/60.7
Applied associate-/r/60.7
Simplified50.3
rmApplied pow150.3
Applied pow150.3
Applied pow-prod-up50.3
Applied pow150.3
Applied pow150.3
Applied pow-prod-up50.3
Applied pow-prod-up50.2
Simplified50.2
Taylor expanded around inf 0.7
Simplified0.1
if -1.9941623063372853e+44 < x < 158565.28261171645Initial program 3.9
rmApplied frac-sub3.2
Simplified3.2
rmApplied flip3-+3.2
Applied associate-*l/3.2
Applied associate-/r/3.2
Simplified0.1
rmApplied flip-+0.1
Applied frac-times0.1
Simplified0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2019162 +o rules:numerics
(FPCore (x)
:name "2frac (problem 3.3.1)"
(- (/ 1 (+ x 1)) (/ 1 x)))