x \cdot \left(1 - \left(1 - y\right) \cdot z\right)
\begin{array}{l}
\mathbf{if}\;x \leq -0.6671287443065765:\\
\;\;\;\;\left(x + x \cdot \left(z \cdot y\right)\right) - x \cdot z\\
\mathbf{elif}\;x \leq 5.387746339016036 \cdot 10^{-122}:\\
\;\;\;\;x + z \cdot \left(x \cdot y - x\right)\\
\mathbf{else}:\\
\;\;\;\;x \cdot \left(\left(z \cdot y + 1\right) - z\right)\\
\end{array}(FPCore (x y z) :precision binary64 (* x (- 1.0 (* (- 1.0 y) z))))
(FPCore (x y z)
:precision binary64
(if (<= x -0.6671287443065765)
(- (+ x (* x (* z y))) (* x z))
(if (<= x 5.387746339016036e-122)
(+ x (* z (- (* x y) x)))
(* x (- (+ (* z y) 1.0) z)))))double code(double x, double y, double z) {
return x * (1.0 - ((1.0 - y) * z));
}
double code(double x, double y, double z) {
double tmp;
if (x <= -0.6671287443065765) {
tmp = (x + (x * (z * y))) - (x * z);
} else if (x <= 5.387746339016036e-122) {
tmp = x + (z * ((x * y) - x));
} else {
tmp = x * (((z * y) + 1.0) - z);
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 3.5 |
|---|---|
| Target | 0.2 |
| Herbie | 0.5 |
if x < -0.66712874430657654Initial program 0.1
Taylor expanded around 0 0.1
if -0.66712874430657654 < x < 5.3877463390160363e-122Initial program 6.3
rmApplied sub-neg_binary64_201906.3
Applied distribute-rgt-in_binary64_201476.3
Simplified6.3
Simplified6.3
Taylor expanded around 0 0.1
if 5.3877463390160363e-122 < x Initial program 1.3
Taylor expanded around 0 1.3
Final simplification0.5
herbie shell --seed 2021090
(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) (* (- 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))))