使用两种方法对彩色图像进行直方图均衡化处理,对比两种处理方法的结果。 (1) 对图像的R、G、B三个彩色分量进行直方图均衡化; (2) 将图像从RGB颜色空间转换到HSI颜色空间,使用直方图均衡化单独处理亮度I分量,随后将图像从HSI空间转换回到RGB颜色空间。
时间: 2024-02-06 10:10:16 浏览: 113
基于MATLAB对低照度图像进行直方图均衡化和同态滤波操作.zip
5星 · 资源好评率100%
方法一:对图像的R、G、B三个彩色分量进行直方图均衡化
1. 读入图像并将其拆分为R、G、B三个通道
```python
import cv2
import numpy as np
img = cv2.imread('image.jpg')
# 拆分为三个通道
b, g, r = cv2.split(img)
```
2. 分别对三个通道进行直方图均衡化
```python
# 直方图均衡化
b_eq = cv2.equalizeHist(b)
g_eq = cv2.equalizeHist(g)
r_eq = cv2.equalizeHist(r)
```
3. 合并三个通道并显示结果
```python
# 合并三个通道
img_eq = cv2.merge([b_eq, g_eq, r_eq])
# 显示结果
cv2.imshow('Original Image', img)
cv2.imshow('Equalized Image', img_eq)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
方法二:将图像从RGB颜色空间转换到HSI颜色空间,使用直方图均衡化单独处理亮度I分量,随后将图像从HSI空间转换回到RGB颜色空间。
1. 定义RGB到HSI的转换函数
```python
def rgb2hsi(img):
"""
RGB颜色空间到HSI颜色空间的转换
:param img: RGB图像
:return: HSI图像
"""
# 归一化RGB图像
img = img / 255.0
b, g, r = cv2.split(img)
# 计算亮度分量I
i = (r + g + b) / 3.0
# 计算饱和度分量S
s = 1 - np.minimum(np.minimum(r, g), b) / i
# 计算色调分量H
h = np.zeros_like(i)
mask = i != 0
h[mask] = np.arccos((0.5 * ((r - g) + (r - b))) / (np.sqrt((r - g) ** 2 + (r - b) * (g - b)) + 1e-10))
mask = (b > g) & (mask == True)
h[mask] = 2 * np.pi - h[mask]
h[i == 0] = 0
# 将HSI图像的三个分量缩放到0-255之间,便于显示
h = h * 180 / np.pi / 2
s = s * 255
i = i * 255
hsi = cv2.merge([h, s, i])
return hsi
```
2. 定义HSI到RGB的转换函数
```python
def hsi2rgb(img):
"""
HSI颜色空间到RGB颜色空间的转换
:param img: HSI图像
:return: RGB图像
"""
# 将HSI图像的三个分量缩放回原来的值域
h, s, i = cv2.split(img)
h = h * np.pi * 2 / 180
s = s / 255.0
i = i / 255.0
# 计算RGB图像的三个分量
r, g, b = np.zeros_like(h), np.zeros_like(h), np.zeros_like(h)
mask = (0 <= h) & (h < 2 * np.pi / 3)
b[mask] = i[mask] * (1 - s[mask])
r[mask] = i[mask] * (1 + s[mask] * np.cos(h[mask]) / np.cos(np.pi / 3 - h[mask]))
g[mask] = 3 * i[mask] - (r[mask] + b[mask])
mask = (2 * np.pi / 3 <= h) & (h < 4 * np.pi / 3)
h[mask] = h[mask] - 2 * np.pi / 3
r[mask] = i[mask] * (1 - s[mask])
g[mask] = i[mask] * (1 + s[mask] * np.cos(h[mask]) / np.cos(np.pi / 3 - h[mask]))
b[mask] = 3 * i[mask] - (r[mask] + g[mask])
mask = (4 * np.pi / 3 <= h) & (h < 2 * np.pi)
h[mask] = h[mask] - 4 * np.pi / 3
g[mask] = i[mask] * (1 - s[mask])
b[mask] = i[mask] * (1 + s[mask] * np.cos(h[mask]) / np.cos(np.pi / 3 - h[mask]))
r[mask] = 3 * i[mask] - (g[mask] + b[mask])
# 将RGB图像的三个分量缩放到0-255之间,便于显示
rgb = cv2.merge([b, g, r])
rgb = np.clip(rgb * 255, 0, 255).astype(np.uint8)
return rgb
```
3. 将图像从RGB颜色空间转换到HSI颜色空间,使用直方图均衡化单独处理亮度I分量
```python
# RGB到HSI的转换
hsi = rgb2hsi(img)
# 对亮度分量I进行直方图均衡化
i_eq = cv2.equalizeHist(hsi[:, :, 2].astype(np.uint8))
# 将处理后的亮度分量I替换原来的分量
hsi[:, :, 2] = i_eq.astype(np.float32) / 255.0
```
4. 将图像从HSI颜色空间转换回到RGB颜色空间,并显示结果
```python
# HSI到RGB的转换
img_eq = hsi2rgb(hsi)
# 显示结果
cv2.imshow('Original Image', img)
cv2.imshow('Equalized Image', img_eq)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
两种方法的对比:
方法二得到的结果更加自然,能够更好地保留图像的颜色信息和纹理细节,但是计算过程较为复杂,速度较慢。方法一计算简单,速度较快,但是得到的结果有时可能会出现颜色失真或者过度增强的情况。因此,在实际应用中需要根据具体情况选择合适的方法。
阅读全文