\left(\left(x - \frac{16}{116}\right) \cdot 3\right) \cdot y\left(\left(\left(x - \frac{16}{116}\right) \cdot \left({\left(\sqrt[3]{3}\right)}^{2} \cdot \sqrt[3]{\sqrt[3]{3} \cdot \sqrt[3]{3}}\right)\right) \cdot \sqrt[3]{\sqrt[3]{3}}\right) \cdot ydouble f(double x, double y) {
double r901733 = x;
double r901734 = 16.0;
double r901735 = 116.0;
double r901736 = r901734 / r901735;
double r901737 = r901733 - r901736;
double r901738 = 3.0;
double r901739 = r901737 * r901738;
double r901740 = y;
double r901741 = r901739 * r901740;
return r901741;
}
double f(double x, double y) {
double r901742 = x;
double r901743 = 16.0;
double r901744 = 116.0;
double r901745 = r901743 / r901744;
double r901746 = r901742 - r901745;
double r901747 = 3.0;
double r901748 = cbrt(r901747);
double r901749 = 2.0;
double r901750 = pow(r901748, r901749);
double r901751 = r901748 * r901748;
double r901752 = cbrt(r901751);
double r901753 = r901750 * r901752;
double r901754 = r901746 * r901753;
double r901755 = cbrt(r901748);
double r901756 = r901754 * r901755;
double r901757 = y;
double r901758 = r901756 * r901757;
return r901758;
}




Bits error versus x




Bits error versus y
Results
| Original | 0.2 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 0.2
rmApplied add-cube-cbrt0.2
Applied associate-*r*0.8
rmApplied add-cube-cbrt0.8
Applied cbrt-prod0.8
Applied associate-*r*0.7
Simplified0.2
Final simplification0.2
herbie shell --seed 2020001
(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))