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(-z \cdot \left(x \cdot y\right)\right)\\
\mathbf{else}:\\
\;\;\;\;x \cdot \left(\mathsf{fma}\left(y, -z, {\left(\sqrt[3]{1}\right)}^{3}\right) + y \cdot \left(z + \left(-z\right)\right)\right)\\
\end{array}double f(double x, double y, double z) {
double r234664 = x;
double r234665 = 1.0;
double r234666 = y;
double r234667 = z;
double r234668 = r234666 * r234667;
double r234669 = r234665 - r234668;
double r234670 = r234664 * r234669;
return r234670;
}
double f(double x, double y, double z) {
double r234671 = y;
double r234672 = z;
double r234673 = r234671 * r234672;
double r234674 = -2.3166575333139023e+216;
bool r234675 = r234673 <= r234674;
double r234676 = 4.10641883011992e+205;
bool r234677 = r234673 <= r234676;
double r234678 = !r234677;
bool r234679 = r234675 || r234678;
double r234680 = x;
double r234681 = 1.0;
double r234682 = r234680 * r234681;
double r234683 = r234680 * r234671;
double r234684 = r234672 * r234683;
double r234685 = -r234684;
double r234686 = r234682 + r234685;
double r234687 = -r234672;
double r234688 = cbrt(r234681);
double r234689 = 3.0;
double r234690 = pow(r234688, r234689);
double r234691 = fma(r234671, r234687, r234690);
double r234692 = r234672 + r234687;
double r234693 = r234671 * r234692;
double r234694 = r234691 + r234693;
double r234695 = r234680 * r234694;
double r234696 = r234679 ? r234686 : r234695;
return r234696;
}



Bits error versus x



Bits error versus y



Bits error versus z
if (* y z) < -2.3166575333139023e+216 or 4.10641883011992e+205 < (* y z) Initial program 28.7
rmApplied sub-neg28.7
Applied distribute-rgt-in28.7
Simplified28.7
Simplified1.0
if -2.3166575333139023e+216 < (* y z) < 4.10641883011992e+205Initial program 0.1
rmApplied add-cube-cbrt0.1
Applied prod-diff0.1
Simplified0.1
Simplified0.1
Final simplification0.2
herbie shell --seed 2019179 +o rules:numerics
(FPCore (x y z)
:name "Data.Colour.RGBSpace.HSV:hsv from colour-2.3.3, I"
(* x (- 1.0 (* y z))))