平滑滤波用于模糊处理和降低噪声,模糊处理常用于预处理任务中,如在目标提取之前去除图像中的一些琐碎细节,以及桥接直线或曲线的缝隙,通过线性或非线性平滑滤波也可降低噪声。
目录
1. 线性滤波
1.1 均值滤波
1.2 高斯滤波
2 非线性滤波
2.1 中值滤波
平均值或加权平均值,模板如图所示:
常见的平滑处理应用就是降低噪声。它会去除与滤波器模板尺寸相比较小的像素区域。然而,均值滤波处理会导致边缘出现模糊,而这种模糊是不希望出现的(边缘是由图像灰度尖锐变化带来的特性,携带了大量信息)。
空间均值处理的一个重要应用是为了对感兴趣的物体得到一个粗略的描述,模糊一幅图像。这样,那些较小物体的灰度与背景融合在一起,较大物体变得像“斑点”而易于检测。模板的大小由那些即将融入背景中的物体尺寸来决定。
均值滤波代码:
"""
均值滤波
"""
import numpy as np
import cv2
# 定义函数,生成椒盐噪声图像
def salt_pepperNoise(src):
dst = src.copy()
num = 1000 # 1000个噪声点
ndim = np.ndim(src)
row, col = np.shape(src)[0:2]
for i in range(num):
x = np.random.randint(0, row) # 随机生成噪声点位置
y = np.random.randint(0, col)
indicator = np.random.randint(0, 2) # 生成随机数0和1,决定是椒噪声还是盐噪声
# 灰度图像
if ndim == 2:
if indicator == 0:
dst[x, y] = 0
else:
dst[x, y] = 255
# 彩色图像
elif ndim == 3:
if indicator == 0:
dst[x, y, :] = 0
else:
dst[x, y, :] = 255
return dst
# 定义函数,实现均值滤波
def meanFilter(src, wsize): # src为输入图像,wsize为窗口大小
border = np.uint8(wsize/2.0) # 计算扩充边缘
addBorder = cv2.copyMakeBorder(src, border, border, border, border, cv2.BORDER_REFLECT_101) # 扩充后
dst = src.copy()
filterWin = 1.0/(wsize**2) * np.ones((wsize, wsize), dtype=np.float32) # 定义窗口
row, col = np.shape(addBorder)
# 滑动,开始滤波
for i in range(border, row-border):
for j in range(border, col-border):
temp = addBorder[i-border:i+border+1, j-border:j+border+1]
newValue = np.sum(temp * filterWin) # 均值滤波
dst[i-border, j-border] = newValue
dst = np.uint8(dst + 0.5)
return dst
img = cv2.imread('F:\program_study\Python\data\lena.tif', cv2.IMREAD_GRAYSCALE)
# 生成椒盐图
saltPimg = salt_pepperNoise(img)
cv2.imshow('saltPepper', saltPimg)
# 均值滤波
MeanFimg = meanFilter(saltPimg, 3)
cv2.imshow('MeanFilter', MeanFimg)
cv2.waitKey(0)
cv2.destroyAllWindows()
高斯滤波器可看作是一种带权的平均滤波器,它的模板根据高斯函数计算得到。高斯函数是正态分布的密度函数。正态分布是一种钟形曲线,越接近中心,取值越大,越远离中心,取值越小。高斯函数的图形:
σ控制钟形的“紧度”
高斯分布
一维:
二维:
x,y的取值
高斯滤波模板
常见的模板有
高斯滤波的性质
高斯函数具有五个重要的性质,这些性质使得它在早期图像处理中特别有用。这些性质表明,高斯滤波无论在空间域还是在频率域都是十分有效的低通滤波器。
1)二维高斯函数具有旋转对称性,即滤波器在各个方向上的平滑程度是相同的。一般来说,一幅图像的边缘方向事先是不知道的,因此滤波前无法确定一个方向上比另一方向上需要更多的平滑。旋转对称性意味着高斯平滑滤波器在后续边缘检测中不会偏向任一方向。
2)高斯函数是单值函数,这表明高斯滤波用像素邻域的加权均值来代替该点的像素值,而每一邻域像素点权值是随该点与中心点的距离单调增减的。这一性质是很重要的,因为边缘是一种图像局部特征,如果平滑运算对离算子中心很远的像素点仍然有很大作用,则平滑运算会使边缘失真。
3)高斯函数的傅立叶变换频谱是单瓣的,这一性质是高斯函数傅立叶变换等于高斯函数本身这一事实的直接推论。图像常被不希望的高频信号所污染(噪声和细纹理)。而所希望的图像特征(如边缘),既含有低频分量,又含有高频分量。高斯函数付立叶变换的单瓣意味着平滑图像不会被不需要的高频信号所污染,同时保留了大部分所需信号。
4)高斯滤波器宽度(决定着平滑程度)是由参数σ表征的,而且σ和平滑程度的关系是非常简单的。σ越大,高斯滤波器的频带就越宽,平滑程度就越好。通过调节平滑程度参数σ,可在图像特征过分模糊(过平滑)与平滑图像中由于噪声和细纹理所引起的过多的不希望突变量(欠平滑)之间取得折中。
5)由于高斯函数的可分离性,较大尺寸的高斯滤波器可以得以有效地实现。二维高斯函数卷积可以分两步来进行,首先将图像与一维高斯函数进行卷积,然后将卷积结果与方向垂直的相同一维高斯函数卷积。因此,二维高斯滤波的计算量随滤波模板宽度成线性增长而不是成平方增长。
这种滤波器以统计排序的值代替中心像素的值。它的主要功能是使拥有不同灰度的点看起来更接近于它的相邻点,具有非常优秀的去噪能力,而且比相同尺寸的线性平滑滤波的模糊程度明显要低。
中值滤波处理椒盐噪声非常有效。
另外还有最大值和最小值滤波器。
中值滤波代码:
"""
非线性滤波,包括中值滤波,
最大值滤波,最小值滤波
"""
import numpy as np
import cv2
# 定义函数,生成椒盐噪声图像
def salt_pepperNoise(src):
dst = src.copy()
num = 1000 # 1000个噪声点
ndim = np.ndim(src)
row, col = np.shape(src)[0:2]
for i in range(num):
x = np.random.randint(0, row) # 随机生成噪声点位置
y = np.random.randint(0, col)
indicator = np.random.randint(0, 2) # 生成随机数0和1,决定是椒噪声还是盐噪声
# 灰度图像
if ndim == 2:
if indicator == 0:
dst[x, y] = 0
else:
dst[x, y] = 255
# 彩色图像
elif ndim == 3:
if indicator == 0:
dst[x, y, :] = 0
else:
dst[x, y, :] = 255
return dst
# 定义函数,实现中值滤波,最大值滤波,最小值滤波
def nonlinearFilter(src, wsize):
border = np.uint8(wsize / 2.0)
addBorder = cv2.copyMakeBorder(src, border, border, border, border, cv2.BORDER_REFLECT_101)
dst = src.copy()
row, col = np.shape(addBorder)
# 开始滑动
for i in range(border, row - border):
for j in range(border, col - border):
temp = addBorder[i - border:i + border + 1, j - border:j + border + 1]
newValue = np.median(temp) # 中值滤波
# newValue = np.max(temp) # 最大值滤波
# newValue = np.min(temp) # 最小值滤波
dst[i - border, j - border] = newValue
return dst
img = cv2.imread('F:\program_study\Python\data\lena.tif', cv2.IMREAD_GRAYSCALE)
# 生成椒盐图
saltPimg = salt_pepperNoise(img)
cv2.imshow('saltPepper', saltPimg)
# 中值,最大值,最小值滤波
Fimg = nonlinearFilter(saltPimg, 3)
cv2.imshow('nonlinearFilter', Fimg)
cv2.waitKey(0)
cv2.destroyAllWindows()
去除椒盐噪声效果:
中值滤波是用窗口内像元的中值来代替中心像元的亮度值。
均值滤波和中值滤波非常基础,均值滤波相当于低通滤波,有将图像模糊化的趋势,对椒盐噪声基本无能为力。中值滤波的优点是可以很好的过滤掉椒盐噪声,缺点是易造成图像的不连续性。
最大值滤波是用窗口内最大值来代替中心像素亮度值,可以发现图像中的亮点(放大“盐”噪声,消除“椒”噪声)。
最小值滤波是用窗口内最小值来代替中心像素亮度值,可以发现图像中的暗点(放大“椒”噪声,消除“盐”噪声)。