x + \frac{y}{1.128379167095512558560699289955664426088 \cdot e^{z} - x \cdot y}x + \frac{1}{\mathsf{fma}\left(1.128379167095512558560699289955664426088, \frac{e^{z}}{y}, -x\right)}double f(double x, double y, double z) {
double r332127 = x;
double r332128 = y;
double r332129 = 1.1283791670955126;
double r332130 = z;
double r332131 = exp(r332130);
double r332132 = r332129 * r332131;
double r332133 = r332127 * r332128;
double r332134 = r332132 - r332133;
double r332135 = r332128 / r332134;
double r332136 = r332127 + r332135;
return r332136;
}
double f(double x, double y, double z) {
double r332137 = x;
double r332138 = 1.0;
double r332139 = 1.1283791670955126;
double r332140 = z;
double r332141 = exp(r332140);
double r332142 = y;
double r332143 = r332141 / r332142;
double r332144 = -r332137;
double r332145 = fma(r332139, r332143, r332144);
double r332146 = r332138 / r332145;
double r332147 = r332137 + r332146;
return r332147;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 2.9 |
|---|---|
| Target | 0.0 |
| Herbie | 0.1 |
Initial program 2.9
Simplified2.9
rmApplied clear-num2.9
Simplified2.9
Taylor expanded around inf 0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2019194 +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)))))