1.图像的直方图
- 直方图是图像中像素强度分布的图形表达方式。
- 它统计了每一个强度值所具有的像素个数。
import cv2
import matplotlib.pyplot as plt
original_img = cv2.imread("airplane.jpg")
img_gray=cv2.cvtColor(original_img,cv2.COLOR_BGR2GRAY)
img=img_gray.flatten()
n, bins, patches = plt.hist(img, bins=256, density=1, facecolor='green', alpha=0.75)
plt.show()
cv2.imshow("gray",img_gray)
cv2.waitKey(0)
2.什么是直方图均衡化
- 直方图均衡化是通过拉伸像素强度分布范围来增强图像对比度的一种方法。
- 说得更清楚一些, 以上面的直方图为例, 你可以看到像素主要集中在右边的一些强度值上. 直方图均衡化要做的就是 拉伸 这个范围.。
import cv2
import matplotlib.pyplot as plt
original_img = cv2.imread("airplane.jpg")
img_gray=cv2.cvtColor(original_img,cv2.COLOR_BGR2GRAY)
dst = cv2.equalizeHist(img_gray)
img=dst.flatten()
n, bins, patches = plt.hist(img, bins=256, density=1, facecolor='green', alpha=0.75)
plt.show()
cv2.imshow("gray",img_gray)
cv2.imshow("dst_gray",dst)
cv2.waitKey(0)
3.直方图均衡化的原理
-
均衡化指的是把一个分布 (给定的直方图) 映射 到另一个分布 (一个更宽更统一的强度值分布), 所以强度值分布会在整个范围内展开.
-
要想实现均衡化的效果, 映射函数应该是一个 累积分布函数 (cdf) (更多细节, 参考*学习OpenCV*). 对于直方图 , 它的 累积分布 是:
要使用其作为映射函数, 我们必须对最大值为255 (或者用图像的最大强度值) 的累积分布 进行归一化. 同上例, 累积分布函数为:
- 最后, 我们使用一个简单的映射过程来获得均衡化后像素的强度值: