x \cdot \left(1 - y \cdot z\right)
\begin{array}{l}
\mathbf{if}\;y \cdot z \le -2.316657533313902342261040936204101994876 \cdot 10^{216} \lor \neg \left(y \cdot z \le 4.106418830119920176371277439794922661684 \cdot 10^{205}\right):\\
\;\;\;\;x \cdot 1 + \left(x \cdot y\right) \cdot \left(-z\right)\\
\mathbf{else}:\\
\;\;\;\;\left(1 - y \cdot z\right) \cdot x\\
\end{array}double f(double x, double y, double z) {
double r259099 = x;
double r259100 = 1.0;
double r259101 = y;
double r259102 = z;
double r259103 = r259101 * r259102;
double r259104 = r259100 - r259103;
double r259105 = r259099 * r259104;
return r259105;
}
double f(double x, double y, double z) {
double r259106 = y;
double r259107 = z;
double r259108 = r259106 * r259107;
double r259109 = -2.3166575333139023e+216;
bool r259110 = r259108 <= r259109;
double r259111 = 4.10641883011992e+205;
bool r259112 = r259108 <= r259111;
double r259113 = !r259112;
bool r259114 = r259110 || r259113;
double r259115 = x;
double r259116 = 1.0;
double r259117 = r259115 * r259116;
double r259118 = r259115 * r259106;
double r259119 = -r259107;
double r259120 = r259118 * r259119;
double r259121 = r259117 + r259120;
double r259122 = r259116 - r259108;
double r259123 = r259122 * r259115;
double r259124 = r259114 ? r259121 : r259123;
return r259124;
}



Bits error versus x



Bits error versus y



Bits error versus z
Results
if (* y z) < -2.3166575333139023e+216 or 4.10641883011992e+205 < (* y z) Initial program 28.7
rmApplied sub-neg28.7
Applied distribute-lft-in28.7
Simplified1.0
if -2.3166575333139023e+216 < (* y z) < 4.10641883011992e+205Initial program 0.1
Final simplification0.2
herbie shell --seed 2019179
(FPCore (x y z)
:name "Data.Colour.RGBSpace.HSV:hsv from colour-2.3.3, I"
(* x (- 1.0 (* y z))))