\left|\frac{x + 4}{y} - \frac{x}{y} \cdot z\right|\begin{array}{l}
\mathbf{if}\;x \le -3.23303180311761695 \cdot 10^{88} \lor \neg \left(x \le 4.01567555002013953 \cdot 10^{-110}\right):\\
\;\;\;\;\left|\frac{x + 4}{y} - x \cdot \frac{z}{y}\right|\\
\mathbf{else}:\\
\;\;\;\;\left|\frac{x + 4}{y} - \left(x \cdot z\right) \cdot \frac{1}{y}\right|\\
\end{array}double f(double x, double y, double z) {
double r28404 = x;
double r28405 = 4.0;
double r28406 = r28404 + r28405;
double r28407 = y;
double r28408 = r28406 / r28407;
double r28409 = r28404 / r28407;
double r28410 = z;
double r28411 = r28409 * r28410;
double r28412 = r28408 - r28411;
double r28413 = fabs(r28412);
return r28413;
}
double f(double x, double y, double z) {
double r28414 = x;
double r28415 = -3.233031803117617e+88;
bool r28416 = r28414 <= r28415;
double r28417 = 4.0156755500201395e-110;
bool r28418 = r28414 <= r28417;
double r28419 = !r28418;
bool r28420 = r28416 || r28419;
double r28421 = 4.0;
double r28422 = r28414 + r28421;
double r28423 = y;
double r28424 = r28422 / r28423;
double r28425 = z;
double r28426 = r28425 / r28423;
double r28427 = r28414 * r28426;
double r28428 = r28424 - r28427;
double r28429 = fabs(r28428);
double r28430 = r28414 * r28425;
double r28431 = 1.0;
double r28432 = r28431 / r28423;
double r28433 = r28430 * r28432;
double r28434 = r28424 - r28433;
double r28435 = fabs(r28434);
double r28436 = r28420 ? r28429 : r28435;
return r28436;
}



Bits error versus x



Bits error versus y



Bits error versus z
Results
if x < -3.233031803117617e+88 or 4.0156755500201395e-110 < x Initial program 0.6
rmApplied div-inv0.6
Applied associate-*l*0.8
Simplified0.7
if -3.233031803117617e+88 < x < 4.0156755500201395e-110Initial program 2.4
rmApplied div-inv2.4
Applied associate-*l*5.2
Simplified5.2
rmApplied div-inv5.2
Applied associate-*r*0.4
Final simplification0.6
herbie shell --seed 2020003 +o rules:numerics
(FPCore (x y z)
:name "fabs fraction 1"
:precision binary64
(fabs (- (/ (+ x 4) y) (* (/ x y) z))))