\left(\left(x - \frac{16.0}{116.0}\right) \cdot 3.0\right) \cdot y3.0 \cdot \left(\left(x - \frac{16.0}{116.0}\right) \cdot y\right)double f(double x, double y) {
double r35812984 = x;
double r35812985 = 16.0;
double r35812986 = 116.0;
double r35812987 = r35812985 / r35812986;
double r35812988 = r35812984 - r35812987;
double r35812989 = 3.0;
double r35812990 = r35812988 * r35812989;
double r35812991 = y;
double r35812992 = r35812990 * r35812991;
return r35812992;
}
double f(double x, double y) {
double r35812993 = 3.0;
double r35812994 = x;
double r35812995 = 16.0;
double r35812996 = 116.0;
double r35812997 = r35812995 / r35812996;
double r35812998 = r35812994 - r35812997;
double r35812999 = y;
double r35813000 = r35812998 * r35812999;
double r35813001 = r35812993 * r35813000;
return r35813001;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.2 |
|---|---|
| Target | 0.2 |
| Herbie | 0.3 |
Initial program 0.2
rmApplied add-sqr-sqrt1.0
Applied associate-*r*0.9
rmApplied pow10.9
Applied pow10.9
Applied pow10.9
Applied pow10.9
Applied pow-prod-down0.9
Applied pow-prod-down0.9
Applied pow-prod-down0.9
Simplified0.3
Final simplification0.3
herbie shell --seed 2019165 +o rules:numerics
(FPCore (x y)
:name "Data.Colour.CIE:cieLAB from colour-2.3.3, A"
:herbie-target
(* y (- (* x 3.0) 0.41379310344827586))
(* (* (- x (/ 16.0 116.0)) 3.0) y))