\frac{1}{2} \cdot \log \left(\frac{1 + x}{1 - x}\right)\frac{1}{2} \cdot \left(2 \cdot x + \left(x \cdot \left(\frac{2}{3} \cdot \left(x \cdot x\right)\right) + {x}^{5} \cdot \frac{2}{5}\right)\right)double f(double x) {
double r991783 = 1.0;
double r991784 = 2.0;
double r991785 = r991783 / r991784;
double r991786 = x;
double r991787 = r991783 + r991786;
double r991788 = r991783 - r991786;
double r991789 = r991787 / r991788;
double r991790 = log(r991789);
double r991791 = r991785 * r991790;
return r991791;
}
double f(double x) {
double r991792 = 0.5;
double r991793 = 2.0;
double r991794 = x;
double r991795 = r991793 * r991794;
double r991796 = 0.6666666666666666;
double r991797 = r991794 * r991794;
double r991798 = r991796 * r991797;
double r991799 = r991794 * r991798;
double r991800 = 5.0;
double r991801 = pow(r991794, r991800);
double r991802 = 0.4;
double r991803 = r991801 * r991802;
double r991804 = r991799 + r991803;
double r991805 = r991795 + r991804;
double r991806 = r991792 * r991805;
return r991806;
}



Bits error versus x
Results
Initial program 58.7
Simplified58.7
Taylor expanded around 0 0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2019128
(FPCore (x)
:name "Hyperbolic arc-(co)tangent"
(* (/ 1 2) (log (/ (+ 1 x) (- 1 x)))))