x \cdot \left(1 - y \cdot z\right)
\begin{array}{l}
\mathbf{if}\;y \cdot z \le -1.387439253831378329113104867639571109361 \cdot 10^{71} \lor \neg \left(y \cdot z \le 4.284089717899132673056405413227072964625 \cdot 10^{211}\right):\\
\;\;\;\;1 \cdot x + y \cdot \left(z \cdot \left(-x\right)\right)\\
\mathbf{else}:\\
\;\;\;\;1 \cdot x + \left(-y \cdot z\right) \cdot x\\
\end{array}double f(double x, double y, double z) {
double r132579 = x;
double r132580 = 1.0;
double r132581 = y;
double r132582 = z;
double r132583 = r132581 * r132582;
double r132584 = r132580 - r132583;
double r132585 = r132579 * r132584;
return r132585;
}
double f(double x, double y, double z) {
double r132586 = y;
double r132587 = z;
double r132588 = r132586 * r132587;
double r132589 = -1.3874392538313783e+71;
bool r132590 = r132588 <= r132589;
double r132591 = 4.284089717899133e+211;
bool r132592 = r132588 <= r132591;
double r132593 = !r132592;
bool r132594 = r132590 || r132593;
double r132595 = 1.0;
double r132596 = x;
double r132597 = r132595 * r132596;
double r132598 = -r132596;
double r132599 = r132587 * r132598;
double r132600 = r132586 * r132599;
double r132601 = r132597 + r132600;
double r132602 = -r132588;
double r132603 = r132602 * r132596;
double r132604 = r132597 + r132603;
double r132605 = r132594 ? r132601 : r132604;
return r132605;
}



Bits error versus x



Bits error versus y



Bits error versus z
Results
if (* y z) < -1.3874392538313783e+71 or 4.284089717899133e+211 < (* y z) Initial program 17.9
rmApplied sub-neg17.9
Applied distribute-lft-in17.9
Simplified17.9
Simplified17.9
rmApplied distribute-rgt-neg-in17.9
Applied associate-*l*3.8
Simplified3.8
if -1.3874392538313783e+71 < (* y z) < 4.284089717899133e+211Initial program 0.1
rmApplied sub-neg0.1
Applied distribute-lft-in0.1
Simplified0.1
Simplified0.1
Final simplification0.8
herbie shell --seed 2019347 +o rules:numerics
(FPCore (x y z)
:name "Data.Colour.RGBSpace.HSV:hsv from colour-2.3.3, I"
:precision binary64
(* x (- 1 (* y z))))