图像处理22:图像模糊(滤波器)

与一维信号一样,也可以对 2D 图像实施低通滤波(LPF),高通滤波 (HPF)等。LPF 可以帮助去除噪音,模糊图像。HPF 可以帮助找到图像的边缘 OpenCV 提供的函数cv.filter2D() 可以让我们对一幅图像进行卷积操作。下面我们将对一幅图像使用平均滤波器。下面是一个 5x5 的平均滤波器核:

图像处理22:图像模糊(滤波器)_第1张图片

操作如下:将核放在图像的一个像素A上,求与核对应的图像上25(5x5) 个像素的和,在取平均数,用这个平均数替代像素 A 的值。重复以上操作直到 将图像的每一个像素值都更新一边。

使用低通滤波器可以达到图像模糊的目的。这对与去除噪音很有帮助。其实就是去除图像中的高频成分(比如:噪音,边界)。所以边界也会被模糊一 点。(当然,也有一些模糊技术不会模糊掉边界)。OpenCV 提供了四种模糊技术。

1、平均 

这是由一个归一化卷积框完成的。他只是用卷积框覆盖区域所有像素的平 均值来代替中心元素。可以使用函数 cv2.blur()cv2.boxFilter() 来完 这个任务。可以同看查看文档了解更多卷积框的细节。我们需要设定卷积框的宽和高。下面是一个 3x3 的归一化卷积框:

图像处理22:图像模糊(滤波器)_第2张图片

注意:如果你不想使用归一化卷积框,你应该使用 cv2.boxFilter(),这时要 传入参数 normalize=False。

2、高斯模糊 

现在把卷积核换成高斯核(简单来说,方框不变,将原来每个方框的值是相等的,现在里面的值是符合高斯分布的,方框中心的值最大,其余方框根据距离中心元素的距离递减,构成一个高斯小山包。原来的求平均数现在变成求加权平均数,全就是方框里的值)。实现的函数是cv2.GaussianBlur()。需要指定高斯核的宽和高(必须是奇数)。以及高斯函数沿 X,Y 方向的标准差。如果我们只指定了 X 方向的的标准差,Y 方向也会取相同值。如果两个标准差都是 0,那么函数会根据核函数的大小自己计算。高斯滤波可以有效的从图像中去除高斯噪音。也可以使用函数cv2.getGaussianKernel() 自己 构建一个高斯核。 

3、中值模糊 

是用与卷积框对应像素的中值来替代中心像素的值。这个滤波器经常用来去除椒盐噪声(脉冲噪声)。前面的滤波器都是用计算得到的一个新值来取代中心像素的值,而中值滤波是用中心像素周围(也可以使他本身)的值来取代他。 他能有效的去除噪声。卷积核的大小也应该是一个奇数。 

4、双边滤波 

函数 cv2.bilateralFilter() 能在保持边界清晰的情况下有效的去除噪音。但是这种操作与其他滤波器相比会比较慢。高斯滤波器是求中心点邻近区域像素的高斯加权平均值。这种高斯滤波器只考虑像素之间的空间关系,而不会考虑像素值之间的关系(像素的相似度)。所以这种方法不会考虑一个像素是否位于边界。因此边界也会别模糊掉,而这正不是我们想要。 双边滤波在同时使用空间高斯权重和灰度值相似性高斯权重。

空间高斯函数确保只有邻近区域的像素对中心点有影响,灰度值相似性高斯函数确保只有与中心像素灰度值相近的才会被用来做模糊运算。所以这种方法会确保边界不会被模糊掉,因为边界处的灰度值变化比较大。 


#coding:utf-8
import cv2
import numpy as np
from  matplotlib import pyplot as plt


img = cv2.imread('F:/face.jpg',-1)

b, g, r = cv2.split(img)
img = cv2.merge([r,g,b])#转换色彩,由bgr转为rgb

kernel = np.ones((5,5), np.float32)/25
dst = cv2.filter2D(img,-1,kernel) #平均滤波器
blur = cv2.blur(img,(5,5))#平均模糊
gauss = cv2.GaussianBlur(img,(5,5),0)#高斯模糊
median = cv2.medianBlur(img,5)#中值滤波
bilater = cv2.bilateralFilter(img, 9, 75, 75)#双边滤波器
for i in xrange(50):
    dst = cv2.filter2D(dst, -1, kernel)  # 平均滤波器
    blur = cv2.blur(blur, (5, 5))  # 平均模糊
    gauss = cv2.GaussianBlur(gauss, (5, 5), 0)  # 高斯模糊
    median = cv2.medianBlur(median, 5)  # 中值滤波
    bilater = cv2.bilateralFilter(bilater, 9, 75, 75)  # 双边滤波器

plt.subplot(231),plt.imshow(img),plt.title('Original')
plt.xticks([]),plt.yticks([])
plt.subplot(232),plt.imshow(dst),plt.title('Averaging')
plt.xticks([]),plt.yticks([])
plt.subplot(233),plt.imshow(blur),plt.title('Blurred')
plt.xticks([]),plt.yticks([])
plt.subplot(234),plt.imshow(gauss),plt.title('Gauss')
plt.xticks([]),plt.yticks([])
plt.subplot(236),plt.imshow(bilater),plt.title('Bilater')
plt.xticks([]),plt.yticks([])
plt.subplot(235),plt.imshow(median),plt.title('Median')
plt.xticks([]),plt.yticks([])
plt.show()


结果图:


图像处理22:图像模糊(滤波器)_第3张图片


你可能感兴趣的:(OpenCV)