x + \frac{y}{1.1283791670955126 \cdot e^{z} - x \cdot y}\frac{1}{\frac{\sqrt[3]{\left(e^{z} \cdot 1.1283791670955126\right) \cdot \left(\left(e^{z} \cdot 1.1283791670955126\right) \cdot \left(e^{z} \cdot 1.1283791670955126\right)\right)}}{y} - x} + xdouble f(double x, double y, double z) {
double r17443170 = x;
double r17443171 = y;
double r17443172 = 1.1283791670955126;
double r17443173 = z;
double r17443174 = exp(r17443173);
double r17443175 = r17443172 * r17443174;
double r17443176 = r17443170 * r17443171;
double r17443177 = r17443175 - r17443176;
double r17443178 = r17443171 / r17443177;
double r17443179 = r17443170 + r17443178;
return r17443179;
}
double f(double x, double y, double z) {
double r17443180 = 1.0;
double r17443181 = z;
double r17443182 = exp(r17443181);
double r17443183 = 1.1283791670955126;
double r17443184 = r17443182 * r17443183;
double r17443185 = r17443184 * r17443184;
double r17443186 = r17443184 * r17443185;
double r17443187 = cbrt(r17443186);
double r17443188 = y;
double r17443189 = r17443187 / r17443188;
double r17443190 = x;
double r17443191 = r17443189 - r17443190;
double r17443192 = r17443180 / r17443191;
double r17443193 = r17443192 + r17443190;
return r17443193;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 3.1 |
|---|---|
| Target | 0.0 |
| Herbie | 0.2 |
Initial program 3.1
rmApplied clear-num3.1
rmApplied div-sub3.1
Simplified0.0
rmApplied add-cbrt-cube0.2
Final simplification0.2
herbie shell --seed 2019162
(FPCore (x y z)
:name "Numeric.SpecFunctions:invErfc from math-functions-0.1.5.2, A"
:herbie-target
(+ x (/ 1 (- (* (/ 1.1283791670955126 y) (exp z)) x)))
(+ x (/ y (- (* 1.1283791670955126 (exp z)) (* x y)))))