\frac{e^{x}}{e^{x} - 1}\frac{e^{x} + 1}{\mathsf{expm1}\left(\left(x + x\right)\right)} \cdot e^{x}double f(double x) {
double r3148445 = x;
double r3148446 = exp(r3148445);
double r3148447 = 1.0;
double r3148448 = r3148446 - r3148447;
double r3148449 = r3148446 / r3148448;
return r3148449;
}
double f(double x) {
double r3148450 = x;
double r3148451 = exp(r3148450);
double r3148452 = 1.0;
double r3148453 = r3148451 + r3148452;
double r3148454 = r3148450 + r3148450;
double r3148455 = expm1(r3148454);
double r3148456 = r3148453 / r3148455;
double r3148457 = r3148456 * r3148451;
return r3148457;
}




Bits error versus x
Results
| Original | 40.4 |
|---|---|
| Target | 40.1 |
| Herbie | 0.4 |
Initial program 40.4
rmApplied flip--40.4
Applied associate-/r/40.4
Simplified0.4
rmApplied div-inv0.4
Applied associate-*l*0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019132 +o rules:numerics
(FPCore (x)
:name "expq2 (section 3.11)"
:herbie-target
(/ 1 (- 1 (exp (- x))))
(/ (exp x) (- (exp x) 1)))