当前位置:   article > 正文

OpenCV 直方图均衡化_opencv直方图均衡化函数

opencv直方图均衡化函数

声明

声明:本系列博客是我在学习OpenCV官方教程中文版(For Python)(段力辉 译)所做的笔记。所以,其中的绝大部分内容引自这本书,博客中的代码也是其配套所附带的代码或书中的代码,侵删。其中部分代码可能会因需要而改动。在本系列博客中,其中包含书中的引用,也包括我自己对知识的理解,思考和总结。本系列博客的目的主要有两个,一个是可以作为我自己的学习笔记,时常复习巩固。第二个是可以为想学习python下的opencv 3 相关知识的朋友提供一些参考。

正文

1.什么是直方图均衡化?

直方图均衡化是图像处理领域中利用图像直方图对对比度进行调整的方法。

2.直方图均衡化有什么用?

  • 这种方法通常用来增加许多图像的全局对比度,尤其是当图像的有用数据的对比度相当接近的时候。通过这种方法,亮度可以更好地在直方图上分布。这样就可以用于增强局部的对比度而不影响整体的对比度,直方图均衡化通过有效地扩展常用的亮度来实现这种功能。这种方法对于背景和前景都太亮或者太暗的图像非常有用,这种方法尤其是可以带来X光图像中更好的骨骼结构显示以及曝光过度或者曝光不足照片中更好的细节。
  • 直方图均衡化在很多时候都很有用,例如,脸部识别,在训练分类器前,训练集的所有图片都要先进行直方图均衡化从而使它们达到相同的亮度条件。

3.直方图均衡化的优缺点

  • 优点:这种方法的一个主要优势是它是一个相当直观的技术并且是可逆操作,如果已知均衡化函数,那么就可以恢复原始的直方图,并且计算量也不大。
  • 缺点:它对处理的数据不加选择,它可能会增加背景噪声的对比度并且降低有用信号的对比度。

3.如何实现直方图均衡化?

直方图均衡化要做的事情就是,当一副图像中的大多是像素点的像素值都集中在一个像素值范围之内时,例如,如果一幅图片整体很亮,那所有的像素值应该都会很高。但是一副高质量的图像的像素值分布应该很广泛。所以你应该把它的直方图做一个横向拉伸(如下图),这个横向拉伸的过程就是直方图均衡化要做的要做的事情,通常情况下这种操作会改善图像的对比度。
在这里插入图片描述

OpenCV中的直方图均衡化:

3.1 cv2.equalizeHist()

OpenCV中的直方图均衡化函数为cv2.equalizeHist(),这个函数的输入图片仅仅是一副灰度图像,输出结果是直方图均衡化之后的图像。来看看代码:

import cv2
import numpy as np

img = cv2.imread('jianzhu2.jpg',0)
equ = cv2.equalizeHist(img)
res = np.hstack((img,equ))

cv2.imwrite('jianzhu2_1.png',res)

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

这是原图:
在这里插入图片描述
这是运行结果:
在这里插入图片描述

当直方图中的数据集中在某一个灰度值范围内时,直方图均衡化很有用。

3.2 CLAHE 有限对比适应性直方图均衡化

我们使用上边这个函数做的直方图均衡化会改变整个图像的对比度,但是在很多情况下,这样做的效果并不好。例如,下图分别是输入图像和进行直方图均衡化之后的输出图像。
在这里插入图片描述

的确在进行完直方图均衡化之后,图片背景的对比度被改变了。但是你再对比一下两幅图像中雕像的面图,由于太亮我们丢失了很多信息。造成这种结果的根本原因在于这幅图像的直方图并不是集中在某一个区域(如果不明白,试着画出它的直方图,你就明白了)。

为了解决这个问题,我们需要使用自适应的直方图均衡化。这种情况下,整幅图像会被分成很多小块,这些小块被称为“tiles”(在 OpenCV 中 tiles 的大小默认是 8x8),然后再对每一个小块分别进行直方图均衡化(跟前面类似)。

所以在每一个的区域中,直方图会集中在某一个小的区域中(除非有噪声干扰)。如果有噪声的话,噪声会被放大。为了避免这种情况的出现要使用对比度限制。对于每个小块来说,如果直方图中的 bin 超过对比度的上限的话,就把其中的像素点均匀分散到其他 bins 中,然后在进行直方图均衡化。最后,为了去除每一个小块之间“人造的”(由于算法造成)边界,再使用双线性差值,对小块进行缝合。

下面的代码显示了如何使用OpenCV中的CLAHE。
这次同样使用刚那张图片,我们可以清晰地看到这两种不同方法的差别。

import cv2
import numpy as np

img = cv2.imread('jianzhu2.jpg',0)
clahe = cv2.createCLAHE(clipLimit=2.0, tileGridSize=(8,8))
cl1 = clahe.apply(img)
cv2.imwrite('jianzhu2_2.jpg',cl1)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

运行结果:
在这里插入图片描述
可以看到,在很亮的地方有了很大的改善。

这个方法的确效果很好,以下是更多的例子:
这是原图:
在这里插入图片描述
经过CLAHE 有限对比适应性直方图均衡化后:在这里插入图片描述

这是原图:
在这里插入图片描述
经过CLAHE 有限对比适应性直方图均衡化后:
在这里插入图片描述
效果真的很棒!

感谢观看!

如有错误,欢迎批评指正!

本文内容由网友自发贡献,转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/141156?site
推荐阅读
相关标签
  

闽ICP备14008679号