• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

matlab图像处理-中值滤波原理

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

中值滤波原理

  中值滤波本质上是一种统计排序滤波器。对于原图像中某点(i,j),中值滤波以该点为中心的邻域内的所有像素的统计排序中值作为(i,j)点的响应。

  中值不同于均值,是指排序队列中位于中间位置的元素的值,例如,采用3x3中值滤波器,某点(i,j)的8个邻域的一系列像素值为12,18,25,11、118,17、35,29,23,统计排序结果为11、12,17,18,23,25,29,35,118。排在中间位置(第5位)的23即作为(i,j)点中值滤波的响应g(i,j)。显然,中值滤波并非线性滤波器。

原理图解:选定图像中的某个像素,采用3*3的滤波窗口进行滤波,将周围的8个像素连同选定的像素进行排序,然后选择排好序的中心像素值代替原来的像素值。即将图中的23代替原来的118。

图中可以知道,当像素点太大或者太小时都不同意被选中,所以中值滤波对像素值比较大或者比较小的噪声滤除的效果比较好,如:椒盐噪声,对比较均匀的噪声滤除的效果一般,如:高斯噪声。

中值滤波的优点:

  中值滤波对于某些类型的随机噪声具有非常理想的降噪能力,对于线性平滑滤波而言,在处理的像素邻域之内包含噪声点时,噪声的存在总会或多或少地影响该点的像素值的计算,(对于高斯平滑影响程度同噪声点到中心点的距离成正比),但在中值滤波中噪声点则常常是直接被忽略掉的;而且同线性平滑滤波器相比,中值滤波在降噪同时引起的模糊效应较低。

使用MATLAB展示中值滤波效果:

在matlab中中值滤波的函数是medfilt2函数,示例1,中值滤波对椒盐噪声和高斯噪声的滤波效果展示。

1、采用的原图是:

2、滤除椒盐噪声和高斯噪声的对比代码如下:

%% 滤波效果展示
clear; clc; close all;
rawimg = imread(\'..\picture\1.jpg\');
[~,~,index] = size(rawimg);
if index ~= 1
   rawimg = rgb2gray(rawimg);  % 转化为灰度图 
end
% 显示原图
figure;imshow(rawimg);title(\'原图\');

% 添加噪声
salt_img=imnoise(rawimg,\'salt & pepper\',0.04);     % 叠加密度为0.04的椒盐噪声
guas_img = imnoise(rawimg,\'gaussian\',0.04);
figure;subplot(1,2,1);imshow(salt_img);title(\'添加椒盐噪声\');
subplot(1,2,2);imshow(guas_img);title(\'添加高斯噪声\');

% 进行滤波
salt_fit = medfilt2(salt_img,[3 3]);   % 采用二维中值滤波函数对图像滤波,滤波窗口是3*3
guas_fit = medfilt2(guas_img,[3,3]);  % 滤除高斯噪声

% 滤波效果:
figure;subplot(1,2,1);imshow(salt_fit);title(\'椒盐噪声滤波效果\');
subplot(1,2,2);imshow(guas_fit);title(\'高斯噪声滤波效果\');

添加噪声效果示例:

使用中值滤波滤除的效果示例:

分析:可以很明显的看到,中值滤波对椒盐噪声的滤除效果比高斯噪声要好,边缘部分的细节有部分的保留。

3、选择不同的窗口对椒盐噪声的滤除效果对比示例代码:

%% 滤波窗口选择展示
clear; clc; close all;
rawimg = imread(\'..\picture\1.jpg\');
[~,~,index] = size(rawimg);
if index ~= 1
   rawimg = rgb2gray(rawimg);  % 转化为灰度图 
end

% 添加噪声
salt_img=imnoise(rawimg,\'salt & pepper\',0.04);     % 叠加密度为0.04的椒盐噪声
figure;subplot(1,2,1);imshow(rawimg);title(\'原图\');
subplot(1,2,2);imshow(salt_img);title(\'添加椒盐噪声\');

% 进行滤波
min_fit = medfilt2(salt_img,[3 3]);   % 采用二维中值滤波函数对图像滤波,滤波窗口是3*3
max_fit = medfilt2(salt_img,[9,9]);  % 滤除高斯噪声

% 滤波效果:
figure;subplot(1,2,1);imshow(min_fit);title(\'3*3滤波窗口效果\');
subplot(1,2,2);imshow(max_fit);title(\'9*9滤波窗口效果\');

添加椒盐噪声的效果示例:

分别选择[3,3]滤波窗口和[9,9]滤波窗口对噪声图像进行滤波效果对比示例:

分析:可以很明显看到,当中值滤波的窗口选择越大的时候滤波的效果比较明显,但是窗口选择越大则对原图的边缘,细节部分滤除的部分就会越多,这个特性可以根据自己的需要进行调节。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
利用远程线程注入DLLDelphi版发布时间:2022-07-18
下一篇:
Delphi数组及长度发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap