\frac{e^{x} - 1}{x}\begin{array}{l}
\mathbf{if}\;\frac{e^{x} - 1}{x} \le 0.0:\\
\;\;\;\;\sqrt[3]{\mathsf{fma}\left(x, \mathsf{fma}\left(\frac{1}{6}, x, \frac{1}{2}\right), 1\right) \cdot \left(\mathsf{fma}\left(x, \mathsf{fma}\left(\frac{1}{6}, x, \frac{1}{2}\right), 1\right) \cdot \mathsf{fma}\left(x, \mathsf{fma}\left(\frac{1}{6}, x, \frac{1}{2}\right), 1\right)\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{e^{x}}{x} - \frac{1}{x}\\
\end{array}double f(double x) {
double r3397837 = x;
double r3397838 = exp(r3397837);
double r3397839 = 1.0;
double r3397840 = r3397838 - r3397839;
double r3397841 = r3397840 / r3397837;
return r3397841;
}
double f(double x) {
double r3397842 = x;
double r3397843 = exp(r3397842);
double r3397844 = 1.0;
double r3397845 = r3397843 - r3397844;
double r3397846 = r3397845 / r3397842;
double r3397847 = 0.0;
bool r3397848 = r3397846 <= r3397847;
double r3397849 = 0.16666666666666666;
double r3397850 = 0.5;
double r3397851 = fma(r3397849, r3397842, r3397850);
double r3397852 = 1.0;
double r3397853 = fma(r3397842, r3397851, r3397852);
double r3397854 = r3397853 * r3397853;
double r3397855 = r3397853 * r3397854;
double r3397856 = cbrt(r3397855);
double r3397857 = r3397843 / r3397842;
double r3397858 = r3397844 / r3397842;
double r3397859 = r3397857 - r3397858;
double r3397860 = r3397848 ? r3397856 : r3397859;
return r3397860;
}




Bits error versus x
| Original | 39.8 |
|---|---|
| Target | 40.0 |
| Herbie | 0.6 |
if (/ (- (exp x) 1.0) x) < 0.0Initial program 62.0
Taylor expanded around 0 0
Simplified0
rmApplied add-cbrt-cube0
if 0.0 < (/ (- (exp x) 1.0) x) Initial program 2.7
rmApplied div-sub1.7
Final simplification0.6
herbie shell --seed 2019200 +o rules:numerics
(FPCore (x)
:name "Kahan's exp quotient"
: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))