\frac{\left(1 + \frac{1}{\varepsilon}\right) \cdot e^{-\left(1 - \varepsilon\right) \cdot x} - \left(\frac{1}{\varepsilon} - 1\right) \cdot e^{-\left(1 + \varepsilon\right) \cdot x}}{2}\begin{array}{l}
\mathbf{if}\;x \le 3.434809865163426042522110932873457417314 \cdot 10^{-10}:\\
\;\;\;\;\frac{\left(2 - \frac{x \cdot x}{\frac{\varepsilon}{x}} \cdot 2.77555756156289135105907917022705078125 \cdot 10^{-17}\right) - 1 \cdot \left(x \cdot x\right)}{2}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{1}{e^{\left(\varepsilon + 1\right) \cdot x}} - \left(\frac{\frac{1}{\varepsilon}}{e^{\left(\varepsilon + 1\right) \cdot x}} - \left(\frac{1}{\varepsilon} + 1\right) \cdot e^{\left(\varepsilon - 1\right) \cdot x}\right)}{2}\\
\end{array}double f(double x, double eps) {
double r2445875 = 1.0;
double r2445876 = eps;
double r2445877 = r2445875 / r2445876;
double r2445878 = r2445875 + r2445877;
double r2445879 = r2445875 - r2445876;
double r2445880 = x;
double r2445881 = r2445879 * r2445880;
double r2445882 = -r2445881;
double r2445883 = exp(r2445882);
double r2445884 = r2445878 * r2445883;
double r2445885 = r2445877 - r2445875;
double r2445886 = r2445875 + r2445876;
double r2445887 = r2445886 * r2445880;
double r2445888 = -r2445887;
double r2445889 = exp(r2445888);
double r2445890 = r2445885 * r2445889;
double r2445891 = r2445884 - r2445890;
double r2445892 = 2.0;
double r2445893 = r2445891 / r2445892;
return r2445893;
}
double f(double x, double eps) {
double r2445894 = x;
double r2445895 = 3.434809865163426e-10;
bool r2445896 = r2445894 <= r2445895;
double r2445897 = 2.0;
double r2445898 = r2445894 * r2445894;
double r2445899 = eps;
double r2445900 = r2445899 / r2445894;
double r2445901 = r2445898 / r2445900;
double r2445902 = 2.7755575615628914e-17;
double r2445903 = r2445901 * r2445902;
double r2445904 = r2445897 - r2445903;
double r2445905 = 1.0;
double r2445906 = r2445905 * r2445898;
double r2445907 = r2445904 - r2445906;
double r2445908 = r2445907 / r2445897;
double r2445909 = r2445899 + r2445905;
double r2445910 = r2445909 * r2445894;
double r2445911 = exp(r2445910);
double r2445912 = r2445905 / r2445911;
double r2445913 = r2445905 / r2445899;
double r2445914 = r2445913 / r2445911;
double r2445915 = r2445913 + r2445905;
double r2445916 = r2445899 - r2445905;
double r2445917 = r2445916 * r2445894;
double r2445918 = exp(r2445917);
double r2445919 = r2445915 * r2445918;
double r2445920 = r2445914 - r2445919;
double r2445921 = r2445912 - r2445920;
double r2445922 = r2445921 / r2445897;
double r2445923 = r2445896 ? r2445908 : r2445922;
return r2445923;
}



Bits error versus x



Bits error versus eps
Results
if x < 3.434809865163426e-10Initial program 38.9
Simplified38.9
Taylor expanded around 0 7.1
Simplified7.1
if 3.434809865163426e-10 < x Initial program 2.8
Simplified2.8
rmApplied div-sub2.8
Applied associate-+l-2.6
Final simplification5.9
herbie shell --seed 2019179
(FPCore (x eps)
:name "NMSE Section 6.1 mentioned, A"
(/ (- (* (+ 1.0 (/ 1.0 eps)) (exp (- (* (- 1.0 eps) x)))) (* (- (/ 1.0 eps) 1.0) (exp (- (* (+ 1.0 eps) x))))) 2.0))