C计算CIELAB、CIELUV均匀颜色空间中两种颜色的色差

article/2025/10/6 15:15:22

C计算CIELAB、CIELUV均匀颜色空间中两种颜色的色差

** 如何利用C语言计算两种颜色在CIELAB、CIELUV的总色差?例如:已知两颜色样品的色度值为:Y1=76.79,x1=0.4480, y1=0.3478;Y2=75.67,x2=0.4621,y2=0.4090 试按照2°视场和D50光源计算两颜色的总色差 和(如果需要计算其他颜色的色差,只需要修改代码9、10行的初始值)直接给大家上源代码(vs2017):**

#include<stdio.h>
#include<math.h>
double Luv_vv(double X, double Y, double Z);//计算u’
double Luv_uu(double X, double Y, double Z);//计算v’
double cijizhiX(double x, double y, double Y);//计算X
double cijizhiZ(double z, double y, double Y);//计算Y
int main()
{double Y1 = 76.79, X1 = 0, Z1 = 0, x1 = 0.4480, y1 = 0.3478, z1 = 0, L1, a1, b1, uu1, vv1, u1, v1;//颜色1初始值double Y2 = 75.67, X2 = 0, Z2 = 0, x2 = 0.4621, y2 = 0.4090, z2 = 0, L2, a2, b2, uu2, vv2, u2, v2;//颜色2初始值double Y0 = 100, X0 = 96.42, Z0 = 82.51, uu0 = 0.20916, vv0 = 0.48808;//D50初始值double Eab = 0, Euv = 0;/*******************基本量的计算*****************/z1 = 1 - x1 - y1;z2 = 1 - x2 - y2;X1 = cijizhiX(x1, y1, Y1); Z1 = cijizhiZ(z1, y1, Y1);X2 = cijizhiX(x2, y2, Y2); Z2 = cijizhiZ(z2, y2, Y2);uu1 = Luv_uu(X1, Y1, Z1); uu2 = Luv_uu(X2, Y2, Z2);vv1 = Luv_vv(X1, Y1, Z1); vv2 = Luv_vv(X2, Y2, Z2);printf("X1=%f,Y1=%f,Z1=%f,X2=%f,Y2=%f,Z2=%f\n\n", X1, Y1, Z1, X2, Y2, Z2);/***********************颜色1************************/L1 = 116 * pow(Y1 / Y0, 1.0 / 3) - 16;a1 = 500 * (pow(X1 / X0, 1.0 / 3) - pow(Y1 / Y0, 1.0 / 3));b1 = 200 * (pow(Y1 / Y0, 1.0 / 3) - pow(Z1 / Z0, 1.0 / 3));u1 = 13 * L1*(uu1 - uu0);v1 = 13 * L1*(vv1 - vv0);printf("L1=%f,a1=%f,b1=%f,u1=%f,v1=%f\n\n", L1, a1, b1, u1, v1);/********************颜色2*********************/L2 = 116 * pow(Y2 / Y0, 1.0 / 3) - 16;a2 = 500 * (pow(X2 / X0, 1.0 / 3) - pow(Y2 / Y0, 1.0 / 3));b2 = 200 * (pow(Y2 / Y0, 1.0 / 3) - pow(Z2 / Z0, 1.0 / 3));u2 = 13 * L2*(uu2 - uu0);v2 = 13 * L2*(vv2 - vv0);printf("L2=%f,a2=%f,b2=%f,u2=%f,v2=%f\n\n", L2, a2, b2, u2, v2);/*********************总色差*************************/Eab = sqrt(pow(L1 - L2, 2) + pow(a1 - a2, 2) + pow(b1 - b2, 2));Euv = sqrt(pow(L1 - L2, 2) + pow(u1 - u2, 2) + pow(v1 - v2, 2));printf("总色差Eab=%lf\n总色差Euv=%lf\n\n", Eab, Euv);return 0;
}
double cijizhiX(double x,double y,double Y)
{
return x * Y / y;
}
double cijizhiZ(double z, double y, double Y)
{return z * Y / y;
}
double Luv_uu(double X, double Y, double Z)//计算u'
{double uu;return uu = 4 * X / (X + 15 * Y + 3 * Z);
}
double Luv_vv(double X, double Y, double Z)//计算v'
{double vv;return vv = 9 * Y / (X + 15 * Y + 3 * Z)

运行结果如下:(结果正确)
在这里插入图片描述


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

相关文章

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

项目场景&#xff1a; 提示&#xff1a;在颜色科学中&#xff0c;LCh和Lab是比较常用的 LCh是由MATLAB计算出的数据&#xff0c;但是我所需要在Qt的q3dsurface绘制出这个切面&#xff0c;看了Qt官方Examples&#xff0c;墨西哥草帽算法的3D模型就是由XYZ组成的。所以我需要LC…

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…