c# - RGB/XYZ 和 XYZ-LAB 色彩空间转换算法

标签 c# rgb cielab xyz

我尝试将 RGB 颜色空间转换为 CIE-LAB 颜色空间。但有一个错误。

  • 输入 RGB 值 = (50,125,50)
  • 收到的结果 LAB vaues = (41,-38,34)

LAB 值应为 (46.41,-39.24,33.51)

我从 http://colorizer.org/ 检查了这个值

我哪里出错了?

如果您检查以下代码并回答我。我会很高兴。谢谢。

 public static Vector4 RGBToLab(Vector4 color)
        {
            float[] xyz = new float[3];
            float[] lab = new float[3];
            float[] rgb = new float[] { color[0], color[1], color[2], color[3] };

            rgb[0] = color[0] / 255.0f;
            rgb[1] = color[1] / 255.0f;
            rgb[2] = color[2] / 255.0f;

            if (rgb[0] > .04045f)
            {
                rgb[0] = (float)Math.Pow((rgb[0] + .0055) / 1.055, 2.4);
            }
            else
            {
                rgb[0] = rgb[0] / 12.92f;
            }

            if (rgb[1] > .04045f)
            {
                rgb[1] = (float)Math.Pow((rgb[1] + .0055) / 1.055, 2.4);
            }
            else
            {
                rgb[1] = rgb[1] / 12.92f;
            }

            if (rgb[2] > .04045f)
            {
                rgb[2] = (float)Math.Pow((rgb[2] + .0055) / 1.055, 2.4);
            }
            else
            {
                rgb[2] = rgb[2] / 12.92f;
            }
            rgb[0] = rgb[0] * 100.0f;
            rgb[1] = rgb[1] * 100.0f;
            rgb[2] = rgb[2] * 100.0f;


            xyz[0] = ((rgb[0] * .412453f) + (rgb[1] * .357580f) + (rgb[2] * .180423f));  
            xyz[1] = ((rgb[0] * .212671f) + (rgb[1] * .715160f) + (rgb[2] * .072169f));
            xyz[2] = ((rgb[0] * .019334f) + (rgb[1] * .119193f) + (rgb[2] * .950227f));


            xyz[0] = xyz[0] / 95.047f;
            xyz[1] = xyz[1] / 100.0f;
            xyz[2] = xyz[2] / 108.883f;

            if (xyz[0] > .008856f)
            {
                xyz[0] = (float)Math.Pow(xyz[0], (1.0 / 3.0));
            }
            else
            {
                xyz[0] = (xyz[0] * 7.787f) + (16.0f / 116.0f);
            }

            if (xyz[1] > .008856f)
            {
                xyz[1] = (float)Math.Pow(xyz[1], 1.0 / 3.0);
            }
            else
            {
                xyz[1] = (xyz[1] * 7.787f) + (16.0f / 116.0f);
            }

            if (xyz[2] > .008856f)
            {
                xyz[2] = (float)Math.Pow(xyz[2], 1.0 / 3.0);
            }
            else
            {
                xyz[2] = (xyz[2] * 7.787f) + (16.0f / 116.0f);
            }

            lab[0] = (116.0f * xyz[1]) - 16.0f;
            lab[1] = 500.0f * (xyz[0] - xyz[1]);
            lab[2] = 200.0f * (xyz[1] - xyz[2]);
            Debug.Log("L:" + (int)lab[0]);
            Debug.Log("A:" + (int)lab[1]);
            Debug.Log("B:" + (int)lab[2]);
            Debug.Log("W:" + (int)color[3]);

            return new Vector4(lab[0], lab[1], lab[2], color[3]);
        }

最佳答案

它应该是0.055,而不是.0055

逆 Gamma 运算错误:

rgb[0] = (float)Math.Pow((rgb[0] + .0055) / 1.055, 2.4);

应该是:

rgb[0] = (float)Math.Pow((rgb[0] + .055) / 1.055, 2.4);

参见:sRGB reverse gamma transformation

关于c# - RGB/XYZ 和 XYZ-LAB 色彩空间转换算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58952430/

相关文章:

c# - 以编程方式更改 SharePoint 列表的 URL

java - 设置背景(新颜色());在 Java 中不理解给定的 RGB 值

python - Tensorflow CIELAB 颜色空间边界

python - 用于比较 Cielab 颜色的 Delta E 函数返回值的区间是多少?

c++ - valgrind:opencv 中的 cvCvtColor 错误

c# - 何时将枚举与 Entity Framework 一起使用?

c# - 如何唤醒休眠线程?

jpeg - 如何将图像从jpg格式转换为ppm(P3)

java - 生成两种颜色之间的n种颜色

c# - 如何在属性中存储 Linq where 条件