\frac{e^{x} - 1}{x}\begin{array}{l}
\mathbf{if}\;x \le -1.2034034236075878 \cdot 10^{-4}:\\
\;\;\;\;\frac{\frac{\frac{{\left(e^{x \cdot 3}\right)}^{3} - {\left({1}^{3}\right)}^{3}}{\left({\left(e^{x}\right)}^{6} + e^{x \cdot 3} \cdot {1}^{3}\right) + {1}^{6}}}{1 \cdot \left(1 + e^{x}\right) + e^{x + x}}}{x}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{6} \cdot {x}^{2} + \left(\frac{1}{2} \cdot x + 1\right)\\
\end{array}double f(double x) {
double r82407 = x;
double r82408 = exp(r82407);
double r82409 = 1.0;
double r82410 = r82408 - r82409;
double r82411 = r82410 / r82407;
return r82411;
}
double f(double x) {
double r82412 = x;
double r82413 = -0.00012034034236075878;
bool r82414 = r82412 <= r82413;
double r82415 = 3.0;
double r82416 = r82412 * r82415;
double r82417 = exp(r82416);
double r82418 = pow(r82417, r82415);
double r82419 = 1.0;
double r82420 = pow(r82419, r82415);
double r82421 = pow(r82420, r82415);
double r82422 = r82418 - r82421;
double r82423 = exp(r82412);
double r82424 = 6.0;
double r82425 = pow(r82423, r82424);
double r82426 = r82417 * r82420;
double r82427 = r82425 + r82426;
double r82428 = pow(r82419, r82424);
double r82429 = r82427 + r82428;
double r82430 = r82422 / r82429;
double r82431 = r82419 + r82423;
double r82432 = r82419 * r82431;
double r82433 = r82412 + r82412;
double r82434 = exp(r82433);
double r82435 = r82432 + r82434;
double r82436 = r82430 / r82435;
double r82437 = r82436 / r82412;
double r82438 = 0.16666666666666666;
double r82439 = 2.0;
double r82440 = pow(r82412, r82439);
double r82441 = r82438 * r82440;
double r82442 = 0.5;
double r82443 = r82442 * r82412;
double r82444 = 1.0;
double r82445 = r82443 + r82444;
double r82446 = r82441 + r82445;
double r82447 = r82414 ? r82437 : r82446;
return r82447;
}




Bits error versus x
Results
| Original | 39.6 |
|---|---|
| Target | 40.1 |
| Herbie | 0.3 |
if x < -0.00012034034236075878Initial program 0.1
rmApplied flip3--0.1
Simplified0.1
rmApplied pow-exp0.0
rmApplied flip3--0.0
Simplified0.0
if -0.00012034034236075878 < x Initial program 60.0
Taylor expanded around 0 0.4
Final simplification0.3
herbie shell --seed 2020056
(FPCore (x)
:name "Kahan's exp quotient"
:precision binary64
:herbie-target
(if (and (< x 1) (> x -1)) (/ (- (exp x) 1) (log (exp x))) (/ (- (exp x) 1) x))
(/ (- (exp x) 1) x))