x \cdot \left(1 - \left(1 - y\right) \cdot z\right)
\begin{array}{l}
\mathbf{if}\;z \le -1.4004148216332521 \cdot 10^{-37} \lor \neg \left(z \le 1.29604611734931964 \cdot 10^{-41}\right):\\
\;\;\;\;x \cdot 1 + \left(x \cdot z\right) \cdot \left(y - 1\right)\\
\mathbf{else}:\\
\;\;\;\;\left(x \cdot \left(\sqrt[3]{1 - \left(1 - y\right) \cdot z} \cdot \sqrt[3]{1 - \left(1 - y\right) \cdot z}\right)\right) \cdot \sqrt[3]{1 - \left(1 - y\right) \cdot z}\\
\end{array}double code(double x, double y, double z) {
return ((double) (x * ((double) (1.0 - ((double) (((double) (1.0 - y)) * z))))));
}
double code(double x, double y, double z) {
double VAR;
if (((z <= -1.400414821633252e-37) || !(z <= 1.2960461173493196e-41))) {
VAR = ((double) (((double) (x * 1.0)) + ((double) (((double) (x * z)) * ((double) (y - 1.0))))));
} else {
VAR = ((double) (((double) (x * ((double) (((double) cbrt(((double) (1.0 - ((double) (((double) (1.0 - y)) * z)))))) * ((double) cbrt(((double) (1.0 - ((double) (((double) (1.0 - y)) * z)))))))))) * ((double) cbrt(((double) (1.0 - ((double) (((double) (1.0 - y)) * z))))))));
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 3.3 |
|---|---|
| Target | 0.2 |
| Herbie | 0.3 |
if z < -1.4004148216332521e-37 or 1.29604611734931964e-41 < z Initial program 7.1
rmApplied sub-neg7.1
Applied distribute-lft-in7.1
Simplified0.2
if -1.4004148216332521e-37 < z < 1.29604611734931964e-41Initial program 0.1
rmApplied add-cube-cbrt0.3
Applied associate-*r*0.3
Final simplification0.3
herbie shell --seed 2020161
(FPCore (x y z)
:name "Data.Colour.RGBSpace.HSV:hsv from colour-2.3.3, J"
:precision binary64
:herbie-target
(if (< (* x (- 1.0 (* (- 1.0 y) z))) -1.618195973607049e+50) (+ x (* (- 1.0 y) (* (neg z) x))) (if (< (* x (- 1.0 (* (- 1.0 y) z))) 3.892237649663903e+134) (- (* (* x y) z) (- (* x z) x)) (+ x (* (- 1.0 y) (* (neg z) x)))))
(* x (- 1.0 (* (- 1.0 y) z))))