x + \frac{y}{1.12837916709551256 \cdot e^{z} - x \cdot y}x + \frac{1}{1.12837916709551256 \cdot \frac{e^{z}}{y} - x}double f(double x, double y, double z) {
double r337998 = x;
double r337999 = y;
double r338000 = 1.1283791670955126;
double r338001 = z;
double r338002 = exp(r338001);
double r338003 = r338000 * r338002;
double r338004 = r337998 * r337999;
double r338005 = r338003 - r338004;
double r338006 = r337999 / r338005;
double r338007 = r337998 + r338006;
return r338007;
}
double f(double x, double y, double z) {
double r338008 = x;
double r338009 = 1.0;
double r338010 = 1.1283791670955126;
double r338011 = z;
double r338012 = exp(r338011);
double r338013 = y;
double r338014 = r338012 / r338013;
double r338015 = r338010 * r338014;
double r338016 = r338015 - r338008;
double r338017 = r338009 / r338016;
double r338018 = r338008 + r338017;
return r338018;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 3.1 |
|---|---|
| Target | 0.0 |
| Herbie | 0.1 |
Initial program 3.1
Taylor expanded around inf 3.1
Simplified2.0
rmApplied clear-num2.0
Taylor expanded around inf 0.1
Final simplification0.1
herbie shell --seed 2019199 +o rules:numerics
(FPCore (x y z)
:name "Numeric.SpecFunctions:invErfc from math-functions-0.1.5.2, A"
:herbie-target
(+ x (/ 1.0 (- (* (/ 1.1283791670955126 y) (exp z)) x)))
(+ x (/ y (- (* 1.1283791670955126 (exp z)) (* x y)))))