Average Error: 39.6 → 0.0
Time: 8.4s
Precision: 64
\[\frac{e^{x} - 1}{x}\]
\[\frac{\mathsf{expm1}\left(x\right)}{x}\]
\frac{e^{x} - 1}{x}
\frac{\mathsf{expm1}\left(x\right)}{x}
double f(double x) {
        double r2972820 = x;
        double r2972821 = exp(r2972820);
        double r2972822 = 1.0;
        double r2972823 = r2972821 - r2972822;
        double r2972824 = r2972823 / r2972820;
        return r2972824;
}

double f(double x) {
        double r2972825 = x;
        double r2972826 = expm1(r2972825);
        double r2972827 = r2972826 / r2972825;
        return r2972827;
}

Error

Bits error versus x

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Target

Original39.6
Target38.8
Herbie0.0
\[\begin{array}{l} \mathbf{if}\;x \lt 1 \land x \gt -1:\\ \;\;\;\;\frac{e^{x} - 1}{\log \left(e^{x}\right)}\\ \mathbf{else}:\\ \;\;\;\;\frac{e^{x} - 1}{x}\\ \end{array}\]

Derivation

  1. Initial program 39.6

    \[\frac{e^{x} - 1}{x}\]
  2. Simplified0.0

    \[\leadsto \color{blue}{\frac{\mathsf{expm1}\left(x\right)}{x}}\]
  3. Final simplification0.0

    \[\leadsto \frac{\mathsf{expm1}\left(x\right)}{x}\]

Reproduce

herbie shell --seed 2019162 +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))