\left(e^{x} - 2\right) + e^{-x}(\left(\log \left(e^{\left(\left(x \cdot x\right) \cdot \left(x \cdot x\right)\right) \cdot \frac{1}{360}}\right)\right) \cdot \left(x \cdot x\right) + \left((\left(\left(x \cdot x\right) \cdot \left(x \cdot x\right)\right) \cdot \frac{1}{12} + \left(x \cdot x\right))_*\right))_*double f(double x) {
double r6518308 = x;
double r6518309 = exp(r6518308);
double r6518310 = 2.0;
double r6518311 = r6518309 - r6518310;
double r6518312 = -r6518308;
double r6518313 = exp(r6518312);
double r6518314 = r6518311 + r6518313;
return r6518314;
}
double f(double x) {
double r6518315 = x;
double r6518316 = r6518315 * r6518315;
double r6518317 = r6518316 * r6518316;
double r6518318 = 0.002777777777777778;
double r6518319 = r6518317 * r6518318;
double r6518320 = exp(r6518319);
double r6518321 = log(r6518320);
double r6518322 = 0.08333333333333333;
double r6518323 = fma(r6518317, r6518322, r6518316);
double r6518324 = fma(r6518321, r6518316, r6518323);
return r6518324;
}




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