\frac{e^{x} - 1}{x}\begin{array}{l}
\mathbf{if}\;x \le -0.000188050340254322:\\
\;\;\;\;\frac{\left(\sqrt[3]{\log \left(e^{-1 + e^{x}}\right)} \cdot \sqrt[3]{\log \left(e^{-1 + e^{x}}\right)}\right) \cdot \sqrt[3]{\log \left(e^{-1 + e^{x}}\right)}}{x}\\
\mathbf{else}:\\
\;\;\;\;\frac{\left(x \cdot x\right) \cdot \left(\frac{1}{6} \cdot x + \frac{1}{2}\right) + x}{x}\\
\end{array}double f(double x) {
double r1369078 = x;
double r1369079 = exp(r1369078);
double r1369080 = 1.0;
double r1369081 = r1369079 - r1369080;
double r1369082 = r1369081 / r1369078;
return r1369082;
}
double f(double x) {
double r1369083 = x;
double r1369084 = -0.000188050340254322;
bool r1369085 = r1369083 <= r1369084;
double r1369086 = -1.0;
double r1369087 = exp(r1369083);
double r1369088 = r1369086 + r1369087;
double r1369089 = exp(r1369088);
double r1369090 = log(r1369089);
double r1369091 = cbrt(r1369090);
double r1369092 = r1369091 * r1369091;
double r1369093 = r1369092 * r1369091;
double r1369094 = r1369093 / r1369083;
double r1369095 = r1369083 * r1369083;
double r1369096 = 0.16666666666666666;
double r1369097 = r1369096 * r1369083;
double r1369098 = 0.5;
double r1369099 = r1369097 + r1369098;
double r1369100 = r1369095 * r1369099;
double r1369101 = r1369100 + r1369083;
double r1369102 = r1369101 / r1369083;
double r1369103 = r1369085 ? r1369094 : r1369102;
return r1369103;
}




Bits error versus x
Results
| Original | 39.4 |
|---|---|
| Target | 38.6 |
| Herbie | 0.3 |
if x < -0.000188050340254322Initial program 0.1
rmApplied add-log-exp0.1
Applied add-log-exp0.1
Applied diff-log0.1
Simplified0.1
rmApplied add-cube-cbrt0.1
if -0.000188050340254322 < x Initial program 60.2
Taylor expanded around 0 0.4
Simplified0.4
Final simplification0.3
herbie shell --seed 2019152
(FPCore (x)
:name "Kahan's exp quotient"
:herbie-target
(if (and (< x 1) (> x -1)) (/ (- (exp x) 1) (log (exp x))) (/ (- (exp x) 1) x))
(/ (- (exp x) 1) x))