\left|\frac{x + 4}{y} - \frac{x}{y} \cdot z\right|\begin{array}{l}
\mathbf{if}\;y \le -4.045130865518068 \cdot 10^{-32} \lor \neg \left(y \le 2.53733113516034195 \cdot 10^{221}\right):\\
\;\;\;\;\left|\frac{x + 4}{y} - x \cdot \frac{z}{y}\right|\\
\mathbf{else}:\\
\;\;\;\;\left|\frac{x + 4}{y} - \frac{1}{\sqrt[3]{y} \cdot \sqrt[3]{y}} \cdot \left(\frac{x}{\sqrt[3]{y}} \cdot z\right)\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.045130865518068e-32) || !(y <= 2.537331135160342e+221))) {
VAR = ((double) fabs(((double) (((double) (((double) (x + 4.0)) / y)) - ((double) (x * ((double) (z / y))))))));
} else {
VAR = ((double) fabs(((double) (((double) (((double) (x + 4.0)) / y)) - ((double) (((double) (1.0 / ((double) (((double) cbrt(y)) * ((double) cbrt(y)))))) * ((double) (((double) (x / ((double) cbrt(y)))) * z))))))));
}
return VAR;
}



Bits error versus x



Bits error versus y



Bits error versus z
Results
if y < -4.045130865518068e-32 or 2.53733113516034195e221 < y Initial program 3.4
rmApplied div-inv3.4
Applied associate-*l*0.1
Simplified0.1
if -4.045130865518068e-32 < y < 2.53733113516034195e221Initial program 0.4
rmApplied add-cube-cbrt0.7
Applied *-un-lft-identity0.7
Applied times-frac0.7
Applied associate-*l*1.2
Final simplification0.7
herbie shell --seed 2020162
(FPCore (x y z)
:name "fabs fraction 1"
:precision binary64
(fabs (- (/ (+ x 4.0) y) (* (/ x y) z))))