\frac{e^{x}}{e^{x} - 1}\frac{e^{x}}{\mathsf{expm1}\left(x\right)}double f(double x) {
double r3730360 = x;
double r3730361 = exp(r3730360);
double r3730362 = 1.0;
double r3730363 = r3730361 - r3730362;
double r3730364 = r3730361 / r3730363;
return r3730364;
}
double f(double x) {
double r3730365 = x;
double r3730366 = exp(r3730365);
double r3730367 = expm1(r3730365);
double r3730368 = r3730366 / r3730367;
return r3730368;
}




Bits error versus x
Results
| Original | 39.7 |
|---|---|
| Target | 39.3 |
| Herbie | 0.5 |
Initial program 39.7
rmApplied expm1-log1p-u39.7
Simplified0.5
Final simplification0.5
herbie shell --seed 2019163 +o rules:numerics
(FPCore (x)
:name "expq2 (section 3.11)"
:herbie-target
(/ 1 (- 1 (exp (- x))))
(/ (exp x) (- (exp x) 1)))