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 r414165 = x;
double r414166 = y;
double r414167 = 1.1283791670955126;
double r414168 = z;
double r414169 = exp(r414168);
double r414170 = r414167 * r414169;
double r414171 = r414165 * r414166;
double r414172 = r414170 - r414171;
double r414173 = r414166 / r414172;
double r414174 = r414165 + r414173;
return r414174;
}
double f(double x, double y, double z) {
double r414175 = x;
double r414176 = 1.0;
double r414177 = 1.1283791670955126;
double r414178 = z;
double r414179 = exp(r414178);
double r414180 = y;
double r414181 = r414179 / r414180;
double r414182 = r414177 * r414181;
double r414183 = r414182 - r414175;
double r414184 = r414176 / r414183;
double r414185 = r414175 + r414184;
return r414185;
}




Bits error versus x




Bits error versus y




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