\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 r3847822 = x;
double r3847823 = exp(r3847822);
double r3847824 = 2.0;
double r3847825 = r3847823 - r3847824;
double r3847826 = -r3847822;
double r3847827 = exp(r3847826);
double r3847828 = r3847825 + r3847827;
return r3847828;
}
double f(double x) {
double r3847829 = 0.002777777777777778;
double r3847830 = x;
double r3847831 = r3847830 * r3847830;
double r3847832 = r3847831 * r3847831;
double r3847833 = r3847831 * r3847832;
double r3847834 = 0.08333333333333333;
double r3847835 = fma(r3847832, r3847834, r3847831);
double r3847836 = fma(r3847829, r3847833, r3847835);
return r3847836;
}




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