\frac{e^{x} - 1}{x}\begin{array}{l}
\mathbf{if}\;x \le -1.28069707875689865 \cdot 10^{-4}:\\
\;\;\;\;\frac{\frac{e^{x} \cdot e^{x} - 1 \cdot 1}{e^{x} + 1}}{x}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{6} \cdot {x}^{2} + \left(\frac{1}{2} \cdot x + 1\right)\\
\end{array}double code(double x) {
return ((double) (((double) (((double) exp(x)) - 1.0)) / x));
}
double code(double x) {
double VAR;
if ((x <= -0.00012806970787568986)) {
VAR = ((double) (((double) (((double) (((double) (((double) exp(x)) * ((double) exp(x)))) - ((double) (1.0 * 1.0)))) / ((double) (((double) exp(x)) + 1.0)))) / x));
} else {
VAR = ((double) (((double) (0.16666666666666666 * ((double) pow(x, 2.0)))) + ((double) (((double) (0.5 * x)) + 1.0))));
}
return VAR;
}




Bits error versus x
Results
| Original | 39.3 |
|---|---|
| Target | 39.7 |
| Herbie | 0.3 |
if x < -0.00012806970787568986Initial program 0.1
rmApplied flip--0.1
if -0.00012806970787568986 < x Initial program 60.2
Taylor expanded around 0 0.4
Final simplification0.3
herbie shell --seed 2020131
(FPCore (x)
:name "Kahan's exp quotient"
:precision binary64
:herbie-target
(if (and (< x 1.0) (> x -1.0)) (/ (- (exp x) 1.0) (log (exp x))) (/ (- (exp x) 1.0) x))
(/ (- (exp x) 1.0) x))