\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 r766193 = x;
double r766194 = 16.0;
double r766195 = 116.0;
double r766196 = r766194 / r766195;
double r766197 = r766193 - r766196;
double r766198 = 3.0;
double r766199 = r766197 * r766198;
double r766200 = y;
double r766201 = r766199 * r766200;
return r766201;
}
double f(double x, double y) {
double r766202 = x;
double r766203 = 16.0;
double r766204 = 116.0;
double r766205 = r766203 / r766204;
double r766206 = r766202 - r766205;
double r766207 = 3.0;
double r766208 = cbrt(r766207);
double r766209 = 2.0;
double r766210 = pow(r766208, r766209);
double r766211 = r766208 * r766208;
double r766212 = cbrt(r766211);
double r766213 = r766210 * r766212;
double r766214 = r766206 * r766213;
double r766215 = cbrt(r766208);
double r766216 = r766214 * r766215;
double r766217 = y;
double r766218 = r766216 * r766217;
return r766218;
}




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 +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))