\left|\frac{x + 4}{y} - \frac{x}{y} \cdot z\right|\begin{array}{l}
\mathbf{if}\;y \le 4.2510798617965315 \cdot 10^{-152}:\\
\;\;\;\;\left|\frac{x + 4}{y} - \left(x \cdot z\right) \cdot \frac{1}{y}\right|\\
\mathbf{else}:\\
\;\;\;\;\left|\frac{x + 4}{y} - \frac{x}{\frac{y}{z}}\right|\\
\end{array}double code(double x, double y, double z) {
return ((double) fabs(((double) (((double) (((double) (x + 4.0)) / y)) - ((double) (((double) (x / y)) * z))))));
}
double code(double x, double y, double z) {
double VAR;
if ((y <= 4.2510798617965315e-152)) {
VAR = ((double) fabs(((double) (((double) (((double) (x + 4.0)) / y)) - ((double) (((double) (x * z)) * ((double) (1.0 / y))))))));
} else {
VAR = ((double) fabs(((double) (((double) (((double) (x + 4.0)) / y)) - ((double) (x / ((double) (y / z))))))));
}
return VAR;
}



Bits error versus x



Bits error versus y



Bits error versus z
Results
if y < 4.2510798617965315e-152Initial program 1.2
rmApplied associate-*l/3.0
rmApplied div-inv3.0
if 4.2510798617965315e-152 < y Initial program 1.7
rmApplied associate-*l/4.1
rmApplied associate-/l*1.2
Final simplification2.3
herbie shell --seed 2020163
(FPCore (x y z)
:name "fabs fraction 1"
:precision binary64
(fabs (- (/ (+ x 4.0) y) (* (/ x y) z))))