\frac{e^{x} - e^{-x}}{e^{x} + e^{-x}}
\frac{\mathsf{fma}\left(2, x, 0.3333333333333333 \cdot {x}^{3}\right)}{e^{x} + e^{-x}}
(FPCore (x) :precision binary64 (/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))))
(FPCore (x) :precision binary64 (/ (fma 2.0 x (* 0.3333333333333333 (pow x 3.0))) (+ (exp x) (exp (- x)))))
double code(double x) {
return (exp(x) - exp(-x)) / (exp(x) + exp(-x));
}
double code(double x) {
return fma(2.0, x, (0.3333333333333333 * pow(x, 3.0))) / (exp(x) + exp(-x));
}



Bits error versus x
Initial program 58.3
Taylor expanded in x around 0 2.1
Simplified2.1
Final simplification2.1
herbie shell --seed 2022125
(FPCore (x)
:name "Hyperbolic tangent"
:precision binary64
(/ (- (exp x) (exp (- x))) (+ (exp x) (exp (- x)))))