数字图像处理(c++ opencv):彩色图像处理-彩色基础与彩色模型

彩色图像基础

颜色特性:亮度、色调、饱和度

  • (1)亮度:即强度,如灰度值

  • (2)色调:混合光波中的主导光波属性,即被观察者感知的主导色。如描述一个物体为红色,就是这个物体的色调为红色。

  • (3)饱和度:指相对的纯度,或与一种色调混合的白光量。比如深红色(红色+白色)和淡紫色(紫色+白色)是不饱和的,白色越多,越不饱和。

色度:色调+饱和度,颜色可以由亮度+色度来表征

彩色图像模型

常见的彩色图像模型有:

  • (1)RGB(红、绿、蓝):一般用于彩色显示器和彩色摄像机;

  • (2)CMY(青、深红、黄)和CMYK(青、深红、黄、黑):一般用于彩色打印;

  • (3)HSI(色调、饱和度、亮度):描述和解释颜色;

RGB和HSI之间的相互转换

从RGB到HSI

H色调分量的计算:

S饱和度分量计算:

I 亮度分量计算:

备注:上面的转换公式假设图像的RGB值归一化到[0, 1]区间,得到的HSI结果值也在区间[0, 1]。

python 复制代码
def RGB2HSI(img1):
    img1 = img1.astype('float32')
    b, g, r = img1[:, :, 0]/255.0, img1[:, :, 1]/255.0, img1[:, :, 2]/255.0

    I = (r+g+b)/3.0

    tem = np.where(b >= g, g, b)
    minValue = np.where(tem >= r, r, tem)
    S = 1 - (3 / (r + g + b)) * minValue

    num1 = 2*r - g - b
    num2 = 2*np.sqrt(((r - g) ** 2) + (r-b)*(g-b))
    deg = np.arccos(num1/num2)
    H = np.where(g >= b, deg, 2*np.pi - deg)

    resImg = np.zeros((img1.shape[0], img1.shape[1],
                    img1.shape[2]), dtype=np.float)
    resImg[:, :, 0], resImg[:, :, 1], resImg[:, :, 2] = H*255, S*255, I*255
    resImg = resImg.astype('uint8')
    return resImg
从HSI到RGB(值区间与(1)相同[0, 1])

前提:在将HSI转换为RGB时,需要先通过H色调值进行判断,然后使用不同的公式:

  • 即将H值乘360°,将值从[0, 1]转换到[0, 360],然后进行分类:

  • RG扇区(H在[0, 120]):

B蓝色分量计算:

R红色分量计算:

G绿分量计算:

GB扇区(H在[120, 240]):

首先将H减去120:

然后转换到RGB:

BR扇区(H在[240, 360]):

首先将H减去240:

然后计算RGB值:

python 复制代码
def HSI2RGB(img):
    H1, S1, I1 = img[:,:,0]/255.0, img[:,:,1]/255.0, img[:,:,2]/255.0
    B = np.zeros((H1.shape[0], H1.shape[1]), dtype='float32')
    G = np.zeros((S1.shape[0], S1.shape[1]), dtype='float32')
    R = np.zeros((I1.shape[0], I1.shape[1]), dtype='float32')
    H = np.zeros((H1.shape[0], H1.shape[1]), dtype='float32')
    
    for i in range(H1.shape[0]):
        for j in range(H1.shape[1]):
            H = H1[i][j]
            S = S1[i][j]
            I = I1[i][j]   
            if (H >=0) & (H < (np.pi * (2/3))):
                B[i][j] = I*(1-S)
                R[i][j] = I * (1 + ((S*np.cos(H))/np.cos(np.pi * (1/3) - H)))
                G[i][j] = 3*I - (B[i][j]+R[i][j])
                
            elif (H >= (np.pi * (2/3))) & (H < np.pi * (4/3)):
                R[i][j] = I*(1-S)
                G[i][j] = I * (1 + ((S*np.cos(H - np.pi * (2/3)))/np.cos(np.pi * (1/2) - H)))
                B[i][j] = 3*I - (G[i][j]+R[i][j])
            elif (H >= (np.pi * (2/3))) & (H < (np.pi * 2)):
                G[i][j] = I*(1-S)
                B[i][j] = I * (1 + ((S*np.cos(H - np.pi * (4/3)))/np.cos(np.pi * (10/9) - H)))
                R[i][j] = 3*I - (G[i][j]+B[i][j])
    img = cv2.merge((B*255, G*255, R*255))
    img = img.astype('uint8')
    return img
相关推荐
minstbe2 分钟前
AI开发 - 算法基础 递归 的概念和入门(二)汉诺塔问题 递归的应用和使用注意 - Python
开发语言·python·算法
web1478621072317 分钟前
Python毕业设计选题:基于django+vue的疫情数据可视化分析系统
python·信息可视化·课程设计
岁月如歌,青春不败26 分钟前
HMSC联合物种分布模型
开发语言·人工智能·python·深度学习·r语言
TANGLONG22227 分钟前
【初阶数据结构与算法】八大排序之非递归系列( 快排(使用栈或队列实现)、归并排序)
java·c语言·数据结构·c++·算法·蓝桥杯·排序算法
susu108301891129 分钟前
python中Windows系统使用 pywin32 来复制图像到剪贴板,并使用 Selenium 模拟 Ctrl+V 操作
python·selenium
不想当程序猿_30 分钟前
【蓝桥杯每日一题】与或异或——DFS
c++·算法·蓝桥杯·深度优先
Pocker_Spades_A31 分钟前
阿里云-通义灵码:在 PyCharm 中的强大助力(下)
ide·python·阿里云·pycharm
言之。33 分钟前
【Java】面试题 并发安全 (1)
java·开发语言
m0_7482345233 分钟前
2025最新版Java面试八股文大全
java·开发语言·面试
chengxuyuan1213_39 分钟前
Python有哪些常用的库
开发语言·python