\left(\left(x - \frac{16}{116}\right) \cdot 3\right) \cdot yy \cdot \mathsf{fma}\left(3, x, -0.413793103448275856\right)double code(double x, double y) {
return (((x - (16.0 / 116.0)) * 3.0) * y);
}
double code(double x, double y) {
return (y * fma(3.0, x, -0.41379310344827586));
}




Bits error versus x




Bits error versus y
Results
| Original | 0.2 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 0.2
Taylor expanded around 0 0.2
Simplified0.2
rmApplied fma-neg0.2
Final simplification0.2
herbie shell --seed 2020105 +o rules:numerics
(FPCore (x y)
:name "Data.Colour.CIE:cieLAB from colour-2.3.3, A"
:precision binary64
:herbie-target
(* y (- (* x 3) 0.41379310344827586))
(* (* (- x (/ 16 116)) 3) y))