\frac{2}{e^{x} + e^{-x}}\begin{array}{l}
\mathbf{if}\;e^{x} + e^{-x} \le 2.0000000483992446:\\
\;\;\;\;\frac{2}{{x}^{2} + \left(\frac{1}{12} \cdot {x}^{4} + 2\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{2}{\left(\sqrt[3]{e^{x} + e^{-x}} \cdot \sqrt[3]{e^{x} + e^{-x}}\right) \cdot \sqrt[3]{e^{x} + e^{-x}}}\\
\end{array}double f(double x) {
double r60638 = 2.0;
double r60639 = x;
double r60640 = exp(r60639);
double r60641 = -r60639;
double r60642 = exp(r60641);
double r60643 = r60640 + r60642;
double r60644 = r60638 / r60643;
return r60644;
}
double f(double x) {
double r60645 = x;
double r60646 = exp(r60645);
double r60647 = -r60645;
double r60648 = exp(r60647);
double r60649 = r60646 + r60648;
double r60650 = 2.0000000483992446;
bool r60651 = r60649 <= r60650;
double r60652 = 2.0;
double r60653 = 2.0;
double r60654 = pow(r60645, r60653);
double r60655 = 0.08333333333333333;
double r60656 = 4.0;
double r60657 = pow(r60645, r60656);
double r60658 = r60655 * r60657;
double r60659 = r60658 + r60653;
double r60660 = r60654 + r60659;
double r60661 = r60652 / r60660;
double r60662 = cbrt(r60649);
double r60663 = r60662 * r60662;
double r60664 = r60663 * r60662;
double r60665 = r60652 / r60664;
double r60666 = r60651 ? r60661 : r60665;
return r60666;
}



Bits error versus x
Results
if (+ (exp x) (exp (- x))) < 2.0000000483992446Initial program 0.0
Taylor expanded around 0 0.0
if 2.0000000483992446 < (+ (exp x) (exp (- x))) Initial program 0.0
rmApplied add-cube-cbrt0.0
Final simplification0.0
herbie shell --seed 2020100
(FPCore (x)
:name "Hyperbolic secant"
:precision binary64
(/ 2 (+ (exp x) (exp (- x)))))