将Lab转换为XYZ

时间:2017-10-08 03:56:18

标签: java colors color-conversion

我需要能够将Lab颜色转换为XYZ颜色。根据我在其他人的问题上找到的建议,我按照此页面的说明进行了说明:http://www.brucelindbloom.com/index.html?Eqn_Lab_to_XYZ.html

我已经关注它了,但是我的X和Z值是偏离的,但是Y是正确的(我已经针对几个在线转换器测试了它(它们没有显示它们如何转换它...)) 。我一直盯着那个实验室到XYZ网站一段时间,试图找出我的数学错误。

我测试的Lab颜色:Lab[41, 48, -19]

我得到的XYZ值:XYZ[5676.0352, 0.1186, 4845.2021](该网站称结果应在[0, 1]范围内

referenceXreferenceYreferenceZ是我的参考白色值。

这是我的代码(Java):

    // https://www.mathworks.com/help/images/ref/whitepoint.html
    // a: 1.0985, 1, 0.3556
    // c: 0.9807, 1, 1.1822
    // e: 1,1, 1
    // d50: 0.9642, 1, 0.8251
    // d55: 0.9568, 1, 0.9214
    // d65: 0.9504, 1, 1.0888
    // icc: 0.9642, 1, 0.8249 (what we're using)
    double referenceX = 0.9642;
    double referenceY = 1;
    double referenceZ = 0.8249;

    double fy = (this.lightness + 16) / 116;
    double fx = this.a / 500 + fy;
    double fz = fy - this.b / 200;
    //todo make these constants
    double kappa = 216 / 24389.0;
    double epsilon = 24389 / 27.0;

    double fx3 = fx * fx * fx;
    double fz3 = fz * fz * fz;
    double xr = fx3 > epsilon ? fx3 : (116 * fx - 16) / kappa;
    double yr = this.lightness > kappa * epsilon ? Math.pow((this.lightness + 16) / 116, 3) : this.lightness / kappa;
    double zr = fz3 > epsilon ? fz3 : (116 * fz - 16) / kappa;

    double X = xr * referenceX;
    double Y = yr * referenceY;
    double Z = zr * referenceZ;

所以我想我的问题当然是我的数学有什么问题?或者任何人都可以找到另一个网站进行转换(我似乎找不到任何东西)?

感谢。如果您需要任何澄清或有任何疑问,请询问。

1 个答案:

答案 0 :(得分:0)

不确定这里出了什么问题(如果有人知道,请说出来!),但我最终使用了维基百科转换(https://en.wikipedia.org/wiki/Lab_color_space#RGB_and_CMYK_conversions,请参阅反向转换)。我不知道为什么我最初没有看到这个。