CIE颜色空间LCh、Lab、XYZ-sRGB介绍与转换关系(包含源码)

article/2025/10/6 12:57:25

项目场景:

提示:在颜色科学中,LCh和Lab是比较常用的

LCh是由MATLAB计算出的数据,但是我所需要在Qt的q3dsurface绘制出这个切面,看了Qt官方Examples,墨西哥草帽算法的3D模型就是由XYZ组成的。所以我需要LCh->Lab->XYZ,这三步的转换。


LCh、Lab、XYZ概念

  • LCh
    CIELCh颜色空间用于描述颜色的亮度、色度和色相。
    CIELCh颜色空间相比CIELAB颜色空间更加直观,它以极坐标形式表示颜色属性,更适合描述颜色的外观特征和感知属性。
    Lightness(L)指的是颜色的明暗程度或亮度级别。它表示颜色相对于中性灰色的明暗程度,取值范围通常为0到100。较低的亮度值接近黑色,较高的亮度值接近白色。
    Chroma(C)表示颜色的饱和度或色彩的强度。它衡量的是颜色相对于中性灰色的纯度或饱和度。较低的色度值表示颜色较暗或接近灰色,而较高的色度值表示颜色鲜艳、饱和度较高。
    Hue表示色相(h),取值范围为0到360度,表示颜色在色轮上的位置。

  • Lab
    CIELAB颜色空间是通过对人眼对不同光谱刺激的感知进行数学建模而得到的。
    L表示亮度(Lightness),取值范围为0到100,表示从黑到白的亮度级别。
    a表示颜色在红绿轴上的位置,取值范围为-128到+127,其中负值表示绿色,正值表示红色。
    b表示颜色在黄蓝轴上的位置,取值范围为-128到+127,其中负值表示蓝色,正值表示黄色。

  • XYZ
    X表示颜色在红-绿轴上的位置。
    Y表示颜色在亮度轴上的位置。
    Z表示颜色在黄-蓝轴上的位置。


LCh转Lab

  1. 获取LCh颜色空间中的L、Chroma和Hue分量的值。
  2. 计算Lab颜色空间中的a和b分量,可以使用以下公式:a = Chroma * cos(Hue),b = Chroma * sin(Hue)。
  3. 最终的Lab颜色空间中的分量为L、a和b。

CIELab颜色空间中的三个分量对应于3D坐标空间中的以下轴
L(亮度):对应于Y轴,表示颜色的明暗程度。
a(红绿):对应于X轴,表示颜色在红色和绿色之间的位置。
b(黄蓝):对应于Z轴,表示颜色在黄色和蓝色之间的位置。

#include <cmath>void LChToLab(double L, double Chroma, double Hue, double& Lab_L, double& Lab_a, double& Lab_b)
{Lab_a = Chroma * std::cos(Hue);Lab_b = Chroma * std::sin(Hue);Lab_L = L;
}

L表示LCh颜色空间中的亮度分量,Chroma表示色度分量,Hue表示色相分量。通过调用该函数并传入LCh颜色的分量值,即可获得对应的Lab颜色空间中的L、a和b分量的值


Lab转XYZ

  1. 获取Lab颜色空间中的L、a和b分量的值。
  2. 将Lab中的L、a和b分量进行逆变换,得到对应的线性RGB颜色空间中的R、G和B分量。这可以通过使用Lab到XYZ转换矩阵来实现。
  3. 将线性RGB颜色空间中的R、G和B分量进行非线性校正,以获得标准化的RGB值。
  4. 将标准化的RGB值转换为XYZ颜色空间中的X、Y和Z分量,也可以通过使用RGB到XYZ转换矩阵来实现。
  5. 再转成sRGB。
void LabToXYZ(double Lab_L, double Lab_a, double Lab_b, double& XYZ_X, double& XYZ_Y, double& XYZ_Z)
{// Lab到XYZ转换矩阵double Xr = 0.95047;double Yr = 1.00000;double Zr = 1.08883;double fy = (Lab_L + 16.0) / 116.0;double fx = fy + (Lab_a / 500.0);double fz = fy - (Lab_b / 200.0);double xr = (std::pow(fx, 3.0) > 0.008856) ? std::pow(fx, 3.0) : ((fx - 16.0 / 116.0) / 7.787);double yr = (Lab_L > (903.3 * 0.008856)) ? std::pow((Lab_L + 16.0) / 116.0, 3.0) : (Lab_L / 903.3);double zr = (std::pow(fz, 3.0) > 0.008856) ? std::pow(fz, 3.0) : ((fz - 16.0 / 116.0) / 7.787);XYZ_X = xr * Xr;XYZ_Y = yr * Yr;XYZ_Z = zr * Zr;
}

在函数中,Lab_L、Lab_a和Lab_b分别表示Lab颜色空间中的L、a和b分量的值。通过调用该函数并传入Lab颜色的分量值,即可获得对应的XYZ颜色空间中的X、Y和Z分量的值。请注意,示例中的转换矩阵参数(Xr、Yr和Zr)是用于D65标准光源的参数,你可以根据需要调整它们以适应不同的光源。

Demo

#include <iostream>
#include <vector>
#include <cmath>struct Lab {int L;int a;int b;
};struct XYZ {int X;int Y;int Z;
};XYZ convertLabtoXYZ(const Lab& lab)
{double L = lab.L / 100.0;double a = (lab.a - 128) / 127.0;double b = (lab.b - 128) / 127.0;double X = 0.95047 * pow(((L + 0.16) / 1.16), 3.0);double Y = 1.00000 * pow(((L + 0.16) / 1.16), 3.0);double Z = 1.08883 * pow(((L + 0.16) / 1.16), 3.0);X = X + (0.43607 * a) - (0.39894 * b);Y = Y - (0.00003 * a) + (0.03951 * b);Z = Z + (0.00816 * a) + (0.01388 * b);XYZ xyz;xyz.X = static_cast<int>(X * 100);xyz.Y = static_cast<int>(Y * 100);xyz.Z = static_cast<int>(Z * 100);return xyz;
}int main()
{// 示例使用int N = 3;std::vector<Lab> labValues(N);std::vector<XYZ> xyzValues(N);// 假设输入的LAB值labValues[0] = {50, 0, 0};labValues[1] = {75, 30, -40};labValues[2] = {90, -10, 20};// 将每个LAB值转换为XYZ值for (int i = 0; i < N; ++i) {xyzValues[i] = convertLabtoXYZ(labValues[i]);}// 打印转换后的XYZ值for (int i = 0; i < N; ++i) {XYZ xyz = xyzValues[i];std::cout << "Lab: L=" << labValues[i].L << ", a=" << labValues[i].a << ", b=" << labValues[i].b<< " -> XYZ: X=" << xyz.X << ", Y=" << xyz.Y << ", Z=" << xyz.Z << std::endl;}return 0;
}

这边举了3组数据进行计算。
在这里插入图片描述
完结撒花,球球一件三联噢,这真的对我很重要
在这里插入图片描述


http://chatgpt.dhexx.cn/article/sg2FUHMn.shtml

相关文章

RGB和CIELAB颜色空间转换及偏色检测

RGB转为CIELAB 首先RGB是不可以直接转为CIELAB颜色空间的&#xff0c;RGB需要先转为CIEXYZ颜色空间&#xff0c;然后再由CIEXYZ颜色空间转为CIELAB颜色空间。关于这2个颜色空间的互转&#xff0c;主要参考了http://www.cnblogs.com/Imageshop/archive/2013/02/02/2889897.html…

sRGB转CIEXYZ转CIELAB,以及色彩距离

sRGB是标准色彩空间 是一个微软和惠普于1996年定义的标准色彩空间 如果想从sRGB转到CIEXYZ空间&#xff0c;要乘以这个矩阵&#xff1a; 得到CIEXYZ之后&#xff0c;可以再转成CIELAB&#xff1a; 其中 X 0 , Y 0 , Z 0 X_0, Y_0, Z_0 X0​,Y0​,Z0​是定义的参考白点&#…

深入理解color model(颜色模型)

什么是颜色 Wiki是这样说的&#xff1a;颜色或色彩是通过眼、脑和我们的生活经验所产生的一种对光的视觉效应。嗯&#xff0c;简单点说&#xff0c;颜色就是人对光的一种感觉&#xff0c;由大脑产生的一种感觉。感觉是一个很主观的东西&#xff0c;你怎么确定你看到的红色和我…

深度学习AI美颜系列---肤色相似度计算(CIELAB色差计算)

深度学习AI美颜系列---肤色相似度计算&#xff08;CIELAB色差计算&#xff09; 在AI美颜中&#xff0c;经常会用到肤色相似度计算&#xff0c;如何实现这个算法&#xff1f; 步骤如下&#xff1a; 1&#xff0c;人脸皮肤分割&#xff1b; 2&#xff0c;对人脸皮肤分割结果进…

彩色图像--色彩空间 CIELAB、CIELUV

学习DIP第65天 转载请标明本文出处&#xff1a;http://blog.csdn.net/tonyshengtan &#xff0c;出于尊重文章作者的劳动&#xff0c;转载请标明出处&#xff01;文章代码已托管&#xff0c;欢迎共同开发&#xff1a;https://github.com/Tony-Tan/DIPpro 更多图像处理机器学习内…

【视觉基础篇】10 # 图形系统如何表示颜色?

说明 【跟月影学可视化】学习笔记。 RGB 和 RGBA 颜色 RGB 和 RGBA 的颜色表示法 #RRGGBB 是 RGB 颜色的十六进制表示法&#xff0c;其中 RR、GG、BB 分别是两位十六进制数字&#xff0c;表示红、绿、蓝三色通道的色阶。 色阶可以表示某个通道的强弱。 每个通道一共有 25…

CIELab图像的通道分解与合成

import cv2 import numpy as np lotus cv2.imread(lotus.jpg) showImgByPlot(lotus,10,6) lotus_lab cv2.cvtColor(lotus, cv2.COLOR_BGR2LAB) l, a, b cv2.split(lotus_lab) #! featureMat cv2.merge([l, a, b]) #! merge失败 featureMat np.dstack((l, a, b)).astype(np…

CIELab和LCH的色彩空间图

资料来源&#xff1a;http://www.18show.cn/share_news/599547.html CIE Lab&#xff1a; LAB色空间是基于一种颜色不能同时既是蓝又是黄这个理论而建立。所以CIE Lab&#xff0c;单一数值可用于描述红/绿色及黄/蓝色特徽。当一种颜色用CIE L*a*b*时&#xff0c;L* 表示明度值…

CIELAB色差计算

CIE色差计算就是在之前Lab颜色空间进行的。色差一般指的是由于位置不同或者放大率不同所造成的颜色差异。而在图像处理领域&#xff0c;尤其是针对色彩的处理中&#xff0c;很重要的一点就是消除色差。那么接下来我们就讨论CIE色差公式的改进过程&#xff0c;每次改进的意义&am…

彩色空间-CIELAB和LAB的关系

CIELAB和LAB的关系 CIELab是CIE的一个颜色系统&#xff0c;表色体系&#xff0c;基于CIELab的意思是基于这个颜色系统之上&#xff0c;基本是用于确定某个颜色的数值信息。 Hunter 1948 L, a, b色彩空间的坐标是L, a和b。但是&#xff0c;Lab经常用做CIE 1976 (L*, a*, b*)色彩…

MATLAB GUI设计如何弹出新界面?

本意是想要设计一个图像处理系统&#xff0c;在该系统中点击按钮可以跳转到另一个GUI界面&#xff0c;在该界面设计后将所设置参数引回到原有的GUI界面&#xff0c;并在该界面进行显示处理好的图像。各位如果有好的结果的话麻烦江湖救急&#xff01;或者可以加我QQ&#xff1a;…

Matlab GUI编程

在matlab命令行上输入guide或者从菜单中选择New GUI可以创建matlab的图形用户界面。 创建空白的GUI界面&#xff08;默认&#xff09;&#xff0c;其界面如下&#xff1a; 未命名情况下matlab将会在当前工作目录下&#xff0c;同时将会生成untitled.fig和untitled.m文件。其中…

学习matlab(十四)——GUI

1.编程方法 在本章首先详细的介绍了MATLAB的图形句柄,通过对图形对象的属性进行设置,可以是实现图形的底层控制和设置。然后介绍了用户接口对象,用于建立各种按钮、菜单和工具条等。最后介绍了常用的对话框,这些对话框是GUI编程常用的基本元件。 在MATLAB中,各种句柄图形对象…

matlab制作GUI界面(1)

matlab制作GUI界面 概述创建GUI界面界面设置静态文本最后 概述 图形用户界面&#xff08;Graphical User Interface&#xff0c;简称 GUI&#xff0c;又称图形用户接口&#xff09;是指采用图形方式显示的计算机操作用户界面。 图形用户界面是一种人与计算机通信的界面显示格式…

matlab GUI编程入门

转载请注明来自&#xff1a;黄朝辉的博客 1.前言 这里我们来实现一个加法器&#xff0c;功能比较简单&#xff0c;主要用于了解matlab中的代码是如何与控件进行交互。 2.绘制界面 在命令行窗口中输入&#xff1a; >> guide 直接“确定”即可。 将需要的控件从左边托…

MATLAB GUI学习———简易计算器

暑假快要过完了才想起来学习&#xff0c;最近刚好接触到MATLAB中的GUI&#xff0c;觉得还挺有意思的&#xff0c;今天就用GUI产生了一个简易的计算器&#xff0c;实现了基本的加、减、乘、除运算。由于是新手小白&#xff0c;所以刚刚开始的时候&#xff0c;我是在网上去找了一…

MATLAB的GUI设计——计算器

出于兴趣爱好自学了一段时间的MATLAB&#xff0c;然后学习自制了一个属于自己的一个计算器&#xff0c;现在将我的第一个GUI分享给大家。&#xff08;MATLAB版本为R2019a&#xff09; 一、准备工作 ①首先在MATLAB中的命令行窗口输入guide&#xff0c;之后会出现如下界面&…

MATLAB 编写一个简单的GUI

MATLAB作为一个使用方便、容易上手的工具&#xff0c;也经常用来进行相关项目的结果展示 本次博客讲解一下如何创建一个简单的GUI 首先&#xff0c;启动matlab&#xff0c;在命令窗口输入 guide 在弹出的窗口选择 Blank GUI 在随后弹出的窗口中&#xff0c;左侧是工具栏&#…

Matlab GUI组件详解

1、触控按钮&#xff08;Push Button&#xff09; 在Push Button 上双击调用属性查看器可以查看和设置Push Button 的所有属性Push Button 对象的常用属性见下表。 2、静态文本&#xff08;Static Text&#xff09; Static Text 通常用于显示其他对象的数值状态等Static Text…

MATLAB创建GUI

1.matlab命令行输入guide&#xff0c;新建GUI图形界面&#xff0c;或者新建–应用程序–GUIDE&#xff0c;选择Blank GUI&#xff0c;选择路径。 2.在图形界面点击左侧控件和组件构建图形界面。 主要用到的控件和组件&#xff1a; &#xff08;1&#xff09;按钮&#xff08;选…