x \cdot \left(1.0 - \left(1.0 - y\right) \cdot z\right)
\begin{array}{l}
\mathbf{if}\;x \le -4.957570734057136 \cdot 10^{-13}:\\
\;\;\;\;\left(x - z \cdot x\right) \cdot 1.0 + \left(z \cdot x\right) \cdot y\\
\mathbf{elif}\;x \le 6.0021867161161834 \cdot 10^{-139}:\\
\;\;\;\;\left(\left(x \cdot \left(y - 1.0\right)\right) \cdot z + \mathsf{fma}\left(1.0, -1, 1.0\right) \cdot \left(z \cdot x\right)\right) + 1.0 \cdot x\\
\mathbf{else}:\\
\;\;\;\;\left(x - z \cdot x\right) \cdot 1.0 + \left(z \cdot x\right) \cdot y\\
\end{array}double f(double x, double y, double z) {
double r38242155 = x;
double r38242156 = 1.0;
double r38242157 = y;
double r38242158 = r38242156 - r38242157;
double r38242159 = z;
double r38242160 = r38242158 * r38242159;
double r38242161 = r38242156 - r38242160;
double r38242162 = r38242155 * r38242161;
return r38242162;
}
double f(double x, double y, double z) {
double r38242163 = x;
double r38242164 = -4.957570734057136e-13;
bool r38242165 = r38242163 <= r38242164;
double r38242166 = z;
double r38242167 = r38242166 * r38242163;
double r38242168 = r38242163 - r38242167;
double r38242169 = 1.0;
double r38242170 = r38242168 * r38242169;
double r38242171 = y;
double r38242172 = r38242167 * r38242171;
double r38242173 = r38242170 + r38242172;
double r38242174 = 6.0021867161161834e-139;
bool r38242175 = r38242163 <= r38242174;
double r38242176 = r38242171 - r38242169;
double r38242177 = r38242163 * r38242176;
double r38242178 = r38242177 * r38242166;
double r38242179 = -1.0;
double r38242180 = fma(r38242169, r38242179, r38242169);
double r38242181 = r38242180 * r38242167;
double r38242182 = r38242178 + r38242181;
double r38242183 = r38242169 * r38242163;
double r38242184 = r38242182 + r38242183;
double r38242185 = r38242175 ? r38242184 : r38242173;
double r38242186 = r38242165 ? r38242173 : r38242185;
return r38242186;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 3.1 |
|---|---|
| Target | 0.2 |
| Herbie | 0.1 |
if x < -4.957570734057136e-13 or 6.0021867161161834e-139 < x Initial program 0.8
Simplified0.8
rmApplied fma-udef0.8
Applied distribute-lft-in0.8
rmApplied associate-*r*0.2
rmApplied sub-neg0.2
Applied distribute-lft-in0.2
Applied associate-+l+0.2
Simplified0.2
if -4.957570734057136e-13 < x < 6.0021867161161834e-139Initial program 5.9
Simplified5.9
rmApplied fma-udef5.9
Applied distribute-lft-in5.9
rmApplied add-cube-cbrt5.9
Applied add-sqr-sqrt34.5
Applied prod-diff34.5
Applied distribute-lft-in34.5
Applied distribute-lft-in34.5
Simplified0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2019163 +o rules:numerics
(FPCore (x y z)
:name "Data.Colour.RGBSpace.HSV:hsv from colour-2.3.3, J"
:herbie-target
(if (< (* x (- 1.0 (* (- 1.0 y) z))) -1.618195973607049e+50) (+ x (* (- 1.0 y) (* (- z) x))) (if (< (* x (- 1.0 (* (- 1.0 y) z))) 3.892237649663903e+134) (- (* (* x y) z) (- (* x z) x)) (+ x (* (- 1.0 y) (* (- z) x)))))
(* x (- 1.0 (* (- 1.0 y) z))))