\frac{e^{x}}{e^{x} - 1}\frac{e^{x}}{\mathsf{expm1}\left(x\right)}double f(double x) {
double r2830714 = x;
double r2830715 = exp(r2830714);
double r2830716 = 1.0;
double r2830717 = r2830715 - r2830716;
double r2830718 = r2830715 / r2830717;
return r2830718;
}
double f(double x) {
double r2830719 = x;
double r2830720 = exp(r2830719);
double r2830721 = expm1(r2830719);
double r2830722 = r2830720 / r2830721;
return r2830722;
}




Bits error versus x
Results
| Original | 39.9 |
|---|---|
| Target | 39.4 |
| Herbie | 0.4 |
Initial program 39.9
rmApplied expm1-def0.4
Final simplification0.4
herbie shell --seed 2019129 +o rules:numerics
(FPCore (x)
:name "expq2 (section 3.11)"
:herbie-target
(/ 1 (- 1 (exp (- x))))
(/ (exp x) (- (exp x) 1)))