\frac{1}{2} \cdot \log \left(\frac{1 + x}{1 - x}\right)\left(x \cdot \left(2 + \frac{2}{3} \cdot \left(x \cdot x\right)\right) + {x}^{5} \cdot \frac{2}{5}\right) \cdot \frac{1}{2}double f(double x) {
double r1846298 = 1.0;
double r1846299 = 2.0;
double r1846300 = r1846298 / r1846299;
double r1846301 = x;
double r1846302 = r1846298 + r1846301;
double r1846303 = r1846298 - r1846301;
double r1846304 = r1846302 / r1846303;
double r1846305 = log(r1846304);
double r1846306 = r1846300 * r1846305;
return r1846306;
}
double f(double x) {
double r1846307 = x;
double r1846308 = 2.0;
double r1846309 = 0.6666666666666666;
double r1846310 = r1846307 * r1846307;
double r1846311 = r1846309 * r1846310;
double r1846312 = r1846308 + r1846311;
double r1846313 = r1846307 * r1846312;
double r1846314 = 5.0;
double r1846315 = pow(r1846307, r1846314);
double r1846316 = 0.4;
double r1846317 = r1846315 * r1846316;
double r1846318 = r1846313 + r1846317;
double r1846319 = 0.5;
double r1846320 = r1846318 * r1846319;
return r1846320;
}



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