数字图像去噪典型算法及matlab实现
利用Matlab进行图像去噪和图像增强
利用Matlab进行图像去噪和图像增强随着数字图像处理技术的不断发展和成熟,图像去噪和图像增强在各个领域都有广泛的应用。
而在数字图像处理的工具中,Matlab凭借其强大的功能和易于使用的特点,成为了许多研究者和工程师首选的软件之一。
本文将介绍如何利用Matlab进行图像去噪和图像增强的方法和技巧。
一、图像去噪图像去噪是指通过一系列算法和技术,将图像中的噪声信号去除或减弱,提高图像的质量和清晰度。
Matlab提供了多种去噪方法,其中最常用的方法之一是利用小波变换进行去噪。
1. 小波变换去噪小波变换是一种多尺度分析方法,能够对信号进行时频分析,通过将信号分解到不同的尺度上,实现对图像的去噪。
在Matlab中,可以使用"dwt"函数进行小波变换,将图像分解为低频和高频子带,然后通过对高频子带进行阈值处理,将噪声信号滤除。
最后通过逆小波变换将去噪后的图像重构出来。
这种方法能够有效抑制高频噪声,保留图像的细节信息。
2. 均值滤波去噪均值滤波是一种基于平均值的线性滤波方法,通过计算像素周围邻域内像素的平均值,替代原始像素的值来去除噪声。
在Matlab中,可以使用"imfilter"函数进行均值滤波,通过设置适当的滤波模板大小和滤波器系数,实现对图像的去噪。
二、图像增强图像增强是指通过一系列算法和技术,改善图像的质量、增强图像的细节和对比度,使图像更容易被观察和理解。
Matlab提供了多种图像增强方法,以下将介绍其中的两种常用方法。
1. 直方图均衡化直方图均衡化是一种通过对图像像素值的分布进行调整,增强图像对比度的方法。
在Matlab中,可以使用"histeq"函数进行直方图均衡化处理。
该函数能够将图像的像素值分布拉伸到整个灰度级范围内,提高图像的动态范围和对比度。
2. 锐化增强锐化增强是一种通过增强图像边缘和细节来改善图像质量的方法。
在Matlab中,可以使用"imsharpen"函数进行图像的锐化增强处理。
Matlab中的图像去噪方法探究
Matlab中的图像去噪方法探究引言:图像去噪是数字图像处理中一个重要的领域,通常被用于清除图像中的噪声,提高图像的质量。
Matlab作为最常用的科学计算软件之一,提供了众多图像去噪方法的实现。
本文将探究在Matlab环境下常用的图像去噪方法,包括均值滤波、中值滤波、小波去噪和Total Variation(TV)去噪等。
1. 均值滤波均值滤波是一种简单且常用的图像去噪方法。
其基本思想是通过计算像素周围邻域像素的平均值来减少噪声的影响。
在Matlab中,可以使用`imfilter`函数来实现均值滤波。
该函数通过对图像进行卷积操作,可以选择不同大小的滤波器来达到不同程度的去噪效果。
然而,均值滤波的缺点是会导致图像的细节模糊化,并且无法处理噪声的非高斯分布情况。
2. 中值滤波中值滤波是一种基于排序统计的图像去噪方法。
它的原理是通过对像素周围邻域像素进行排序,然后选择中间值作为输出像素的值。
与均值滤波相比,中值滤波能够更好地保留图像的细节信息。
Matlab中的`medfilt2`函数可以用于实现中值滤波。
需要注意的是,中值滤波对于椒盐噪声和脉冲噪声等非高斯分布噪声具有较好的去除效果,但对于高斯噪声等其他类型噪声的去噪效果相对较差。
3. 小波去噪小波去噪是一种基于小波变换的图像去噪方法,它通过将图像信号分解为不同频率的小波系数,然后根据小波系数的能量分布情况进行去噪处理。
在Matlab中,可以使用Wavelet Toolbox提供的函数来实现小波去噪。
其中,`wdenoise`函数可以根据设定的阈值对小波系数进行修正,从而实现图像去噪的效果。
由于小波去噪考虑了图像的频域特性,因此在去除噪声的同时能够尽可能地保留图像的细节信息。
4. Total Variation(TV)去噪Total Variation(TV)去噪是一种基于偏微分方程的图像去噪方法,它通过最小化图像的总变差来减少图像中的噪声。
在Matlab中,可以使用Image Processing Toolbox中的`imdenoise`函数来实现TV去噪。
利用中值滤波去除图像噪声的研究及MATLAB实现
文章编号:1001-3717(2006)01-0063-03利用中值滤波去除图像噪声的研究及MA TL AB实现3江景涛,姜学东,李福荣(莱阳农学院机电工程学院,山东青岛266109)摘要:根据扫描工程图像的特点,研究了图像中噪声产生的机理和消除方法;提出了利用中值滤波法消除图像噪声的实用方法。
使用软件工具MA TL AB快速地实现了图像的中值滤波。
结果表明,利用中值滤波法消除图像中的随机噪声是图像噪声处理的最佳方法。
关键词:图像处理;噪声;中值滤波;Matlab中图分类号:TP317.4文献标识码:AThe Study of R emoving Image Noise with Medium V alue Filterand Matlab R ealizationJ IAN G Jing2tao,J IAN G Xue2dong,L I Fu2rong(College of Mechanical and Electronic Engineering,LAC,Qingdao266109,China)Abstract:In t his paper,t he mechanism of p roducing image noise and met hod of removing it were st udied, according to t he p roperty of engineering drawing and image.A practical met hod of removing image noise wit h medium value filter was p ut forward.The medium value filter of image was realized wit h MA TL AB software system.As t he result s show t hat medium value filter is an optimum met hod in removing image noise.K ey w ords:image p rocessing;noise;medium value filter;Matlab 图纸以简洁的形式表达复杂的信息,它具有自然、直观、含义清晰等特点,被大量采用,特别是随着计算机辅助设计系统的出现,给设计和维护工程图纸提供了有效的手段。
数字图像处理中图像去噪的算法实现方法
数字图像处理中图像去噪的算法实现方法数字图像处理是指对数字化的图像进行处理、分析和修改的过程。
图像去噪是其中一项重要的任务,它的目标是尽量降低图像中的噪声,并使图像保持尽可能多的细节信息。
本文将介绍数字图像处理中常用的图像去噪算法及其实现方法。
一、图像噪声的分类在了解图像去噪算法之前,我们需要了解图像中可能存在的噪声类型。
常见的图像噪声主要有以下几种:1. 高斯噪声:是一种符合高斯分布的噪声,其特点是随机性较强,像素值呈现连续分布。
2. 盐噪声和胡椒噪声:分别指图像中像素值变为最大值和最小值的噪声。
这种噪声会导致图像呈现颗粒状或斑点状的亮点和暗点。
3. 椒盐噪声:是指图像中同时存在盐噪声和胡椒噪声。
4. 均匀噪声:是指图像中像素值随机增减的噪声,使图像呈现均匀的亮度变化。
二、常用的图像去噪算法1. 均值滤波算法均值滤波算法是一种简单直观的图像去噪方法。
它的基本原理是用邻域像素的平均值来代替当前像素的值。
具体实现方法如下:(1)选择一个固定大小的滑动窗口,如3×3或5×5。
(2)将窗口中的像素值求平均,并将平均值赋给当前像素。
均值滤波算法的优点是简单易懂、计算量小,但它对于去除噪声的效果有限,特别是对于像素值发生较大变化的情况效果较差。
2. 中值滤波算法中值滤波算法是一种基于排序统计的图像去噪方法。
它的基本原理是用邻域像素的中值来代替当前像素的值。
具体实现方法如下:(1)选择一个固定大小的滑动窗口,如3×3或5×5。
(2)对窗口中的像素值进行排序,并取中间值作为当前像素的值。
中值滤波算法的优点是对于不同类型的噪声都有较好的去除效果,但它在去除噪声的同时也会对图像细节产生一定的模糊。
3. 双边滤波算法双边滤波算法是一种基于像素相似性的图像去噪方法。
它的基本原理是通过考虑像素的空间距离和像素值的相似程度来进行滤波。
具体实现方法如下:(1)选择一个固定大小的滑动窗口,如3×3或5×5。
Matlab中的图像降噪算法与技术
Matlab中的图像降噪算法与技术摘要随着数字图像处理的快速发展,图像降噪成为实际应用中一个重要的问题。
在本文中,我们将探讨Matlab中的图像降噪算法与技术。
首先,我们将介绍图像降噪的基本原理和方法。
然后,我们将深入研究Matlab中常用的图像降噪算法,包括均值滤波、中值滤波、高斯滤波等。
最后,我们将讨论图像降噪的一些进一步扩展和应用。
一、图像降噪的基本原理和方法图像降噪是指通过一系列算法和技术,减少或去除数字图像中的噪声信号,以使图像更清晰、更易于识别和分析。
图像噪声主要来自于图片采集过程中的环境噪声、传感器噪声以及信号传输中的干扰等。
图像降噪的基本原理是通过对图像进行滤波处理,使噪声信号受到抑制,同时尽量保留图像的有用信息。
常用的图像降噪方法包括空域滤波和频域滤波。
空域滤波是指对图像的像素直接进行操作的滤波方法,例如均值滤波、中值滤波等。
频域滤波是指将图像转换到频域进行处理的滤波方法,例如傅里叶变换和小波变换。
二、Matlab中常用的图像降噪算法1. 均值滤波均值滤波是一种最简单、最常用的图像降噪方法。
它通过计算像素周围邻域内像素的平均值,将当前像素的值替换为该平均值。
在Matlab中,我们可以使用imfilter函数来实现均值滤波。
具体步骤如下:(1)读取图像,并将其转换为灰度图像。
(2)选择适当的滤波器大小和模板类型。
(3)使用imfilter函数进行滤波处理。
(4)显示并保存结果图像。
2. 中值滤波中值滤波是一种非线性图像滤波方法,它通过将像素周围邻域内像素的灰度值进行排序,然后选择中间值作为当前像素的灰度值。
这种方法对于椒盐噪声等脉冲性噪声有很好的抑制效果。
在Matlab中,我们可以使用medfilt2函数来实现中值滤波。
3. 高斯滤波高斯滤波是一种线性平滑滤波方法,它通过将像素周围邻域内的像素值与高斯函数进行加权平均来实现图像降噪。
在Matlab中,我们可以使用fspecial和imfilter函数来实现高斯滤波。
matlab去噪声方法
matlab去噪声方法MATLAB中去噪声的方法有很多,以下列举了一些常用的方法:1. 均值滤波:均值滤波是一种简单且有效的去噪声方法,它通过计算邻域内像素的平均值来减小噪声。
具体操作是创建一个与输入图像大小相同的零矩阵,然后遍历图像的每个像素,将邻域内的像素值求和,最后除以邻域内像素的数量,得到滤波后的像素值。
2. 中值滤波:中值滤波主要用于去除图像中的脉冲噪声和椒盐噪声。
该方法的核心思想是将图像中相邻像素的灰度值进行排序,然后取中间值作为滤波后的像素值。
3. 高斯滤波:高斯滤波是一种广泛应用于图像去噪的方法,它通过在图像上滑动一个高斯核函数来降低噪声。
高斯核函数的宽度决定了滤波的效果,宽度越大,去噪效果越明显,但同时也会导致图像变得模糊。
4. 双边滤波:双边滤波是一种基于邻域的滤波方法,它同时考虑了像素的空间距离和灰度差异。
通过在图像上滑动一个双边核函数,可以有效地去除噪声并保留图像的细节。
5. 基于小波变换的方法:小波变换可以将图像分解为不同尺度、方向和频率的子带,通过对子带的处理,可以有效地去除图像中的噪声。
常用的有小波分解、小波合成和小波去噪等方法。
6. 基于深度学习的方法:深度学习方法,如卷积神经网络(CNN)和循环神经网络(RNN),在图像去噪领域也取得了很好的效果。
通过训练神经网络,可以学习到图像的复杂特征,从而在去噪的同时保留图像的细节。
在MATLAB中实现这些方法,可以利用内置的图像处理函数或自行编写代码。
例如,使用imfilter函数实现均值滤波,使用im2double函数将图像转换为双精度值等。
同时,可以借助图像处理工具箱中的各种滤波器和图像读取、显示函数,如sobel、roberts、prewitt算子等,来实现特定的去噪效果。
基于Matlab的图像去噪算法仿真综述
基于Matlab的图像去噪算法仿真在信息化的社会里,图像在信息传播中所起的作用越来越大。
所以,消除在图像采集和传输过程中而产生的噪声,保证图像受污染度最小,成了数字图像处理领域里的重要部分。
本文主要研究分析邻域平均法、中值滤波法、维纳滤波法及模糊小波变换法的图像去噪算法。
首先介绍图像处理应用时的常用函数及其用法;其次详细阐述了四种去噪算法原理及特点;最后运用Matlab软件对一张含噪图片(含高斯噪声或椒盐噪声)进行仿真去噪,通过分析仿真结果得出:一.均值滤波是典型的线性滤波,对高斯噪声抑制是比较好的;二.中值滤波是常用的非线性滤波方法,对椒盐噪声特别有效;三.维纳滤波对高斯噪声有明显的抑制作用;四.对小波系数进行阈值处理可以在小波变换域中去除低幅值的噪声和不期望的信号。
本论文主要是从两方面展开,首先是图像去噪算法:简要说明了图像噪声的概念及分类,详细阐述了邻域平均法、中值滤波法、维纳滤波法及模糊小波变换法的去噪原理及特点。
其次是基于Matlab的图像去噪算法仿真:根据邻域平均法、中值滤波法、维纳滤波法及模糊小波变换法原理分析,运用Matlab仿真软件编写代码,对一张含噪图片(含高斯噪声或椒盐噪声)进行仿真去噪,并对结果分析讨论,比较几种方法的优缺点。
本论文仿真时选取一张彩色图片“2010-03-09-2.bmp”,并在图片中加入两种噪声:高斯噪声和椒盐噪声。
所谓高斯噪声是指它的概率密度函数服从高斯分布的一类噪声。
椒盐噪声是由图像传感器、传输信道、解码处理等产生的黑白相间的亮暗点噪声,属于非平稳噪声。
本章利用Matlab软件对含噪图像的去噪算法进行仿真,将应用邻域平均法、中值滤波法、维纳滤波法和模糊小波变换法对含有高斯噪声和椒盐噪声图像的去噪效果进行比较,从而得到相应结论。
1.1邻域平均法的仿真本节选用邻域平均法对含有高斯噪声和椒盐噪声的图片进行去噪,并用Matlab软件仿真。
(1)给图像加入均值为0,方差为0.02的高斯噪声,选择3×3模板去噪Matlab部分代码:j=imnoise(x,'gaussian',0,0.02);h=ones(3,3);h=h/9;k=conv2(j,h);仿真结果如图4-1所示。
图像去噪处理的研究及MATLAB仿真
图像去噪处理的研究及MATLAB仿真[摘要]图像是一种重要的信息源,通过图像处理可以帮助人们了解信息的内涵。
数字图像噪声去除涉及光学系统、微电子技术、计算机科学、数学分析等领域,是一门综合性很强的边缘科学,如今其理论体系已十分完善,且其实践应用很广泛,在医学、军事、艺术、农业等都有广泛且成熟的应用。
MATLAB是一种高效的工程计算语言,在数值计算、数据处理、图像处理、神经网络、小波分析等方面都有广泛的应用。
MATLAB是一种向量语言,它非常适合于进行图像处理。
本文概述了小波阈值去噪的基本原理。
对常用的几种阈值去噪方法进行了分析比较和仿真实现。
最后结合理论分析和实验结果,讨论了一个完整去噪算法中影响去噪性能的各种因素。
为实际的图像处理中,小波阈值去噪法的选择和改进提供了数据参考和依据。
关键字:小波变换图像去噪阈值MATLABThe Research of Image De-noising Based on Matlab[Abstract] Image is one kind of important information source, may help People through the imagery processing to understand the information the connotation. The digital image de-noise involves domains and so on optical system, microelectronic technology, computer science,mathematical analysis, it’s a very comprehensive interdisciplinary science, now its practice application is very widespread: In the medicine, the military, art, the agriculture and all have very extensive and ripe using so on. MATLAB is one kind of highly effective engineering calculation language,in aspects and so on value computation, data processing, imagery processing, neural network, wavelet analysis all has the widespread application.This article has stated the theory of wavelet threshold denoising ,then done comparing experiments using several good threshold denoising methods.Finally according to the theory analysis and simulation results,the paper discusses several kinds of factors which affect the denoising capability in a complete denoising algorithm.That provides the date reference of threshold denoising methods in actual image process.Keywords: Wavelet transformation; Image denoising; Wavelet threshold; MATLAB目录前言第一章图像与噪声 (1)1.1 噪声图像模型及噪声特性 (1)1.1.1 含噪模型 (1)1.1.2 噪声特性 (1)1.2 图像质量的评价 (2)1.2.1 主观评价 (2)1.2.2 客观评价 (2)第二章图像去噪方法 (4)2.1 传统去噪方法 (4)2.1.1 空域滤波 (4)2.1.2 频域低通滤波法 (5)2.2 小波去噪 (8)2.2.1 小波去噪的发展历程 (8)2.2.2 小波去噪的研究现状 (9)2.2.3 小波去噪方法 (11)第三章小波变换理论基础 (12)3.1 从傅里叶变换到小波变换 (12)3.2 小波理论的基本概念 (13)3.2.1 连续小波变换 (13)3.2.2 离散小波变换 (15)第四章小波阈值去噪及MATLAB仿真 (18)4.1 小波阈值去噪概述 (18)4.1.1 阈值去噪法简述 (18)4.2 基于MATLAB的小波去噪函数简介 (19)4.3 小波去噪对比试验 (20)4.3.1 实验信号的产生 (20)4.3.2 各参数下的去噪效果对比 (22)4.4 利用小波去噪函数去除给定图像中的噪声 (25)总结与展望(本行顶头,下面的红色字去掉) (28)1 全文工作总结 (28)2 工作展望 (28)致谢语 (30)参考文献 (31)附录 (34)前言图像在生成和传输过程中常常因受到各种噪声的干扰和影响而使图像降质,这对后续图像的处理(如分割、压缩和图像理解等)将产生不利影响。
matlab图像去噪算法设计说明书
数字图像去噪典型算法及matlab实现希望得到大家的指点和帮助图像去噪是数字图像处理中的重要环节和步骤。
去噪效果的好坏直接影响到后续的图像处理工作如图像分割、边缘检测等。
图像信号在产生、传输过程中都可能会受到噪声的污染,一般数字图像系统中的常见噪声主要有:高斯噪声(主要由阻性元器件内部产生)、椒盐噪声(主要是图像切割引起的黑图像上的白点噪声或光电转换过程中产生的泊松噪声)等;目前比较经典的图像去噪算法主要有以下三种:均值滤波算法:也称线性滤波,主要思想为邻域平均法,即用几个像素灰度的平均值来代替每个像素的灰度。
有效抑制加性噪声,但容易引起图像模糊,可以对其进行改进,主要避开对景物边缘的平滑处理。
中值滤波:基于排序统计理论的一种能有效抑制噪声的非线性平滑滤波信号处理技术。
中值滤波的特点即是首先确定一个以某个像素为中心点的邻域,一般为方形邻域,也可以为圆形、十字形等等,然后将邻域中各像素的灰度值排序,取其中间值作为中心像素灰度的新值,这里领域被称为窗口,当窗口移动时,利用中值滤波可以对图像进行平滑处理。
其算法简单,时间复杂度低,但其对点、线和尖顶多的图像不宜采用中值滤波。
很容易自适应化。
Wiener维纳滤波:使原始图像和其恢复图像之间的均方误差最小的复原方法,是一种自适应滤波器,根据局部方差来调整滤波器效果。
对于去除高斯噪声效果明显。
实验一:均值滤波对高斯噪声的效果I=imread('C:\Documents and Settings\Administrator\桌面\1.gif');%读取图像J=imnoise(I,'gaussian',0,0.005);%加入均值为0,方差为0.005的高斯噪声subplot(2,3,1);imshow(I);title('原始图像');subplot(2,3,2); imshow(J);title('加入高斯噪声之后的图像');精心整理学习帮手%采用MATLAB中的函数filter2对受噪声干扰的图像进行均值滤波K1=filter2(fspecial('average',3),J)/255; %模板尺寸为3K2=filter2(fspecial('average',5),J)/255;% 模板尺寸为5K3=filter2(fspecial('average',7),J)/255; %模板尺寸为7K4= filter2(fspecial('average',9),J)/255; %模板尺寸为9 subplot(2,3,3);imshow(K1);title('改进后的图像1');subplot(2,3,4); imshow(K2);title('改进后的图像2');subplot(2,3,5);imshow(K3);title('改进后的图像3');subplot(2,3,6);imshow(K4);title('改进后的图像4');精心整理学习帮手PS:filter2用法fspecial函数用于创建预定义的滤波算子,其语法格式为:h = fspecial(type)h = fspecial(type,parameters)参数type制定算子类型,parameters指定相应的参数,具体格式为:type='average',为均值滤波,参数为n,代表模版尺寸,用向量表示,默认值为[3,3]。
基于Matlab的数字图像处理降噪方法
80%
参数调整
根据不同的图像和降噪需求,调 整滤波器大小、阈值等参数。
实验结果展示和分析
01
02
03
04
结果展示
通过对比降噪前后的图像,展 示降噪效果。
• 主观评价
通过观察降噪后的图像,评估 降噪效果。
• 客观评价
• 讨论
使用PSNR、SSIM等客观评价 指标,量化评估降噪效果。
分析不同降噪算法在不同图像 上的优缺点,以及参数调整对 降噪效果的影响。
详细描述
均值滤波对去除高斯噪声有一定效果,但可能会使图像模糊。在Matlab中,可以使用`imfilter`函数实 现均值滤波。
高斯滤波降噪
总结词
高斯滤波是一种线性滤波方法,通过将像素值替换为高斯函数在邻近像素上的加 权和,从而达到降噪效果。
详细描述
高斯滤波能够平滑图像并减少噪声,同时保持图像的边缘清晰。在Matlab中, 可以使用`imgaussfilt`函数实现高斯滤波。
基于Matlab的数字图像处理 降噪方法
目
CONTENCT
录
• 引言 • 数字图像降噪的基本原理 • 基于Matlab的图像降噪技术 • 实验和结果分析 • 结论和未来工作 • 参考文献
01
引言
数字图像处理的重要性
数字图像处理是计算机视觉领域的重要分支,广泛应用于安防、 医疗、通信、交通等领域。
通过数字图像处理,可以对图像进行增强、分析和理解,提高图 像的视觉效果和信息含量。
降噪在数字图像处理中的角色
降噪是数字图像处理中的一项基础任 务,旨在消除图像中的噪声,提高图 像质量。
噪声可能来源于图像获取、传输和存 储过程中,对后续图像分析和识别任 务产生干扰。
matlab11种数字信号滤波去噪算法
matlab11种数字信号滤波去噪算法Matlab是一种强大的数学软件,广泛应用于信号处理领域。
在数字信号处理中,滤波去噪是一个重要的任务,可以提高信号的质量和准确性。
本文将介绍Matlab中的11种数字信号滤波去噪算法。
1. 均值滤波:该算法通过计算信号中一定窗口内的像素平均值来去除噪声。
它适用于高斯噪声和椒盐噪声的去除。
2. 中值滤波:该算法通过计算信号中一定窗口内的像素中值来去除噪声。
它适用于椒盐噪声的去除。
3. 高斯滤波:该算法通过对信号进行高斯模糊来去除噪声。
它适用于高斯噪声的去除。
4. 维纳滤波:该算法通过最小均方误差准则来估计信号的真实值,并去除噪声。
它适用于高斯噪声的去除。
5. 自适应滤波:该算法通过根据信号的局部特性来调整滤波器的参数,从而去除噪声。
它适用于非线性噪声的去除。
6. 小波去噪:该算法通过将信号分解为不同频率的小波系数,并对系数进行阈值处理来去除噪声。
它适用于各种类型的噪声的去除。
7. Kalman滤波:该算法通过对信号进行状态估计和观测更新来去除噪声。
它适用于线性系统的去噪。
8. 粒子滤波:该算法通过使用一组粒子来估计信号的状态,并通过重采样来去除噪声。
它适用于非线性系统的去噪。
9. 线性预测滤波:该算法通过使用线性预测模型来估计信号的未来值,并去除噪声。
它适用于平稳信号的去噪。
10. 自适应线性组合滤波:该算法通过对信号进行线性组合来估计信号的真实值,并去除噪声。
它适用于各种类型的噪声的去除。
11. 稀疏表示滤波:该算法通过使用稀疏表示模型来估计信号的真实值,并去除噪声。
它适用于各种类型的噪声的去除。
以上是Matlab中的11种数字信号滤波去噪算法。
每种算法都有其适用的场景和优缺点,根据具体的信号和噪声类型选择合适的算法进行去噪处理。
Matlab提供了丰富的函数和工具箱,可以方便地实现这些算法,并对信号进行滤波去噪。
通过合理选择和组合这些算法,可以有效提高信号的质量和准确性,为后续的信号处理任务提供更好的基础。
去除高斯噪声的matlab代码
去除高斯噪声的matlab代码高斯噪声是一种常见的图像噪声,它会导致图像变得模糊和不清晰。
在数字图像处理中,我们经常需要去除这种噪声,以提高图像的质量和清晰度。
本文将介绍如何使用MATLAB编写代码来去除高斯噪声。
首先,我们需要导入图像并显示它。
假设我们的图像文件名为"image.jpg",我们可以使用以下代码来导入和显示图像:```matlabimage = imread('image.jpg');imshow(image);```接下来,我们需要将图像转换为灰度图像。
这是因为高斯噪声通常会影响图像的亮度,而不是颜色。
我们可以使用以下代码将图像转换为灰度图像:```matlabgray_image = rgb2gray(image);imshow(gray_image);```然后,我们可以使用MATLAB的内置函数"imnoise"来添加高斯噪声到图像中。
该函数需要指定噪声类型和噪声强度。
对于高斯噪声,我们可以使用"gaussian"作为噪声类型,并指定噪声强度为0.02。
以下是添加高斯噪声的代码:```matlabnoisy_image = imnoise(gray_image, 'gaussian', 0, 0.02);imshow(noisy_image);```现在,我们可以使用MATLAB的内置函数"wiener2"来去除高斯噪声。
该函数使用维纳滤波器来恢复图像的清晰度。
以下是去除高斯噪声的代码:```matlabdenoised_image = wiener2(noisy_image);imshow(denoised_image);```最后,我们可以将去噪后的图像保存到新的文件中。
假设我们要保存的文件名为"denoised_image.jpg",我们可以使用以下代码来保存图像:```matlabimwrite(denoised_image, 'denoised_image.jpg');```至此,我们已经完成了去除高斯噪声的MATLAB代码。
(完整word版)数字图像去噪典型算法及matlab实现
图像去噪是数字图像办理中的重要环节和步骤。
去噪收效的利害直接影响到后续的图像办理工作如图像切割、边缘检测等。
图像信号在产生、传输过程中都可能会碰到噪声的污染,一般数字图像系统中的常有噪声主要有:高斯噪声〔主要由阻性元器件内部产生〕、椒盐噪声〔主若是图像切割引起的黑图像上的白点噪声或光电变换过程中产生的泊松噪声〕等;目前比较经典的图像去噪算法主要有以下三种:均值滤波算法:也称线性滤波,主要思想为邻域平均法,即用几个像素灰度的平均值来代替每个像素的灰度。
有效控制加性噪声,但简单引起图像模糊,能够对其进行改良,主要避开对光景边缘的圆滑办理。
中值滤波:基于排序统计理论的一种能有效控制噪声的非线性圆滑滤波信号办理技术。
中值滤波的特点即是第一确定一个以某个像素为中心点的邻域,一般为方形邻域,也能够为圆形、十字形等等,尔后将邻域中各像素的灰度值排序,取其中间值作为中心像素灰度的新值,这里领域被称为窗口,当窗口搬动时,利用中值滤波能够对图像进行圆滑办理。
其算法简单,时间复杂度低,但其对点、线和尖顶多的图像不宜采用中值滤波。
很简单自适应化。
Wiener 维纳滤波:使原始图像和其恢复图像之间的均方误差最小的复原方法,是一种自适应滤波器,依照局部方差来调整滤波器收效。
对于去除高斯噪声收效明显。
实验一:均值滤波对高斯噪声的收效代码I=imread('C:\Documents and桌面\1.gif');%读取图像J=imnoise(I,'gaussian',0,0.005);%参加均值为 0 ,方差为的高斯噪声subplot(2,3,1);imshow(I);title(' 原始图像 ');subplot(2,3,2); imshow(J);title(' 参加高斯噪声此后的图像');%采用 MATLAB 中的函数 filter2 对受噪声搅乱的图像进行均值滤波K1=filter2(fspecial('average',3),J)/255; %模板尺寸为3K2=filter2(fspecial('average',5),J)/255;%模板尺寸为 5K3=filter2(fspecial('average',7),J)/255; %模板尺寸为7K4= filter2(fspecial('average',9),J)/255; %模板尺寸为9subplot(2,3,3);imshow(K1);title('改良后的图像1');subplot(2,3,4); imshow(K2);title('改良后的图像2');subplot(2,3,5);imshow(K3);title('改良后的图像3');subplot(2,3,6);imshow(K4);title(' 改良后的图像 4');PS:filter2 用法fspecial 函数用于创立预定义的滤波算子,其语法格式为:h = fspecial(type)h = fspecial(type,parameters)参数 type 拟定算子种类, parameters 指定相应的参数,详尽格式为:type='average',为均值滤波,参数为n,代表模版尺寸,用向量表示,默认值为[3,3] 。
MATLAB技术图像降噪教程
MATLAB技术图像降噪教程引言:图像降噪是数字图像处理中的重要任务之一,它旨在减少图像中的噪声和干扰,提高图像的质量和视觉效果。
MATLAB是一种广泛使用的工具,它提供了许多功能强大的工具箱和函数,用于数字图像处理和分析。
在本教程中,我们将介绍一些在MATLAB中进行图像降噪的常用技术和方法。
一、图像噪声简介图像噪声是由各种因素引起的图像中的不希望的非结构化信息。
噪声可以降低图像的质量,并影响后续的图像处理和分析。
主要的图像噪声类型包括高斯噪声、椒盐噪声和泊松噪声等。
了解图像噪声的类型和特点对于选择合适的降噪方法非常重要。
二、图像降噪方法1. 基于滤波器的降噪方法滤波器是一种常用的图像降噪方法。
MATLAB提供了许多经典的滤波器,如均值滤波器、中值滤波器和高斯滤波器。
这些滤波器通过对图像进行平滑或去除异常值的操作,来减少噪声的影响。
例如,可以使用MATLAB中的medfilt2函数来执行中值滤波,该函数可以有效地去除椒盐噪声。
2. 基于小波变换的降噪方法小波变换是一种多尺度分析方法,常用于图像降噪。
MATLAB提供了丰富的小波函数和工具箱,如wavedec2和waverec2。
通过对图像进行小波分解和重构,可以将噪声和信号分离,然后对噪声进行滤除。
使用小波变换进行图像降噪需要选择合适的小波基函数和阈值参数,以达到最佳的降噪效果。
3. 基于深度学习的降噪方法近年来,深度学习在图像处理领域取得了巨大的突破。
MATLAB提供了深度学习工具箱,可以用于训练和应用深度学习模型。
对于图像降噪任务,可以使用卷积神经网络(CNN)进行建模和训练。
通过使用大量的图像数据进行训练,深度学习模型可以自动学习图像中的噪声分布和特征,并实现高质量的图像降噪效果。
三、降噪实例演示我们将通过一个具体的图像降噪实例来演示MATLAB中的图像降噪技术。
假设我们有一张受到高斯噪声干扰的图像,我们将使用不同的方法对其进行降噪。
1. 基于滤波器的降噪方法首先,我们将使用均值滤波器对图像进行降噪。
Matlab技术图像去噪与去模糊方法总结
Matlab技术图像去噪与去模糊方法总结引言图像的噪声和模糊经常会影响到图像的质量和可用性。
在现实生活中,由于环境的不可控因素或图像传感器本身的限制,我们常常会面对图像存在噪声和模糊的情况。
因此,如何有效地去除图像中的噪声和模糊成为了图像处理中的重要问题。
本文将总结Matlab技术中常用的图像去噪和去模糊方法,并介绍它们的原理和应用场景。
一、图像去噪方法1. 均值滤波均值滤波是一种常见的图像去噪方法,它基于图像中的像素局部平均值来代替原始像素的值。
均值滤波器将一个像素的值设置为相邻像素的平均值,从而实现去除图像中的噪声。
2. 中值滤波中值滤波是一种非线性滤波器,它在处理噪声图像时非常有效。
该方法通过使用像素值的中值来替换像素值,从而去除图像中的噪声。
中值滤波器对于椒盐噪声和脉冲噪声有很好的去除效果。
3. 小波去噪法小波去噪法是一种基于小波变换的图像处理方法。
它将图像分解为不同尺度的子图像,并通过阈值处理去除子图像中的噪声。
小波去噪法可以有效地保留图像细节,并在去除噪声的同时保持图像的清晰度。
二、图像去模糊方法1. 维纳滤波维纳滤波是一种常用的图像去模糊方法,它通过最小化图像的噪声和失真之间的均方误差来恢复原始图像。
维纳滤波器在频域或空域中操作,可以根据图像的特点选择最适合的滤波器。
2. 直方图均衡化直方图均衡化是一种将图像的像素强度值映射到特定范围的方法。
在去模糊处理中,直方图均衡化可以增强图像的对比度,减少图像的模糊程度。
3. 傅里叶变换傅里叶变换是一种将图像从时域转换到频域的方法。
在图像去模糊中,可以使用傅里叶变换来将图像转换到频域,然后应用滤波器来去除模糊。
三、图像去噪和去模糊方法的应用场景1. 医学影像医学影像中的噪声和模糊会影响到医生对病情的判断。
因此,图像去噪和去模糊在医学影像中具有重要意义。
例如,在CT扫描中,可以使用均值滤波和小波去噪法来去除图像中的噪声;而在MRI影像中,可以使用维纳滤波和傅里叶变换来恢复图像的清晰度和细节。
使用Matlab进行图像去噪与增强的技巧
使用Matlab进行图像去噪与增强的技巧图像去噪与增强是数字图像处理中的重要环节,在很多领域都有所应用,如医学影像、无人驾驶技术、智能安防等。
Matlab是一种广泛应用于科研与工程领域的软件,以其强大的图像处理功能备受青睐。
本文将介绍一些使用Matlab进行图像去噪与增强的技巧,让读者能够更好地掌握这一工具以及相关的技术。
1. 图像去噪技术图像去噪是指从图像中消除由于采集设备、传输过程或其他因素引入的噪声,使得图像更加清晰可辨。
Matlab提供了很多常用的图像去噪工具和算法,下面将介绍其中几种常见的方法。
1.1 均值滤波均值滤波是一种简单有效的降噪方法,其基本思想是用相邻像素的平均值来代替当前像素的值。
Matlab提供了均值滤波函数`imfilter`,可以通过指定滤波器类型和大小来实现不同程度的去噪效果。
例如,可以使用`fspecial`函数生成一个指定大小的均值滤波器矩阵,然后通过`imfilter`函数对图像进行滤波处理。
1.2 中值滤波中值滤波是一种非线性滤波方法,其原理是用像素领域内的中值来代替当前像素的值。
相比于均值滤波,中值滤波能够更好地保留图像的细节信息,并且在去除椒盐噪声等脉冲噪声方面表现更好。
在Matlab中,可以使用`medfilt2`函数来进行中值滤波操作,通过指定滤波器大小来调整滤波程度。
1.3 小波降噪小波降噪是一种基于小波变换的图像去噪方法,能够在不同尺度上对图像进行分析和处理。
Matlab中提供了丰富的小波变换工具箱,可以选择不同的小波基和阈值方法来实现图像的降噪和增强。
例如,可以使用`wdenoise`函数对图像进行小波去噪操作,在指定阈值和小波基的情况下,实现对图像的去噪效果的控制。
2. 图像增强技术图像增强是指通过一系列处理方法,使得图像的质量得到改善,更适合进行分析和应用。
Matlab提供了很多图像增强的函数和工具箱,下面将介绍一些常见的图像增强技术。
2.1 灰度拉伸灰度拉伸是一种常用的增强方法,其原理是通过对图像像素的灰度值进行线性转换,使得图像的对比度得到改善。
常用的去噪方法
常用的数字图像去噪典型算法及matlab实现发表于603天前⁄图像处理⁄评论数1⁄被围观743views+图像去噪是数字图像处理中的重要环节和步骤。
去噪效果的好坏直接影响到后续的图像处理工作如图像分割、边缘检测等。
图像信号在产生、传输过程中都可能会受到噪声的污染,一般数字图像系统中的常见噪声主要有:高斯噪声(主要由阻性元器件内部产生)、椒盐噪声(主要是图像切割引起的黑图像上的白点噪声或光电转换过程中产生的泊松噪声)等;目前比较经典的图像去噪算法主要有以下三种:均值滤波算法:也称线性滤波,主要思想为邻域平均法,即用几个像素灰度的平均值来代替每个像素的灰度。
有效抑制加性噪声,但容易引起图像模糊,可以对其进行改进,主要避开对景物边缘的平滑处理。
中值滤波:基于排序统计理论的一种能有效抑制噪声的非线性平滑滤波信号处理技术。
中值滤波的特点即是首先确定一个以某个像素为中心点的邻域,一般为方形邻域,也可以为圆形、十字形等等,然后将邻域中各像素的灰度值排序,取其中间值作为中心像素灰度的新值,这里领域被称为窗口,当窗口移动时,利用中值滤波可以对图像进行平滑处理。
其算法简单,时间复杂度低,但其对点、线和尖顶多的图像不宜采用中值滤波。
很容易自适应化。
Wiener维纳滤波:使原始图像和其恢复图像之间的均方误差最小的复原方法,是一种自适应滤波器,根据局部方差来调整滤波器效果。
对于去除高斯噪声效果明显。
实验一:均值滤波对高斯噪声的效果代码I=imread('C:\Documents and Settings\Administrator\桌面\1.gif');%读取图像J=imnoise(I,'gaussian',0,0.005);%加入均值为0,方差为0.005的高斯噪声subplot(2,3,1);imshow(I);title('原始图像');subplot(2,3,2);imshow(J);title('加入高斯噪声之后的图像');%采用MATLAB中的函数filter2对受噪声干扰的图像进行均值滤波K1=filter2(fspecial('average',3),J)/255;%模板尺寸为3K2=filter2(fspecial('average',5),J)/255;%模板尺寸为5K3=filter2(fspecial('average',7),J)/255;%模板尺寸为7K4=filter2(fspecial('average',9),J)/255;%模板尺寸为9subplot(2,3,3);imshow(K1);title('改进后的图像1');subplot(2,3,4);imshow(K2);title('改进后的图像2');subplot(2,3,5);imshow(K3);title('改进后的图像3');subplot(2,3,6);imshow(K4);title('改进后的图像4');PS:filter2用法fspecial函数用于创建预定义的滤波算子,其语法格式为:h=fspecial(type)h=fspecial(type,parameters)参数type制定算子类型,parameters指定相应的参数,具体格式为:type=’average’,为均值滤波,参数为n,代表模版尺寸,用向量表示,默认值为[3,3]。
基于Matlab的数字图像典型去噪算法_丁永胜 (1)
2010年 11月 Journal of Science of Teachers′College and University Nov. 2010文章编号:1007-9831(2010)06-0010-04基于Matlab 的数字图像典型去噪算法丁永胜1,李朝红2,张水胜1(1. 齐齐哈尔大学 理学院, 黑龙江 齐齐哈尔 161006;2. 齐齐哈尔高等师范专科学校 数学系, 黑龙江 齐齐哈尔 161005) 摘要:针对数字图像处理中的典型去噪算法,利用Matlab 进行分析处理,并从主观和客观2个角度对数字图像的去噪效果进行分析.在分析过程中可以看出,针对不同类型的噪声需要相应的滤波去噪算法才能取得较好的效果.关键词:Matlab ;去噪;滤波中图分类号:TP391.72 文献标识码:A doi:10.3969/j.issn.1007-9831.2010.06.0041 图像中的噪声与图像去噪噪声可以理解为妨碍人们感觉器官对所接收的信源信息理解的因素.例如:一幅黑白图片,其平面亮度分布假定为) ,(y x f ,那么对其接收起干扰作用的亮度分布) ,(y x h 即可称为图像噪声[1].图像去噪是数字图像处理中的重要环节和步骤.去噪效果的好坏直接影响到后续的图像处理工作,如图像分割、边缘检测等.一般数字图像系统中的常见噪声主要有高斯噪声和椒盐噪声等,减少噪声的方法可以在图像空间域或在图像频率域完成.在空间域对图像处理主要有均值滤波算法和中值滤波算法.图像频率域去噪方法是对图像进行某种变换,将图像从空间域转换到频率域,对频率域中的变换系数进行处理,再进行反变换将图像从频率域转换到空间域来达到去除图像噪声的目的.将图像从空间转换到变换域的变换方法很多,常用的有傅立叶变换、小波变换等.在Matlab 中常用的去噪函数有filter2( ), wiener2( ), medfilt2( ), ordfilt2( )以及小波分析工具箱提供的wrcoef2( )和wpdencmp( )等[2].本文基于Matlab 提供的去噪函数,针对数字图像处理中的典型去噪算法,利用Matlab 进行分析处理,并从主观和客观2个角度对数字图像的去噪效果进行分析.2 图像质量的评价方法图像质量的评价方法有主观评价和客观评价2种.图像的主观评价就是通过人来观察图像,对图像的优劣作主观评定,然后对评分进行统计平均,就得出评价的结果.这时评价出的图像质量与观察者的特性及观察条件等因素有关.由于主观评价带有较强的个人因素特征,并且在一些研究场合,或者由于实验条件的限制,也希望对图像质量有一个定量的客观评价.最常用的客观评价有均方误差(MSE)、峰值信噪比(PSNR)和信噪比(SNR)等.本文主要以信噪比(SNR)进行客观评价. 信噪比主要由公式⎟⎟⎠⎞⎜⎜⎝⎛××=∑∑==M i N j j i g MSE N M SNR 112) ,(1log 10定义,其中:N M ×为图像矩阵的大小;) ,(j i g 为小波变换后的图像在) ,(j i 位置处的像素值;) ,(j i f 为原始图像在) ,(j i 位置处的像素值;收稿日期:2010-04-20作者简介:丁永胜(1974-),男,黑龙江讷河人,副教授,硕士,从事计算机图形学、计算机辅助几何设计研究.E-mail:dysnwpu@()∑∑==−××=M i N j j i f j i g M N MSE 112) ,() ,(11. 根据以上所述,在Matlab 仿真过程中,可以利用SNR 函数得到各去噪方法作用过的图像的信噪比,程序如下:[m n]=size(I1);for i=1:m;for j=1:n;s=s+double(I2(i,j))^2;n=n+(double(I1(i,j))-double(I2 (i,j)))^2;endendSNR=10*log10((s/n))3 Matlab 仿真去噪及分析3.1 均值滤波去噪首先加入均值为0、方差为0.005的高斯白噪声,然后采用函数fspecial(type, parameters)且type='average',创建均值滤波算子并进行滤波去噪,通过改变模板尺寸,得到不同去噪效果(见图1).部分Matlab代码如下:I=imread('qqhru.bmp');I2=imnoise(I,'gaussian',0,0.005);K1=filter2(fspecial('average',3), I2)/255;K2=filter2(fspecial('average',5), I2)/255;K3=filter2(fspecial('average',7), I2)/255;K4= filter2(fspecial('average',9),J)/255;图1 均值滤波去噪从图1中可以看出,使用均值滤波去噪(高斯噪声)时选用的模板尺寸(邻域半径)越大效果越好.3.2 3种去噪算法对比分析对图像qqhru.bmp分别加入高斯噪声、椒盐噪声,然后对加入2类噪声的图像分别作二维统计、中值和维纳滤波,并对去噪后图像(见图2)进行对比分析.部分Matlab代码如下:I=imread('qqhru.bmp');J1=imnoise(I,'gaussian',0,0.02);J2=imnoise(I,'salt & pepper',0.02) ;K1=filter2(fspecial('average',3),J1)/255;K2= medfilt2(J1);K3=wiener2(J1,[3 3]);Ks1=filter2(fspecial('average',3),J2)/255;Ks2=medfilt2(J2);Ks3=wiener2(J2,[3 3]);图2 3种去噪算法对比通过图2可以看出,在处理服从高斯分布的一类噪声时,维纳滤波与中值滤波去除效果较好一些,而二维统计滤波去除效果较差.二维统计滤波与中值滤波对于去除椒盐噪声效果好,而维纳滤波去除效果差,中值滤波对于去除椒盐噪声效果明显,是因为椒盐噪声只在画面上的部分点随机出现,而中值滤波根据数据排序,将未被污染的点代替噪声点的值的概率较大,所以抑制效果好.对点、线和尖顶较多的图像不宜采用中值滤波,因为一些细节点可能被当成噪声点.通过SNR 函数得到3种去噪方法的信噪比(见表1),也可以说明以上的结论是正确的.3.3 小波分析工具图像去噪Matlab 小波分析工具箱提供于图像去噪的有wrcoef 2和wpdencmp 等函数.X=wrcoef 2('type ',C,S, 'wname ')返回基于小波分解结构[C,S]的小波重构图像X(见图3).[xd,treed,datad,perf0,perfl2]=wpdencmp(x,sorh,N, 'wname ',crit,par,keepapp)是通过小波包定限(阈值化),返回输入信号或图像X 的除噪结果xd(见图4).部分Matlab 代码如下:I=imread(' qqhru.bmp');J=imnoise(I,'gaussian',0,0.005);[c,l]=wavedec2(J,2,'sym4');J1= wrcoef2('a',c,l,'sym4',1);J2= wrcoef2('a',c,l,'sym4',2);[thr,sorh,keepapp] = ddencmp('den','wv',J);J3=wdencmp('gbl',J,'sym4',2,thr,sorh,keepapp);J4=medfilt2(J3);表1 3种去噪方法的信噪比 噪声类型二维统计滤波 中值滤波 维纳滤波高斯噪声16.504 8 19.184 3 19.574 4椒盐噪声22.238 3 26.492 8 19.158 3图3 wrcoef2函数去噪小波分解可以把图像分层次按照小波基展开,并且可以根据图像的性质及给定的处理标准确定展开到哪一级为止,还可以把细节分量和近似分量分开[3]. 从图3、图4可以看出,wrcoef 2和wpdencmp等函数可以有效地进行去噪处理.基于Matlab 给出qqhru.bmp 图像来考察各种去噪模型的去噪效果,同时从主观和客观2个角度对数字图像的去噪效果进行分析.在分析过程中可以看出,针对不同类型的噪声需要相应的滤波去噪算法才能取得较好的效果,才能使后续的图像处理工作得以更加优质的进行.参考文献:[1] Rafael C,Gonzalez,Richard E.数字图像处理[M].2版.阮秋琦,译.北京:电子工业出版社,2007:276-303.[2] 高成.Matlab 图像处理与应用[M].北京:国防工业出版社,2007:81-127.[3] 王登位,李炜.基于小波变换的图像去噪研究[J].计算机与数字工程,2007,35(9):131-132.The typical de-noising algorithms for digital image by MatlabDING Yong-sheng 1,LI Zhao-hong 2,ZHANG Shui-sheng 1(1. School of Science,Qiqihar University,Qiqihar 161006,China;2. Department of Mathematics,Qiqihar Normal Technological Academy,Qiqihar 161005,China) Abstract:According to the typical de-noising algorithm for the digital image processing researched de-noising results in Matlab,and analyzed digital image de-noising effect from two angles of the subjective and the objective.Through the analysis of the results can be known, choosing corresponding filtering de-noising algorithm can obtain better result according to different types of noise.Key words:Matlab;de-noising;filtering 图4 wpdencmp 函数去噪。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
图像去噪是数字图像处理中的重要环节和步骤。
去噪效果的好坏直接影响到后续的图像处理工作如图像分割、边缘检测等。
图像信号在产生、传输过程中都可能会受到噪声的污染,一般数字图像系统中的常见噪声主要有:高斯噪声(主要由阻性元器件内部产生)、椒盐噪声(主要是图像切割引起的黑图像上的白点噪声或光电转换过程中产生的泊松噪声)等;目前比较经典的图像去噪算法主要有以下三种:均值滤波算法:也称线性滤波,主要思想为邻域平均法,即用几个像素灰度的平均值来代替每个像素的灰度。
有效抑制加性噪声,但容易引起图像模糊,可以对其进行改进,主要避开对景物边缘的平滑处理。
中值滤波:基于排序统计理论的一种能有效抑制噪声的非线性平滑滤波信号处理技术。
中值滤波的特点即是首先确定一个以某个像素为中心点的邻域,一般为方形邻域,也可以为圆形、十字形等等,然后将邻域中各像素的灰度值排序,取其中间值作为中心像素灰度的新值,这里领域被称为窗口,当窗口移动时,利用中值滤波可以对图像进行平滑处理。
其算法简单,时间复杂度低,但其对点、线和尖顶多的图像不宜采用中值滤波。
很容易自适应化。
Wiener维纳滤波:使原始图像和其恢复图像之间的均方误差最小的复原方法,是一种自适应滤波器,根据局部方差来调整滤波器效果。
对于去除高斯噪声效果明显。
实验一:均值滤波对高斯噪声的效果代码I=imread('C:\Documents and Settings\Administrator\桌面\1.gif');%读取图像J=imnoise(I,'gaussian',0,0.005);%加入均值为0,方差为0.005的高斯噪声subplot(2,3,1);imshow(I);title('原始图像');subplot(2,3,2); imshow(J);title('加入高斯噪声之后的图像');%采用MATLAB中的函数filter2对受噪声干扰的图像进行均值滤波K1=filter2(fspecial('average',3),J)/255; %模板尺寸为3K2=filter2(fspecial('average',5),J)/255;% 模板尺寸为5K3=filter2(fspecial('average',7),J)/255; %模板尺寸为7K4= filter2(fspecial('average',9),J)/255; %模板尺寸为9subplot(2,3,3);imshow(K1);title('改进后的图像1');subplot(2,3,4); imshow(K2);title('改进后的图像2');subplot(2,3,5);imshow(K3);title('改进后的图像3');subplot(2,3,6);imshow(K4);title('改进后的图像4');PS:filter2用法fspecial函数用于创建预定义的滤波算子,其语法格式为:h = fspecial(type)h = fspecial(type,parameters)参数type制定算子类型,parameters指定相应的参数,具体格式为:type='average',为均值滤波,参数为n,代表模版尺寸,用向量表示,默认值为[3,3]。
type= 'gaussian',为高斯低通滤波器,参数有两个,n表示模版尺寸,默认值为[3,3],sigma表示滤波器的标准差,单位为像素,默认值为0.5。
type= 'laplacian',为拉普拉斯算子,参数为alpha,用于控制拉普拉斯算子的形状,取值范围为[0,1],默认值为0.2。
type= 'log',为拉普拉斯高斯算子,参数有两个,n表示模版尺寸,默认值为[3,3],sigma为滤波器的标准差,单位为像素,默认值为0.5type= 'prewitt',为prewitt算子,用于边缘增强,无参数。
type= 'sobel',为著名的sobel算子,用于边缘提取,无参数。
type= 'unsharp',为对比度增强滤波器,参数alpha用于控制滤波器的形状,范围为[0,1],默认值为0.2。
据我目测,使用均值滤波去噪(高斯噪声)效果选用的邻域半径越大效果越好,当然其代价也会更大,另外确切的去噪效果的好坏还需要用SNR等数据来度量。
实验二:二维自适应维纳滤波对高斯噪声的滤除效果代码I=imread('C:\Documents and Settings\Administrator\桌面\1.gif'); %读取图像J=imnoise(I,'gaussian',0,0.005); %加入均值为0,方差为0.005的高斯噪声K2=wiener2(J,[3 3]); %对加噪图像进行二维自适应维纳滤波K2=wiener2(J,[5 5]); %对加噪图像进行二维自适应维纳滤波K2=wiener2(J,[7 7]); %对加噪图像进行二维自适应维纳滤波K2=wiener2(J,[9 9]); %对加噪图像进行二维自适应维纳滤波subplot(2,3,1);imshow(I);title('原始图像');subplot(2,3,2);imshow(J);title('加噪图像');subplot(2,3,3);imshow(K1);title('恢复图像1');subplot(2,3,4);imshow(K2);title('恢复图像2');subplot(2,3,5);imshow(K3);title('恢复图像3');subplot(2,3,6);imshow(K4);title('恢复图像3');PS:维纳滤波的两个函数wiener2与deconvwnr都能够完成维纳滤波的功能, deconvwnr强调图象复原方面,wiener2强调图象空间域锐化的作用,其中J=wiener2(I,[m,n])返回有噪声图像I经过wierner(维纳)滤波后的图像,[m,n]指定滤波器窗口大小为m*n,默认值为3*3,J=wiener2(I,[m,n],noise)指定噪声的功率,[J,noise]=wiener2(I,[m,n])在图像滤波的同时,返回噪声功率的估计值noise。
imnoise的语法格式为J = imnoise(I,type)J = imnoise(I,type,parameters)其中J = imnoise(I,type)返回对原始图像I添加典型噪声的有噪图像J。
参数type和parameters用于确定噪声的类型和相应的参数。
实验三:对加入椒盐噪声的图像分别作均值、中值和维纳滤波代码I=imread(1.gif');J1=imnoise(I,'gaussian',0,0.02);J2=imnoise(I,'salt & pepper',0.02);J3=imnoise(I,'speckle',0.02);运行效果见图2I=imread('C:\Documents and Settings\Administrator\桌面\1.gif');J=imnoise(I,'salt & pepper',0.02);%h=ones(3,3)/9;%产生3*3的全1数组%B=conv2(J,h);%卷积运算K2=filter2(fspecial('average',3),J)/255; %均值滤波模板尺寸为3K= medfilt2(J);%采用二维中值滤波函数medfilt2对受椒盐噪声干扰的图像滤波K1=wiener2(J,[3 3]); %对加噪图像进行二维自适应维纳滤波subplot(2,3,1);imshow(I);title('原始图像');subplot(2,3,2);imshow(J);title('加噪图像');subplot(2,3,3);imshow(K2);title('均值滤波后的图像');subplot(2,3,4);imshow(K);title('中值滤波后的图像');subplot(2,3,5);imshow(K1);title('维纳滤波后的图像');通过图3我们也可得出结论,即中值滤波对于去除椒盐噪声效果最好,而维纳滤波去除效果则较差。
中值滤波对于去除椒盐噪声效果明显,是因为椒盐噪声只在画面上的部分点随机出现,而中值滤波根据数据排序,将未被污染的点代替噪声点的值的概率较大,所以抑制效果好。
对点、线和尖顶较多的图像不宜采用中值滤波,因为一些细节点可能被当成噪声点。
实验四:分别使用二维统计滤波对椒盐噪声和高斯噪声进行滤波代码I=imread('C:\Documents and Settings\Administrator\桌面\1.gif');J1=imnoise(I,'salt & pepper',0.004);subplot(2,3,1);imshow(I);title('原始图像');subplot(2,3,2);imshow(J1);title('加椒盐噪声后的图像');J= ordfilt2(J1,5,ones(3,4));% 进行二维统计顺序过滤subplot(2,3,3);imshow(J);title('椒盐噪声滤波后的图像');J2=imnoise(I,'gaussian',0,0.004);subplot(2,3,4);imshow(J2);title('加高斯噪声后的图像');J3= ordfilt2(J2,5,ones(3,4));subplot(2,3,5);imshow(J3);title('高斯噪声滤波后的图像');PS:MATLAB小波分析工具箱提供的用于图像去噪的函数有wrcoef2和wpdencmp,其语法格式分别为:X=wrcoef2(‘type’,C,S,’wname’)[xd,treed,datad,perf0,perfl2]=wpdencmp(x,sorh,N,’wname’,crit,par,keepapp)其中,X=wrcoef2(‘type’,C,S,’wname’)返回基于小波分解结构[C,S]的小波重构图像X。