发布时间:2021-09-23 23:31:15编辑:run阅读(7856)
线性(空间)滤波具有对(在邻域内)像素值加权求和的功能,它是一种线性运算,可以用来对图像进行模糊或去噪。模糊用于预处理过程,如删除不重要的(不相关的)细节。常用的线性滤波器有盒式滤波器和高斯滤波器。滤波器是通过一个小(如3X3)核得以实现的,通过在输入图像上滑动掩模重新计算像素值,并将过滤函数应用到输入图像的每一个可能的像素(输入图像中心像素值所对应的掩模所具有的权重被像素值的加权和所替代)。盒式滤波器(也称为均值滤波器)用其邻域的平均值替换每个像素,并(通过去除清晰的特征,例如模糊边缘而空间平滑消除噪声)实现平滑效果。
基于ImageFilter平滑,PIL的ImageFilter模块的滤波功能如何用于对噪声图像进行去噪。通过改变输入图像的噪声水平来观察其对模糊滤波器的影响。
from PIL import Image, ImageEnhance, ImageFilter
import matplotlib.pylab as pylab
import numpy as np
pylab.rcParams['font.sans-serif'] = ['KaiTi']
pylab.rcParams['axes.unicode_minus'] = False
def plot_image(image, title=''):
pylab.title(title, size=20)
pylab.imshow(image)
pylab.axis('off')
i = 1
pylab.figure(figsize=(20, 15))
for prop_noise in np.linspace(0.05, 0.3, 3):
im = Image.open(r'D:\image_processing\image4\f.jpg')
n = int(im.width * im.height * prop_noise)
x, y = np.random.randint(0, im.width, n), np.random.randint(0, im.height, n)
for (x, y) in zip(x, y):
im.putpixel((x, y), ((0, 0, 0) if np.random.rand() < 0.5 else (255, 255, 255)))
im.save(r'D:\image_processing\image4\_' + str(prop_noise) + '.jpg')
pylab.subplot(6, 2, i)
plot_image(im, '参杂了' + str(int(100*prop_noise)) + '%噪声的原始图像')
i += 1
im1 = im.filter(ImageFilter.BLUR)
pylab.subplot(6, 2, i)
plot_image(im1, '模糊图像')
i += 1
pylab.show()
可以看到,随着输入图像噪声的增大,平滑后的图像质量变差。
51257
50695
41293
38114
32574
29479
28340
23200
23167
21496
1571°
2287°
1897°
1837°
2149°
1880°
2569°
4308°
4158°
2965°