x \cdot \left(1 - \left(1 - y\right) \cdot z\right)
\begin{array}{l}
\mathbf{if}\;z \le -1.639188773065111173943924236271911560756 \cdot 10^{-29}:\\
\;\;\;\;\mathsf{fma}\left(z \cdot x, y, 1 \cdot \left(x - z \cdot x\right)\right)\\
\mathbf{elif}\;z \le 5.566768969692308823890016512965200546653 \cdot 10^{-22}:\\
\;\;\;\;x \cdot \left(z \cdot y - 1 \cdot z\right) + 1 \cdot x\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(z \cdot x, y, 1 \cdot \left(x - z \cdot x\right)\right)\\
\end{array}double f(double x, double y, double z) {
double r100259489 = x;
double r100259490 = 1.0;
double r100259491 = y;
double r100259492 = r100259490 - r100259491;
double r100259493 = z;
double r100259494 = r100259492 * r100259493;
double r100259495 = r100259490 - r100259494;
double r100259496 = r100259489 * r100259495;
return r100259496;
}
double f(double x, double y, double z) {
double r100259497 = z;
double r100259498 = -1.6391887730651112e-29;
bool r100259499 = r100259497 <= r100259498;
double r100259500 = x;
double r100259501 = r100259497 * r100259500;
double r100259502 = y;
double r100259503 = 1.0;
double r100259504 = r100259500 - r100259501;
double r100259505 = r100259503 * r100259504;
double r100259506 = fma(r100259501, r100259502, r100259505);
double r100259507 = 5.566768969692309e-22;
bool r100259508 = r100259497 <= r100259507;
double r100259509 = r100259497 * r100259502;
double r100259510 = r100259503 * r100259497;
double r100259511 = r100259509 - r100259510;
double r100259512 = r100259500 * r100259511;
double r100259513 = r100259503 * r100259500;
double r100259514 = r100259512 + r100259513;
double r100259515 = r100259508 ? r100259514 : r100259506;
double r100259516 = r100259499 ? r100259506 : r100259515;
return r100259516;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 3.4 |
|---|---|
| Target | 0.2 |
| Herbie | 0.1 |
if z < -1.6391887730651112e-29 or 5.566768969692309e-22 < z Initial program 7.7
Simplified7.7
rmApplied fma-udef7.7
Applied distribute-rgt-in7.7
Taylor expanded around inf 7.7
Simplified0.2
if -1.6391887730651112e-29 < z < 5.566768969692309e-22Initial program 0.1
Simplified0.1
rmApplied fma-udef0.1
Applied distribute-rgt-in0.0
Taylor expanded around inf 0.0
Simplified0.0
Final simplification0.1
herbie shell --seed 2019173 +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))))