数字图像处理实验三中值滤波和均值滤波实验报告
- 格式:docx
- 大小:154.74 KB
- 文档页数:22
实验三图像滤波实验3.13*3均值滤波一.实验目的1.熟悉MATLAB图像处理工具箱及均值滤波函数的使用;2.理解和掌握3*3均值滤波的方法和应用;二.实验设备1.PC机一台;2.软件MATLAB;三.程序设计在MATLAB环境中,程序首先读取图像,然后调用图像增强(均值滤波)函数,设置相关参数,再输出处理后的图像。
closeall;I=imread('cameraman.tif');figure;subplot(2,3,1);imshow(I);%加入Gaussian噪声J1=imnoise(I,'gaussian',0,0.005);subplot(2,3,2);imshow(J1);%加入椒盐噪声J2=imnoise(I,'salt&pepper',0.02);subplot(2,3,3);imshow(J2);h=fspecial('average',[33]);G1=imfilter(J1,h);subplot(2,3,5);imshow(G1);G2=imfilter(J2,h);subplot(2,3,6);imshow(G2);四.实验步骤1.启动MATLAB双击桌面MATLAB图标启动MATLAB环境;2.在MATLAB命令窗口中输入相应程序。
书写程序时,首先读取图像,一般调用MATLAB自带的图像,如:cameraman图像;再调用相应的图像增强(均值滤波)函数,设置参数;最后输出处理后的图像;3.浏览源程序并理解含义;4.运行,观察显示结果;5.结束运行,退出;五.实验结果观察MATLAB环境下原始图像经3*3均值滤波处理后的结果。
(a)原始图像(b)3*3均值滤波处理后的图像图(3)六.实验报告要求输入一幅灰度图像,给出其图像经3*3均值滤波处理后的结果,然后对每一点的灰度值和它周围24个点,一共25个点的灰度值进行均值滤波,看看对25个点取均值与对9个点进行均值滤波有什么区别?有没有其他的算法可以改进滤波效果。
华东师范大学电子工程系2017.6实验1:图像灰度级修正【实验目的】掌握常用的图像灰度级修正方法(灰度变换法和直方图均衡化),加深对直方图的理解。
观察图像的增强效果,对灰度级修正前后的图像加以比较。
【实验内容】1)编程实现图像的灰度变换,改变图像的输入、输出映射参数范围(线性拉伸和反比);2)修改参数gamma值(大于、小于、等于1),观察处理结果;3)对图像直方图作均衡化处理,显示均衡前后的图像及其直方图。
【实验代码】original=imread('lena.bmp');linstr=imadjust(original,[0.3 0.7],[0 1]); %线性拉伸opposite=imadjust(original,[0 1],[1 0]); %反比above=imadjust(original,[0 1],[0 1],2); %gamma>1equal=imadjust(original,[0 1],[0 1],1); %gamma=1below=imadjust(original,[0 1],[0 1],0.5); %gamma<1subplot(3,3,1);imshow(original);title('原图像');subplot(3,3,2);imshow(linstr);title('线性拉伸');subplot(3,3,3);imshow(opposite);title('反比');subplot(3,3,4);imshow(above);title('gamma>1');subplot(3,3,5);imshow(equal);title('gamma=1');subplot(3,3,6);imshow(below);title('gamma<1');subplot(3,3,7);imhist(original);title('原图像直方图'); histequal=histeq(original);%对图像均衡化subplot(3,3,8);imshow(histequal);title('均衡后的图像'); subplot(3,3,9);imhist(histequal);title('均衡图像的直方图'); axis([0 256 0 2000]);【输出图像】【实验思考】根据以下图片以及实验结果可知gamma>1时图像整体变暗,灰度级整体变小;gamma<1时图像整体变亮,灰度级整体变小;而gamma=1时,图像维持不变。
数字与图像处理报告
姓名:罗钰婧班级:12信国学号:20121378032
1.均值滤中值滤波对去除噪声
⑴.椒盐噪声:出现位置是随机的,但噪声的幅值是基本相同的。
对于椒盐噪声,中值滤波比均值滤波好。
因为椒盐噪声图像中既有干净点又有污染点,中值滤波是选适当的点来代替污染点,随意处理效果好;
而噪声均值不为0,所以均值滤波不能很好的去除椒盐噪声。
⑵.高斯噪声:出现位置是一定的(每一个点上),噪声的幅值是随机的。
对于高斯噪声,均值滤波比中指滤波好。
因为图像中每个点都是污染点,中值滤波找不到合适的干净点。
而正态分布的均值为0,所以均值滤波可以较好的减弱噪声。
对于中值滤波,可以发现取的领域越大,图像越模糊。
因为随着领域变大,精度降低。
同中值滤波,可以发现取的领域越大,图像越模糊。
2.傅里叶变换频谱图
3.伪彩色。
2010年4月一,实验目的。
1.了解在数字图像处理中滤波的概念和意义。
2.掌握数字图像处理滤波程序。
二,实验原理。
图像的中值滤波是一种非线性的图像处理方法,它通过对邻域内像素按灰度排序的结果决定中心像素的灰度。
图像的中值滤波是统计排序滤波器的一种常见应用,它是通过对邻域内采样数据进行排序并取得中值来决定中心像素灰度的一种处理手段,图像的中值滤波在少量离散杂点的消除方面效果显著。
前面介绍过图像简单平滑和高斯平滑,以这两种算法为代表的平滑线性滤波算法在消除离散型杂点方面,都采取的是将杂点的干扰分摊到整个邻域中的每个像素,以减少杂点的影响,然而这样做的代价就是图像清晰度的大量损失。
如图11-14所示,a表示一个5×5邻域的像素灰度,其中中点位置的像素为孤立的杂点,b为对a进行一次简单平滑处理的结果,c 为对b进行简单平滑的结果,从图中可看出简单平滑将杂点对图像的影响分担到了邻域的其他像素。
图11-14 孤立杂点的简单平滑从图11-14中可以发现简单平滑对于孤立的杂点消除较为有效,而对于稍大的杂点或是密集的杂点,图像简单平滑的效果就不够理想。
如图11-15所示,其中a表示一个5×5邻域的像素灰度,其中灰度为0的点为杂点,b为对a进行简单平滑的结果,从图中可以看出简单平滑使画面质量严重下降,并且并没有很好地去除杂点影响。
图11-15 稍大杂点的简单平滑分析原因,可以发现平滑线性滤波器的工作原理可以比喻为用水冲洗桌面上的污点,冲洗的结果污点并没有消失,只是被淡化,如果污点较大较密集,则冲洗的结果是整个桌面都被污点所影响。
尝试换一种思路,如果不采取冲淡污点的办法而是将污点直接去除,这样就可以避免污点数量较多时难以去除的困难,这也就是中值滤波的基本思想。
在中值滤波算法中,对于孤立像素的属性并不非常关注,而是认为图像中的每个像素都跟邻域内其他像素有着密切的关系,对于每一个邻域,算法都会在采样得到的若干像素中,选择一个最有可能代表当前邻域特征的像素的灰度作为中心像素灰度,这样就有效避免了离散型杂点对图像的影响。
数字图像处理作业(中值滤波&均值滤波)学院:电子信息工程学院专业:控制工程姓名:苏良碧1中值滤波1.1、中值滤波原理:中值滤波是基于排序统计理论的一种能有效抑制噪声的非线性信号处理技术,中值滤波的基本原理是把数字图像或数字序列中一点的值用该点的一个邻域中各点值的中值代替,让周围的像素值接近的真实值,从而消除孤立的噪声点。
方法是去某种结构的二维滑动模板,将板内像素按照像素值的大小进行排序,生成单调上升(或下降)的为二维数据序列。
二维中值滤波输出为g(x,y)=med{f(x-k,y-l),(k,l∈W)},其中,f(x,y),g(x,y)分别为原始图像和处理后图像。
W为二维模板,通常为2*2,3*3区域,也可以是不同的的形状,如线状,圆形,十字形,圆环形等。
1.2、实现方法:(1)通过从图像中的某个采样窗口取出奇数个数据进行排序;(2)用排序后的中值取代要处理的数据即可;1.3、matlab程序(zhongzhilvbo.m)clear;close all;I=imread('I3_256.bmp');figure,imshow(I),title('原始图象');J=imnoise(I,'salt&pepper',0.02);imshow(J);title('噪声干扰图像')X=J;a=3;b=3;%3*3的邻域k=floor(a*b/2)+1;%求出中值,即k=5[M,N]=size(X);%求出输入图像的行数M和列数Nuint8Y=zeros(M,N);funBox=zeros(a,b);temp=zeros(a*b);%X(a:b,c:d)表示A矩阵的第a到b行,第c到d列的所有元素for i=1:M-afor j=1:N-bfunBox=X(i:i+a,j:j+b);%把图像中的一个3*3领域赋给funboxtemp=funBox(:);%把领域中的每个元素赋给temptempSort=sort(temp);%对其中的像素值进行排序Y(i,j)=tempSort(k);%将模板的中值(k=5)赋给模板中心位置的元素end;end;figure,imshow(Y);title('中值滤波图像')1.4、结果:2均值滤波2.1、均值滤波原理均值滤波是典型的线性滤波算法,它是指在图像上对目标像素给一个模板,该模板包括了其周围的临近像素(以目标象素为中心的周围8个象素,构成一个滤波模板,即去掉目标象素本身)。
空间滤波实验报告空间滤波实验报告引言:空间滤波是数字图像处理中常用的一种方法,它通过对图像像素进行加权平均或其他操作,以改善图像的质量和增强特定的图像细节。
在本次实验中,我们将探索几种常见的空间滤波技术,并评估它们在不同图像上的效果。
一、均值滤波均值滤波是一种简单的空间滤波方法,它通过计算像素周围邻域的平均值来平滑图像。
在本次实验中,我们选择了一张包含噪声的图像进行均值滤波处理。
结果显示,均值滤波能够有效地减少噪声,但同时也会导致图像的细节模糊化。
这是因为均值滤波是一种线性滤波方法,它对所有像素都施加相同的权重,无法区分图像中的边缘和纹理。
二、中值滤波中值滤波是一种非线性滤波方法,它通过将像素周围邻域的像素值排序并选取中间值来进行滤波。
与均值滤波相比,中值滤波能够更好地保留图像的细节信息。
在实验中,我们使用了一张包含椒盐噪声的图像进行中值滤波处理。
结果显示,中值滤波能够有效去除椒盐噪声,同时也能够保持图像的细节纹理。
这是因为中值滤波对于噪声像素有较好的鲁棒性,能够准确地估计图像中的真实像素值。
三、高斯滤波高斯滤波是一种基于高斯函数的空间滤波方法,它通过对像素周围邻域的像素值进行加权平均来平滑图像。
与均值滤波不同的是,高斯滤波对于不同像素位置的权重是不同的,它能够更好地保持图像的细节和边缘。
在实验中,我们对一张包含高斯噪声的图像进行了高斯滤波处理。
结果显示,高斯滤波能够有效地降低噪声水平,同时也能够保持图像的细节纹理。
这是因为高斯滤波能够根据像素周围邻域的像素值分布来调整权重,从而更好地平衡了图像的平滑度和细节保留。
四、边缘检测除了平滑图像,空间滤波还可以用于边缘检测。
边缘检测是一种常用的图像处理任务,它能够准确地提取图像中的边缘信息。
在实验中,我们使用了一张包含边缘的图像进行了边缘检测实验。
通过应用一种基于梯度的空间滤波算子,我们成功地提取出了图像中的边缘信息。
结果显示,边缘检测能够有效地突出图像中的边缘,但同时也会引入一定的噪声。
数字图像处理实验实验三中值滤波器实验目的●深入理解空域滤波的概念,掌握模板卷积的计算方法●掌握中值滤波器的构建方法,并会中值滤波器对图像进行噪声去除。
实验要求1.读入lena图像,将lena图像转换为灰度图,可用rgb2gray2.用imnoise加入方差为0.2的椒盐噪声。
3.用medfilt2函数对图像进行空间滤波,所用模板为3*3的中值滤波器。
4.改用5*5的中值滤波器重做3中的步骤,比较结果的不同。
实验原理在图像处理中,在进行如边缘检测这样的进一步处理之前,通常需要首先进行一定程度的降噪。
中值滤波是一种非线性数字滤波器技术,经常用于去除图像或者其它信号中的噪声。
这个设计思想就是检查输入信号中的采样并判断它是否代表了信号,使用奇数个采样组成的观察窗实现这项功能。
观察窗口中的数值进行排序,位于观察窗中间的中值作为输出。
然后,丢弃最早的值,取得新的采样,重复上面的计算过程。
中值滤波是图像处理中的一个常用步骤,它对于斑点噪声(en:speckle noise)和椒盐噪声(en:salt-and-pepper noise)来说尤其有用。
保存边缘的特性使它在不希望出现边缘模糊的场合也很有用。
实验心得1.MA TLAB中提供的加噪声的函数和中值滤波函数对本实验的实现提供了便利,直接调用函数即可实现本实验。
2.实验可以分别使用相同类型但方差不同的噪声、模板半径不同的中值滤波器进行实验,用控制变量法观察噪声方差、中值滤波器模板半径对滤波效果的影响。
3.实验可以通过中值滤波器对不同类型噪声污染后的图像的滤波效果进行比较,体会中值滤波器对不同噪声的滤波效果。
4. 自己编写函数对图像进行噪声污染和滤波时,为了方便,不考虑图像边缘滤波,这样程序编写较为方便,而另一方面,图像的滤波不彻底,其边缘噪声不能滤去。
实验源代码1. 用系统函数对图像进行噪声污染和滤波:clcclear all%读入位于D盘\tuxiang的lena图像A=imread('D:\tuxiang\lena.bmp');%将读入的彩色图像转化为灰度图像B=rgb2gray(A);%对图像加入方差为0.2的椒盐噪声C=imnoise(B,'salt & pepper',0.2);F=imnoise(B,'salt & pepper',0.5);%对图像加入均值为0,方差为0.01的高斯噪声I=imnoise(B,'gaussian',0,0.05);%用模板为3*3的中值滤波器对噪声污染后的图像进行空间滤波D=medfilt2(C,[3,3]);G=medfilt2(F,[3,3]);J=medfilt2(I,[3,3]);%用模板为5*5的中值滤波器对噪声污染后的图像进行空间滤波E=medfilt2(C,[5,5]);H=medfilt2(F,[5,5]);K=medfilt2(I,[5,5]);%绘制原始图像figuresubplot(2,2,1);imshow(B);title('原始图像');%绘制被噪声污染的图像subplot(2,2,2);imshow(C);title('方差0.2的椒盐噪声污染后的图像');%绘制用3*3模板的中值滤波器滤波后的图像subplot(2,2,3);imshow(D);title('3*3模板滤波后的后的图像');%绘制用5*5模板的中值滤波器滤波后的图像subplot(2,2,4);imshow(E);title('5*5模板滤波后的后的图像');%绘制原始图像figuresubplot(2,2,1);imshow(B);title('原始图像');%绘制被噪声污染的图像subplot(2,2,2);imshow(F);title('方差0.5的椒盐噪声污染后的图像');%绘制用3*3模板的中值滤波器滤波后的图像subplot(2,2,3);imshow(G);title('3*3模板滤波后的后的图像');%绘制用5*5模板的中值滤波器滤波后的图像subplot(2,2,4);imshow(H);title('5*5模板滤波后的后的图像');%绘制原始图像figuresubplot(2,2,1);imshow(B);title('原始图像');%绘制被噪声污染的图像subplot(2,2,2);imshow(I);title('均值为0、方差0.05的高斯噪声污染后的图像');%绘制用3*3模板的中值滤波器滤波后的图像subplot(2,2,3);imshow(J);title('3*3模板滤波后的后的图像');%绘制用5*5模板的中值滤波器滤波后的图像subplot(2,2,4);imshow(K);title('5*5模板滤波后的后的图像');2. 自己编写程序对图像进行噪声污染和滤波:clcclear allrow=512;%图像的行像素点col=512;%图像的列像素点n1=3;n2=5;N1=zeros(n1*n1);%申明3*3模版,且初始化N2=zeros(n2*n2);%申明5*5模版,且初始化%读入位于D盘\tuxiang的lena图像A=imread('D:\tuxiang\lena.bmp');%将读入的彩色图像转化为灰度图像B=rgb2gray(A);n=rand(row,col);C=B;%申明被噪声污染后的图像C,且初始化%生成噪声污染图像,达到和系统椒盐噪声污染相同的效果for i=1:rowfor j=1:colif(n(i,j)<=0.1)C(i,j)=0;elseif(n(i,j)>=0.9)C(i,j)=255;endendendendD=C;%申明用3*3模版滤波后的图像D,且初始化E=C;%申明用5*5模版滤波后的图像D,且初始化%用模版为3*3的中值滤波器进行滤波,不考虑边缘for x=2:row-1for y=2:col-1N1=[C(x-1,y-1:y+1),C(x,y-1:y+1),C(x+1,y-1:y+1)];N1=sort(N1);D(x,y)=N1((n1*n1+1)/2);endend%用模版为5*5的中值滤波器进行滤波,不考虑边缘for x=3:row-2for y=3:col-2N2=[C(x-2,y-2:y+2),C(x-1,y-2:y+2),C(x,y-2:y+2),C(x+1,y-2:y+2),C(x+2,y-2:y+2)]; N2=sort(N2);E(x,y)=N2((n2*n2+1)/2);endend%绘制原始图像、被噪声污染后的图像及用两种模版滤波后的图像figuresubplot(2,2,1);imshow(B);title('原始图像');subplot(2,2,2);imshow(C);title('噪声污染后的图像');subplot(2,2,3);imshow(D);title('3*3模版滤波后的图像');subplot(2,2,4);imshow(E);title('5*5模版滤波后的图像');实验结果(一)用系统函数对图像进行噪声污染和滤波:1.在原始图像上所加的噪声为方差为0.2的椒盐噪声,分别用模板为3*3的中值滤波器和模板为5*5的中值滤波器对加噪声后的图像进行空间滤波2.在原始图像上所加的噪声为方差为0.5的椒盐噪声,分别用模板为3*3的中值滤波器和模板为5*5的中值滤波器对加噪声后的图像进行空间滤波3.在原始图像上所加的噪声为均值为0、方差为0.05的椒盐噪声,分别用模板为3*3的中值滤波器和模板为5*5的中值滤波器对加噪声后的图像进行空间滤波(二)自己编写程序对图像进行噪声污染和滤波:实验结果分析1.图像在同种椒盐噪声污染的情况下,用模板为5*5的中值滤波器对被噪声污染后的图像进行空间滤波,效果比模板为3*3的中值滤波器好;因为在一定范围内增大滤波器模板的半径,其半径范围内的图像像素点都被污染的概率减小。
均值滤波的实验报告引言在图像处理领域,均值滤波是一种常用的图像平滑方法。
它通过计算像素周围邻域的平均值来替代该像素的灰度值,以达到图像平滑的效果。
均值滤波可以有效地去除图像中的噪声,同时也能够保持图像的整体特征。
本实验旨在探究均值滤波对图像的影响,并比较不同滤波半径下的滤波效果。
实验步骤1. 实验环境准备:在计算机上安装图像处理软件,并导入实验所需图像。
2. 实验设计:选择适当大小的滤波半径,并记录下实验所用的滤波半径。
3. 均值滤波处理:对图像进行均值滤波处理,根据实验设置的滤波半径计算每个像素的邻域平均灰度值,并用该平均值替代原像素的灰度值。
4. 实验结果观察:观察并记录均值滤波后的图像效果,包括图像的平滑度、噪声去除程度等。
5. 不同滤波半径的对比:重复步骤3-4,使用不同的滤波半径进行均值滤波处理,比较不同半径下的滤波效果。
6. 结果分析:根据实验观察和对比结果,分析均值滤波在不同滤波半径下的优缺点。
实验结果经过实验,我们得到了以下结果:实验图像下图为实验所用原始图像,以及采用不同滤波半径进行均值滤波处理后的图像。
结果观察通过对比实验图像,我们可以得到以下观察结果:1. 均值滤波能够有效地去除图像中的噪声,使图像更加平滑。
2. 随着滤波半径的增加,图像的平滑度增加,噪声去除程度也更好。
3. 但是,当滤波半径较大时,图像细节会被模糊化,失去一部分细节信息。
结果分析根据实验结果观察,我们可以得出以下分析结论:1. 均值滤波对图像处理中的噪声去除具有较好的效果,能够使图像更加平滑。
2. 滤波半径的选择对均值滤波的效果有重要影响。
实验三1.实验目的:(1)对指定图像进行均值、中值滤波增强,比较增强的效果;(2)对图片进行噪声处理,进行图像恢复;2.实验内容:对指定图像进行均值、中值滤波增强,比较增强的效果。
图1是一张原始人物图像,图2是一张近似20%像素带有冲激噪声后的人物图像。
现分别利用①5×5区域的邻域平均法和②5×5中值滤波法对图2进行去噪声处理,进行图像恢复。
将原始图像及增强后的图像都显示于屏幕上,观察两种方法对去噪的不同作用。
图1图23.实验结果(代码&结果可视化)1、利用已有的图像处理应用软件集成环境编写相应的平滑程序。
5×5邻域平均法:邻域平均是最简单的平滑滤波,即是将原图的一个像素的灰度值和它周围邻近的24个像素的灰度值相加,然后求得的平均值作为新图该像素的灰度值。
具体算法类似与图像锐化。
5×5中值滤波法:采用滑动窗口法设窗口为5×5 的矩形,该窗口在被处理的图像上逐点移动内含25个像素,每次移动均计算一次中值,赋给窗口中间点,作为其灰度,具体算法类似邻域平均。
2、核心程序:邻域平均核心算法类似梯度锐化,本报告只给出中值滤波的核心程序:// 开始中值滤波// 行(除去边缘几行)for(i = iFilterMY; i < lHeight - iFilterH + iFilterMY + 1; i++){// 列(除去边缘几列)for(j = iFilterMX; j < lWidth - iFilterW + iFilterMX + 1; j++){// 指向新DIB第i行第j个像素的指针lpDst = (unsigned char*)lpNewDIBBits + lLineBytes * (lHeight - 1 - i) + j;// 读取滤波器数组for (k = 0; k < iFilterH; k++){for (l = 0; l < iFilterW; l++){lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i + iFilterMY - k) + j - iFilterMX + l;// 保存像素值aValue[k * iFilterW + l] = *lpSrc;}}// 获取中值* lpDst = GetMedianNum(aValue, iFilterH * iFilterW);}}4.实验分析和总结采用滤波器(低频/高频)处理后的图像可以更加平滑,可以对图像去除噪音,恢复到原始图像。
实验数字图像的空间域滤波
一、实验目的
1、理解图像空间域滤波的原理;
2、掌握图像均值滤波、中值滤波的原理与实现方法;
3、掌握上述方法的改进方法。
二、实验原理
均值滤波的主要步骤为:
(1)将模板在途中漫游,并将模板中心与途中某个象素位置重合;(2)将模板上系数与模板下对应象素相乘;
(3)将所有乘积相加;
(4)将和(模板的输出响应)赋给途中对应模板中心位置的象素。
中值滤波的主要步骤为:
(1)将模板在途中漫游,并将模板中心与途中某个象素位置重合;(2)读取模板下各对应象素的灰度值;
(3)将这些灰度值从小到大排成1列;
(4)找出这些值里排在中间的1个;
(5)将这个中间值赋给对应模板中心位置的象素。
三、实验内容
基本要求:
1、自己编程实现图像的均值滤波;
2、自己编程实现图像的中值滤波;
3、利用matlab图像处理工具箱中的函数实现图像的上述处理;
扩展要求:
4、实现一种图像加权中值滤波或加权均值滤波;
四、实验步骤
1、编程实现图像的均值滤波
程序代码:
运行程序得到如下结果:
2、编程实现图像的中值滤波
程序代码:
运行程序后得到如下结果:
3、实现一种图像加权中值滤波或加权均值滤波设计x模板为:
运行程序可得均值滤波后的结果:
运行程序可得中值滤波后的结果:
五、实验结果分析
从实验结果可以看出,中值滤波较均值滤波效果好些,并且滤波与所选的模板有关,若选择权值相同(本实验为0.1/9)相对不同权值的效果好些。
模板的不同对均值滤波的影响较大。
数字图像处理实验三均值滤波、中值滤波的计算机实现12281166 崔雪莹计科1202 班一、实验目的:1)熟悉均值滤波、中值滤波处理的理论基础;2)掌握均值滤波、中值滤波的计算机实现方法;3)学习VC++ 6。
0 的编程方法;4)验证均值滤波、中值滤波处理理论;5)观察均值滤波、中值滤波处理的结果。
二、实验的软、硬件平台:硬件:微型图像处理系统,包括:主机,PC机;摄像机;软件:操作系统:WINDOWS2000或WINDOWSXP应用软件:VC++6.0三、实验内容:1)握高级语言编程技术;2)编制均值滤波、中值滤波处理程序的方法;3)编译并生成可执行文件;4)考察处理结果。
四、实验要求:1)学习VC+确6。
0编程的步骤及流程;2)编写均值滤波、中值滤波的程序;3)编译并改错;4)把该程序嵌入试验二给出的界面中(作适当修改);5)提交程序及文档;6)写出本次实验的体会。
五、实验结果截图实验均值滤波采用的是3X3的方块,取周围的像素点取得其均值代替原像素点。
边缘像素的处理方法是复制边缘的像素点,增加一个边框,计算里面的像素值得均值滤波。
均值氓浜1W赵六、实验体会本次实验在前一次的实验基础上增加均值滤波和中值滤波,对于椒盐噪声的处理,发现中值滤波的效果更为好一点,而均值滤波是的整个图像变得模糊了一点,效果差异较大。
本次实验更加增加了对数字图像处理的了解与学习。
七、实验程序代码注释及分析// HistDemoADIg.h :头文件//#in elude "ImageWnd.h"#pragma once// CHistDemoADIg 对话框classCHistDemoADIg : public CDialogEx{//构造public:CHistDemoADlg(CWnd* pParent = NULL); // 标准构造函数intnWidth;intnHeight;intnLen;intnByteWidth;BYTE *lpBackup;BYTE *lpBitmap;BYTE *lpBits;CStringFileName;CImageWndsource,dest;// 对话框数据enum { IDD = IDD_HISTDEMOA_DIALOG };protected:virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持// 实现protected:HICON m_hIcon;// 生成的消息映射函数virtual BOOL OnInitDialog();afx_msg void OnSysCommand(UINT nID, LPARAM lParam);afx_msg void OnPaint();afx_msg HCURSOR OnQueryDragIcon();DECLARE_MESSAGE_MAP()public:voidLoadBitmap(void);afx_msg void OnOpen();afx_msg void OnHist();voidHistogramEq(void);voidNoColor(void);void HistogramEq1(intnWidth,intnHeight,BYTE *lpInput,BYTE *lpOutput);voidMeanFilter(intnWidth,intnHeight,BYTE *lpInput,BYTE *lpOutput);voidMedianFilter(intnWidth,intnHeight,BYTE *lpInput,BYTE *lpOutput); afx_msgvoid OnBnClickedClose();afx_msg void OnBnClickedMeanfilter();afx_msg void OnBnClickedMedianfilter();};HistDemoADlg.cpp 对HistDemoADlg.h 进行具体的实现,OnOpen() 函数响应ID 为IDC_OPEN的按钮事件,而且会调取文件选择对话框,选取文件之后,会显示在原始图像区域显示对应的位图图像,OnHist()函数会响应ID为IDC_HIST的按钮事件,调用HistogramEq()进行直方图均衡化的处理,HistogramEq()会调用HistogramEq1()进行直方图均衡化的处理,并用dst.setlmage()显示处理之后的图像,以及NoColor()函数,对原始图像转化为灰度图像之后再显示。
// HistDemoADlg.cpp : 实现文件//#include "stdafx.h"#include "HistDemoA.h"#include "HistDemoADlg.h"#include "afxdialogex.h"#ifdef _DEBUG#define new DEBUG_NEW#endif#define Point(x,y) lpPoints[(x)+(y)*nWidth]#define Point1(x,y) lpPoints1[(x)+(y)*nWidth]// 用于应用程序“关于”菜单项的CAboutDlg 对话框classCAboutDlg : public CDialogEx{public:CAboutDlg();// 对话框数据enum { IDD = IDD_ABOUTBOX };protected:virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV 支持// 实现protected:DECLARE_MESSAGE_MAP()};CAboutDlg::CAboutDlg() : CDialogEx(CAboutDlg::IDD)voidCAboutDlg::DoDataExchange(CDataExchange* pDX) {CDialogEx::DoDataExchange(pDX);}BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx) END_MESSAGE_MAP() // CHistDemoADlg 对话框CHistDemoADlg::CHistDemoADlg(CWnd* pParent /*=NULL*/): CDialogEx(CHistDemoADlg::IDD, pParent){m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);lpBitmap = 0;lpBackup = 0;}voidCHistDemoADlg::DoDataExchange(CDataExchange* pDX){ CDialogEx::DoDataExchange(pDX);}BEGIN_MESSAGE_MAP(CHistDemoADlg, CDialogEx)ON_WM_SYSCOMMAND()ON_WM_PAINT()ON_WM_QUERYDRAGICON()ON_BN_CLICKED(IDC_OPEN, &CHistDemoADlg::OnOpen)ON_BN_CLICKED(IDC_HIST, &CHistDemoADlg::OnHist)ON_BN_CLICKED(IDCLOSE, &CHistDemoADlg::OnBnClickedClose)ON_BN_CLICKED(IDC_MEANFILTER, &CHistDemoADlg::OnBnClickedMeanfilter)ON_BN_CLICKED(IDC_MEDIANFILTER,&CHistDemoADlg::OnBnClickedMedianfilter)END_MESSAGE_MAP() // CHistDemoADlg 消息处理程序BOOL CHistDemoADlg::OnInitDialog(){CDialogEx::OnInitDialog();// 将“关于...”菜单项添加到系统菜单中。
// IDM_ABOUTBOX 必须在系统命令范围内。
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);ASSERT(IDM_ABOUTBOX < 0xF000);CMenu* pSysMenu = GetSystemMenu(FALSE);if (pSysMenu != NULL){BOOL bNameValid;CStringstrAboutMenu;bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);ASSERT(bNameValid);if (!strAboutMenu.IsEmpty()){ pSysMenu->AppendMenu(MF_SEPARATOR);pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);}}// 设置此对话框的图标。
当应用程序主窗口不是对话框时,框架将自动// 执行此操作SetIcon(m_hIcon, TRUE); // 设置大图标SetIcon(m_hIcon, FALSE); // 设置小图标// TODO: 在此添加额外的初始化代码source.Create(0,L"Source",WS_CHILD|WS_VISIBLE,CRect(40,40,360,280),this,10000);dest.Create(0,L"Destination",WS_CHILD|WS_VISIBLE,CRect(400,40,720,280),this ,10001);return TRUE; // 除非将焦点设置到控件,否则返回TRUE}voidCHistDemoADlg::OnSysCommand(UINT nID, LPARAM lParam){if ((nID& 0xFFF0) == IDM_ABOUTBOX){CAboutDlgdlgAbout;dlgAbout.DoModal();}else{CDialogEx::OnSysCommand(nID, lParam);}}// 如果向对话框添加最小化按钮,则需要下面的代码// 来绘制该图标。
对于使用文档/ 视图模型的MFC 应用程序,// 这将由框架自动完成。