\left(e^{x} - 2\right) + e^{-x}\mathsf{fma}\left(\left(\left(x \cdot x\right) \cdot \left(x \cdot x\right)\right) \cdot \left(x \cdot x\right), \frac{1}{360}, \mathsf{fma}\left(\left(x \cdot x\right) \cdot \left(x \cdot x\right), \frac{1}{12}, x \cdot x\right)\right)double f(double x) {
double r4691679 = x;
double r4691680 = exp(r4691679);
double r4691681 = 2.0;
double r4691682 = r4691680 - r4691681;
double r4691683 = -r4691679;
double r4691684 = exp(r4691683);
double r4691685 = r4691682 + r4691684;
return r4691685;
}
double f(double x) {
double r4691686 = x;
double r4691687 = r4691686 * r4691686;
double r4691688 = r4691687 * r4691687;
double r4691689 = r4691688 * r4691687;
double r4691690 = 0.002777777777777778;
double r4691691 = 0.08333333333333333;
double r4691692 = fma(r4691688, r4691691, r4691687);
double r4691693 = fma(r4691689, r4691690, r4691692);
return r4691693;
}




Bits error versus x
| Original | 29.8 |
|---|---|
| Target | 0.0 |
| Herbie | 0.7 |
Initial program 29.8
Taylor expanded around 0 0.7
Simplified0.7
Final simplification0.7
herbie shell --seed 2019163 +o rules:numerics
(FPCore (x)
:name "exp2 (problem 3.3.7)"
:herbie-target
(* 4 (pow (sinh (/ x 2)) 2))
(+ (- (exp x) 2) (exp (- x))))