\left|\frac{x + 4}{y} - \frac{x}{y} \cdot z\right|\left|\mathsf{fma}\left(z, -\frac{x}{y}, \frac{4}{y} + \frac{x}{y}\right) + \left(0 \cdot \frac{x}{y}\right) \cdot z\right|double f(double x, double y, double z) {
double r33994 = x;
double r33995 = 4.0;
double r33996 = r33994 + r33995;
double r33997 = y;
double r33998 = r33996 / r33997;
double r33999 = r33994 / r33997;
double r34000 = z;
double r34001 = r33999 * r34000;
double r34002 = r33998 - r34001;
double r34003 = fabs(r34002);
return r34003;
}
double f(double x, double y, double z) {
double r34004 = z;
double r34005 = x;
double r34006 = y;
double r34007 = r34005 / r34006;
double r34008 = -r34007;
double r34009 = 4.0;
double r34010 = r34009 / r34006;
double r34011 = r34010 + r34007;
double r34012 = fma(r34004, r34008, r34011);
double r34013 = 0.0;
double r34014 = r34013 * r34007;
double r34015 = r34014 * r34004;
double r34016 = r34012 + r34015;
double r34017 = fabs(r34016);
return r34017;
}



Bits error versus x



Bits error versus y



Bits error versus z
Initial program 1.6
rmApplied add-cube-cbrt2.6
Applied prod-diff2.6
Simplified1.6
Simplified1.6
Taylor expanded around 0 1.6
Simplified1.6
Final simplification1.6
herbie shell --seed 2019325 +o rules:numerics
(FPCore (x y z)
:name "fabs fraction 1"
:precision binary64
(fabs (- (/ (+ x 4) y) (* (/ x y) z))))