double f(double x) {
double r31731757 = 1.0;
double r31731758 = x;
double r31731759 = r31731758 + r31731757;
double r31731760 = r31731757 / r31731759;
double r31731761 = r31731758 - r31731757;
double r31731762 = r31731757 / r31731761;
double r31731763 = r31731760 - r31731762;
return r31731763;
}
double f(double x) {
double r31731764 = 1.0;
double r31731765 = x;
double r31731766 = -1.0;
double r31731767 = fma(r31731765, r31731765, r31731766);
double r31731768 = r31731764 / r31731767;
double r31731769 = -2.0;
double r31731770 = r31731768 * r31731769;
return r31731770;
}
\frac{1}{x + 1} - \frac{1}{x - 1}\frac{1}{(x \cdot x + -1)_*} \cdot -2


Bits error versus x
Initial program 14.7
rmApplied flip--29.3
Applied associate-/r/29.3
Applied flip-+14.7
Applied associate-/r/14.7
Applied distribute-lft-out--14.1
Simplified14.1
Simplified0.3
Final simplification0.3
herbie shell --seed 2019102 +o rules:numerics
(FPCore (x)
:name "Asymptote A"
(- (/ 1 (+ x 1)) (/ 1 (- x 1))))