\left(e^{x} - 2\right) + e^{-x}\mathsf{fma}\left(\frac{1}{360}, \left(x \cdot x\right) \cdot \left(\left(x \cdot x\right) \cdot \left(x \cdot x\right)\right), \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 r4414233 = x;
double r4414234 = exp(r4414233);
double r4414235 = 2.0;
double r4414236 = r4414234 - r4414235;
double r4414237 = -r4414233;
double r4414238 = exp(r4414237);
double r4414239 = r4414236 + r4414238;
return r4414239;
}
double f(double x) {
double r4414240 = 0.002777777777777778;
double r4414241 = x;
double r4414242 = r4414241 * r4414241;
double r4414243 = r4414242 * r4414242;
double r4414244 = r4414242 * r4414243;
double r4414245 = 0.08333333333333333;
double r4414246 = fma(r4414243, r4414245, r4414242);
double r4414247 = fma(r4414240, r4414244, r4414246);
return r4414247;
}




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