MATLAB详解高斯噪声、椒盐噪声,简单实现图像的均值滤波、中值滤波并分析其有效性

一、高斯噪声与椒盐噪声的基本特点

噪声类型基本特点滤波处理
高斯噪声噪声的概率密度函数服从高斯分布(即正态分布),即某个强度的噪声点个数最多,离这个强度越远噪声点个数越少。高斯噪声是一种加性噪声,即噪声直接加到原图像上,因此可以用线性滤波器滤除。使用均值滤波等线性滤波方法效果更佳
椒盐噪声由图像传感器、传输信道、解码处理等产生的黑白相间的亮暗点噪声,往往由图像切割引起。椒盐噪声是指两种噪声,盐噪声(高灰度噪声)、胡椒噪声(低灰度噪声)。同时出现时,在图像上呈现为黑白杂点使用中值滤波方法效果更佳

二、使用Matlab的imnoise()函数为图像添加噪声

在Matlab中使用imnoise函数可为图像加入不同类型的噪声,常用调用方法如下:J=imnoise(I,type,parameters)
其中,I指原图像,type指噪声类型,parameters指不同类型噪声的参数,J为添加噪声后的图像。

type的参数值代表的噪声
gaussian高斯噪声
salt & pepper (注意中间有空格)椒盐噪声
speckle乘法噪声
poission泊松噪声

三、使用imfilter()进行均值滤波处理

在Matlab中使用imfilter函数可对多维图像进行线性滤波处理,常用调用方法如下:
B = imfilter(A,H)
H=fspecial(‘average’,para)

其中,A指原图像,B为输出图像,H指滤波算子,‘average’指算子类型为均值,para是指定相应的参数,默认值为3。para的数值越大,均值滤波效果越显著,不过图像也会变得越模糊,测试后挑选一个合适的值即可。
均值滤波处理灰度图
均值滤波处理灰度图
均值滤波处理彩色图像
均值滤波处理彩色图像

四、使用medfilt3()进行中值滤波处理

在Matlab中使用medfilt3函数可对多维图像进行中值滤波处理,常用调用方法如下:
B = medfilt3(A)
其中,A指原图像,B为输出图像。
中值滤波处理灰度图
中值滤波处理灰度图
中值滤波处理彩色图像
中值滤波处理彩色图像

五、两种滤波处理高斯噪声、椒盐噪声效果对比

1.使用均值滤波、中值滤波处理椒盐噪声
使用均值滤波、中值滤波处理椒盐噪声
使用均值滤波、中值滤波处理椒盐噪声
2.使用均值滤波、中值滤波处理高斯噪声
使用均值滤波、中值滤波处理高斯噪声**
使用均值滤波、中值滤波处理高斯噪声

  1. 根据以上图片对比可知,用均值滤波处理高斯噪声,中值滤波处理椒盐噪声效果更显著,不过在用中值滤波处理彩色图像时可能会出现图像颜色变浅的现象。当然啦,这或许和具体的滤波算法有关。
  2. 至于为什么用中值滤波处理椒盐噪声效果更好,可以这么理解,椒盐噪声只影响了图片的部分像素点而不是全部像素点,使用中值滤波方法正好排除了被噪声影响的像素点(被椒盐噪声影响的像素点表现为灰度值255的盐噪点和灰度值0的胡椒噪点),而均值滤波方法采用了包含噪声像素点在内的所有像素点的平均值,效果自然不如中值滤波。
  3. 高斯噪声影响了图片的全部像素点,如果只用像素中的中间值来替代所有像素点,会损失掉其他同样受噪声影响的像素点信息,效果不如采用所有像素点平均值的均值滤波。

六、参考代码

imread()内为所需处理的图片路径,具体代码如下:

A=imread('D:\matlab\Fig1119(a).tif');
figure('name','对高斯噪声进行滤波处理')
subplot(2,2,1)
imshow(A)
title('原图像')
subplot(2,2,2)
B=imnoise(A,'gaussian',0,0.03);
imshow(B)
title('高斯噪声图像')
subplot(2,2,3)
C=imfilter(B,fspecial('average',3));
imshow(C,[])
title('均值滤波处理')
subplot(2,2,4)
D=medfilt3(B);
imshow(D,[])
title('中值滤波处理')
  • 71
    点赞
  • 444
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MATLAB中使用图像处理工具包中的函数可以实现添加高斯噪声椒盐噪声,并进行均值滤波中值滤波处理。 首先,使用imnoise函数来添加高斯噪声椒盐噪声。该函数需要输入原始图像噪声类型参数。例如,要添加高斯噪声,可以使用以下代码: ```matlab img = imread('原始图像.jpg'); % 读取原始图像 noisy_img = imnoise(img, 'gaussian', 0, 0.02); % 添加高斯噪声,参数0和0.02分别表示噪声均值和方差 ``` 同样地,要添加椒盐噪声,可以使用以下代码: ```matlab noisy_img = imnoise(img, 'salt & pepper', 0.05); % 添加椒盐噪声,参数0.05表示噪声比例(图像总像素中噪声像素所占的比例) ``` 然后,可以使用均值滤波中值滤波函数对加图像进行处理。均值滤波使用了一个滤波模板,通过计算邻域像素的平均值来减小噪声中值滤波使用了一个滤波模板,通过计算邻域像素的中值来减小噪声。以下是使用MATLAB中的函数进行均值滤波中值滤波的代码示例: ```matlab mean_filtered_img = imfilter(noisy_img, fspecial('average', [3 3])); % 均值滤波,使用3x3大小的平均滤波 median_filtered_img = medfilt2(noisy_img, [3 3]); % 中值滤波,使用3x3大小的滤波模板 ``` 上述代码中,imfilter函数使用了fspecial函数来创建一个平均滤波。medfilt2函数直接对图像进行中值滤波,指定了滤波模板的大小为3x3。 最后,可以使用imshow函数显示原始图像添加噪声后的图像以及经过均值滤波中值滤波处理后的图像,观察滤波效果。例如: ```matlab subplot(2, 2, 1); imshow(img); title('原始图像'); subplot(2, 2, 2); imshow(noisy_img); title('添加噪声后的图像'); subplot(2, 2, 3); imshow(mean_filtered_img); title('均值滤波处理后的图像'); subplot(2, 2, 4); imshow(median_filtered_img); title('中值滤波处理后的图像'); ``` 上述代码将原始图像添加噪声后的图像以及经过均值滤波中值滤波处理后的图像显示在一个2x2的图像矩阵中。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值