\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 r1873780 = 1.0;
double r1873781 = x;
double r1873782 = r1873781 + r1873780;
double r1873783 = r1873780 / r1873782;
double r1873784 = r1873780 / r1873781;
double r1873785 = r1873783 - r1873784;
return r1873785;
}
double f(double x) {
double r1873786 = x;
double r1873787 = -1.9941623063372853e+44;
bool r1873788 = r1873786 <= r1873787;
double r1873789 = 1.0;
double r1873790 = r1873786 * r1873786;
double r1873791 = r1873790 * r1873786;
double r1873792 = r1873789 / r1873791;
double r1873793 = r1873790 * r1873790;
double r1873794 = r1873789 / r1873793;
double r1873795 = r1873789 / r1873786;
double r1873796 = r1873795 / r1873786;
double r1873797 = r1873794 + r1873796;
double r1873798 = r1873792 - r1873797;
double r1873799 = 158565.28261171645;
bool r1873800 = r1873786 <= r1873799;
double r1873801 = r1873789 - r1873786;
double r1873802 = r1873801 * r1873801;
double r1873803 = r1873793 - r1873802;
double r1873804 = -r1873803;
double r1873805 = fma(r1873790, r1873790, r1873786);
double r1873806 = -1.0;
double r1873807 = fma(r1873786, r1873786, r1873806);
double r1873808 = r1873786 + r1873807;
double r1873809 = r1873805 * r1873808;
double r1873810 = r1873804 / r1873809;
double r1873811 = r1873800 ? r1873810 : r1873798;
double r1873812 = r1873788 ? r1873798 : r1873811;
return r1873812;
}



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
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)))