x \cdot \left(1 - y \cdot z\right)
\begin{array}{l}
\mathbf{if}\;y \cdot z \le -1.17685647831489084453456189150995397973 \cdot 10^{221} \lor \neg \left(y \cdot z \le 7.312372482130218940754485960634465779355 \cdot 10^{187}\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 r163750 = x;
double r163751 = 1.0;
double r163752 = y;
double r163753 = z;
double r163754 = r163752 * r163753;
double r163755 = r163751 - r163754;
double r163756 = r163750 * r163755;
return r163756;
}
double f(double x, double y, double z) {
double r163757 = y;
double r163758 = z;
double r163759 = r163757 * r163758;
double r163760 = -1.1768564783148908e+221;
bool r163761 = r163759 <= r163760;
double r163762 = 7.312372482130219e+187;
bool r163763 = r163759 <= r163762;
double r163764 = !r163763;
bool r163765 = r163761 || r163764;
double r163766 = 1.0;
double r163767 = x;
double r163768 = r163766 * r163767;
double r163769 = -r163767;
double r163770 = r163758 * r163769;
double r163771 = r163757 * r163770;
double r163772 = r163768 + r163771;
double r163773 = -r163759;
double r163774 = r163773 * r163767;
double r163775 = r163768 + r163774;
double r163776 = r163765 ? r163772 : r163775;
return r163776;
}



Bits error versus x



Bits error versus y



Bits error versus z
Results
if (* y z) < -1.1768564783148908e+221 or 7.312372482130219e+187 < (* y z) Initial program 27.5
rmApplied sub-neg27.5
Applied distribute-lft-in27.5
Simplified27.5
Simplified27.5
rmApplied distribute-rgt-neg-in27.5
Applied associate-*l*1.2
Simplified1.2
if -1.1768564783148908e+221 < (* y z) < 7.312372482130219e+187Initial program 0.1
rmApplied sub-neg0.1
Applied distribute-lft-in0.1
Simplified0.1
Simplified0.1
Final simplification0.2
herbie shell --seed 2019325 +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))))