\frac{1}{x + 1} - \frac{1}{x - 1}\begin{array}{l}
\mathbf{if}\;x \le -197.6959578773428347631124779582023620605 \lor \neg \left(x \le 221.5934540176410223466518800705671310425\right):\\
\;\;\;\;\left(-\frac{2}{{x}^{6}}\right) - \left(\frac{\frac{2}{x}}{x} + \frac{2}{{x}^{4}}\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(-\frac{1}{{x}^{3} - {1}^{3}}, \mathsf{fma}\left(x, x, \left(x + 1\right) \cdot 1\right), \frac{1}{x + 1}\right) + \frac{1}{{x}^{3} - {1}^{3}} \cdot \left(\left(-\mathsf{fma}\left(x, x, \left(x + 1\right) \cdot 1\right)\right) + \mathsf{fma}\left(x, x, \left(x + 1\right) \cdot 1\right)\right)\\
\end{array}double f(double x) {
double r121661 = 1.0;
double r121662 = x;
double r121663 = r121662 + r121661;
double r121664 = r121661 / r121663;
double r121665 = r121662 - r121661;
double r121666 = r121661 / r121665;
double r121667 = r121664 - r121666;
return r121667;
}
double f(double x) {
double r121668 = x;
double r121669 = -197.69595787734283;
bool r121670 = r121668 <= r121669;
double r121671 = 221.59345401764102;
bool r121672 = r121668 <= r121671;
double r121673 = !r121672;
bool r121674 = r121670 || r121673;
double r121675 = 2.0;
double r121676 = 6.0;
double r121677 = pow(r121668, r121676);
double r121678 = r121675 / r121677;
double r121679 = -r121678;
double r121680 = r121675 / r121668;
double r121681 = r121680 / r121668;
double r121682 = 4.0;
double r121683 = pow(r121668, r121682);
double r121684 = r121675 / r121683;
double r121685 = r121681 + r121684;
double r121686 = r121679 - r121685;
double r121687 = 1.0;
double r121688 = 3.0;
double r121689 = pow(r121668, r121688);
double r121690 = pow(r121687, r121688);
double r121691 = r121689 - r121690;
double r121692 = r121687 / r121691;
double r121693 = -r121692;
double r121694 = r121668 + r121687;
double r121695 = r121694 * r121687;
double r121696 = fma(r121668, r121668, r121695);
double r121697 = r121687 / r121694;
double r121698 = fma(r121693, r121696, r121697);
double r121699 = -r121696;
double r121700 = r121699 + r121696;
double r121701 = r121692 * r121700;
double r121702 = r121698 + r121701;
double r121703 = r121674 ? r121686 : r121702;
return r121703;
}



Bits error versus x
if x < -197.69595787734283 or 221.59345401764102 < x Initial program 29.1
Taylor expanded around inf 0.8
Simplified0.8
rmApplied associate-/r*0.1
if -197.69595787734283 < x < 221.59345401764102Initial program 0.0
rmApplied flip3--0.0
Applied associate-/r/0.0
Applied add-sqr-sqrt0.2
Applied prod-diff0.2
Simplified0.0
Simplified0.0
Final simplification0.1
herbie shell --seed 2019326 +o rules:numerics
(FPCore (x)
:name "Asymptote A"
:precision binary64
(- (/ 1 (+ x 1)) (/ 1 (- x 1))))