\frac{x}{x + 1} - \frac{x + 1}{x - 1}\begin{array}{l}
\mathbf{if}\;x \le -8055.65433913428842 \lor \neg \left(x \le 6807.5677494866923\right):\\
\;\;\;\;\frac{-1}{{x}^{2}} - \mathsf{fma}\left(3, \frac{1}{{x}^{3}}, \frac{3}{x}\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{\sqrt[3]{x} \cdot \sqrt[3]{x}}{1}, \frac{\sqrt[3]{x}}{x + 1}, -\frac{x + 1}{x - 1}\right)\\
\end{array}double code(double x) {
return ((x / (x + 1.0)) - ((x + 1.0) / (x - 1.0)));
}
double code(double x) {
double temp;
if (((x <= -8055.654339134288) || !(x <= 6807.567749486692))) {
temp = ((-1.0 / pow(x, 2.0)) - fma(3.0, (1.0 / pow(x, 3.0)), (3.0 / x)));
} else {
temp = fma(((cbrt(x) * cbrt(x)) / 1.0), (cbrt(x) / (x + 1.0)), -((x + 1.0) / (x - 1.0)));
}
return temp;
}



Bits error versus x
Results
if x < -8055.654339134288 or 6807.567749486692 < x Initial program 59.3
Taylor expanded around inf 0.3
Simplified0.3
Taylor expanded around 0 0.3
Simplified0.0
if -8055.654339134288 < x < 6807.567749486692Initial program 0.1
rmApplied *-un-lft-identity0.1
Applied add-cube-cbrt0.1
Applied times-frac0.1
Applied fma-neg0.1
Final simplification0.1
herbie shell --seed 2020053 +o rules:numerics
(FPCore (x)
:name "Asymptote C"
:precision binary64
(- (/ x (+ x 1)) (/ (+ x 1) (- x 1))))