\frac{e^{x} - 1}{x}\frac{1}{x} \cdot \mathsf{expm1}\left(x\right)double f(double x) {
double r6403616 = x;
double r6403617 = exp(r6403616);
double r6403618 = 1.0;
double r6403619 = r6403617 - r6403618;
double r6403620 = r6403619 / r6403616;
return r6403620;
}
double f(double x) {
double r6403621 = 1.0;
double r6403622 = x;
double r6403623 = r6403621 / r6403622;
double r6403624 = expm1(r6403622);
double r6403625 = r6403623 * r6403624;
return r6403625;
}




Bits error versus x
Results
| Original | 39.5 |
|---|---|
| Target | 38.7 |
| Herbie | 0.1 |
Initial program 39.5
Simplified0.0
rmApplied div-inv0.1
Final simplification0.1
herbie shell --seed 2019124 +o rules:numerics
(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))