图像的直方图和直方图均衡化

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)

图像的直方图和直方图均衡化_第1张图片图像的直方图和直方图均衡化_第2张图片图像的直方图和直方图均衡化_第3张图片

2.什么是直方图均衡化

  • 直方图均衡化是通过拉伸像素强度分布范围来增强图像对比度的一种方法。
  • 说得更清楚一些, 以上面的直方图为例, 你可以看到像素主要集中在右边的一些强度值上. 直方图均衡化要做的就是 拉伸 这个范围.。

图像的直方图和直方图均衡化_第4张图片图像的直方图和直方图均衡化_第5张图片

    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*). 对于直方图 H(i), 它的 累积分布 H^{'}(i) 是:

要使用其作为映射函数, 我们必须对最大值为255 (或者用图像的最大强度值) 的累积分布 H^{'}(i) 进行归一化. 同上例, 累积分布函数为:

图像的直方图和直方图均衡化_第6张图片

  • 最后, 我们使用一个简单的映射过程来获得均衡化后像素的强度值:

equalized( x, y ) = H^{'}( src(x,y) )

 

 

你可能感兴趣的:(opencv)