\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 r3682424 = x;
double r3682425 = exp(r3682424);
double r3682426 = 2.0;
double r3682427 = r3682425 - r3682426;
double r3682428 = -r3682424;
double r3682429 = exp(r3682428);
double r3682430 = r3682427 + r3682429;
return r3682430;
}
double f(double x) {
double r3682431 = x;
double r3682432 = r3682431 * r3682431;
double r3682433 = r3682432 * r3682432;
double r3682434 = r3682433 * r3682432;
double r3682435 = 0.002777777777777778;
double r3682436 = 0.08333333333333333;
double r3682437 = fma(r3682433, r3682436, r3682432);
double r3682438 = fma(r3682434, r3682435, r3682437);
return r3682438;
}




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