python-opencv的图像滤波

在这里先贴部分卷积图像卷积与滤波的一些知识点



程序部分借助opencv实现的一些方法:
目标:
1、学习使用不同的低通滤波器对图像进行 模糊
2、使用自定义的滤波器对图像进行卷积(2D 卷积)
使用 低通滤波器可以达到图像模糊 的目的。这对与去除噪音很有帮助。其实就是去除图像中的高频成分(比如:噪音,边界)。所以边界也会被模糊一 点。(当然,也有一些模糊技术不会模糊掉边界)。OpenCV 提供了5种模糊技术。
# -*- coding:utf-8 -*-
###这段程序目的是学习图像的模糊的操作
import cv2
import numpy as np
from matplotlib import pyplot as plt
#构建一个卷积核5*5
dir1='nw00011.JPG'
img1=cv2.imread(dir1)
###第一种方法2D滤波
kernel=np.ones((5,5),np.float32)/25
#dst=cv2.filter2D(img1,-1,kernel)
###第二种方法,归一化卷积框
#dst=cv2.blur(img1,(5,5))
###第三种方法, 高斯模糊
#dst=cv2.GaussianBlur(img1,(5,5),0)
###第四种方法,中值模糊
#dst=cv2.medianBlur(img1,5)
###第5种方法,双边滤波
dst = cv2.bilateralFilter(img1,9,75,75)



这5种方法各自的特点简单介绍下:
1、2D 卷积就是自己自定义构造一个核
2、 平均是由一个 归一化卷积框完成的。他只是用卷积框覆盖区域所有像素的平均值来代替中心元素。下面是一个 3x3 的归一化卷积框:
3、高斯模糊 现在把卷积核换成高斯核。现在里面的值是 符合高斯分布的,方框中心的值最大,其余方框根据距离中心元素的距离递减,构成一个高斯小山包。原来的求平均数现在变成求加权平均数,全就是方框里的值)。实现的函数是 cv2.GaussianBlur()。 我们需要指定高斯核的宽和高(必须是奇数)。以及高斯函数沿 X,Y 方向的标准差。如果我们只指定了 X 方向的的标准差,Y 方向也会取相同值。如果两个标 准差都是 0,那么函数会根据核函数的大小自己计算。高斯滤波可以有效的从 图像中去除高斯噪音。 如果你愿意的话,你也可以使用函数 cv2.getGaussianKernel() 自己 构建一个高斯核。
4、中值模糊 顾名思义就是用与卷积框对应像素的中值来替代中心像素的值。 这个滤波器经常用来去除椒盐噪声。前面的滤波器都是用计算得到的一个新值来取代中心像素的值,而中值滤波是用中心像素周围(也可以使他本身)的值来取代他。 他能有效的去除噪声。卷积核的大小也应该是一个奇数。 在这个例子中,我们给原始图像加上 50% 的噪声然后再使用中值模糊。
5、 能在保持边界清晰的情况下有效的去除噪音。但是这种操作与其他滤波器相比会比较慢。我们已经知道高斯滤波器是求中心点邻近区域像素的高斯加权平均值。这种高斯滤波器只考虑像素之间的空 间关系,而不会考虑像素值之间的关系(像素的相似度)。所以这种方法不会考虑一个像素是否位于边界。因此边界也会别模糊掉,而这正不是我们想要。 双边滤波在同时使用空间高斯权重和灰度值相似性高斯权重。空间高斯函 数确保只有邻近区域的像素对中心点有影响,灰度值相似性高斯函数确保只有与中心像素灰度值相近的才会被用来做模糊运算。所以这种方法会确保边界不会被模糊掉,因为边界处的灰度值变化比较大。

博客地址: http://blog.csdn.net/zouxy09/article/details/49080029

你可能感兴趣的:(opencv,python学习)