光学图像处理实验报告
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
光学图像处理实验报告
第一篇:光学图像处理实验报告
光学图像处理实验报告
直方图均衡化的研究
一、摘要
直方图均衡化就是把一已知灰度概率分布的图像经过一种变换,使之演变成一幅具有均匀灰度概率分布的新图像。
它是以累积分布函数变换法为基础的直方图修正法。
分析和总结灰度直方图的均衡化算法并通过VC++实验验证该方法能有效达到图像增强的目的。
对于较为暗淡的图像,采用直方图均衡化能够增强其整体对比度,获的较为理想的观察效果。
二、关键字
灰度统计
直方图
均衡化
三、实验原理
1、直方图的理论基础:
(1)直方图概念:灰度直方图表示图像中每种灰度出现的频率。
(2)直方图的作用:反映一幅图像的灰度分布特性
n(3)直方图的计算:
p(rk)=k0≤rk≤1k=0,1,2,Λ,l-1 n式中:nk为图像中出现rk级灰度的像素数,n是图像像素总数,而nk/n即为频数。
2、设计目的:产生一幅灰度级分布具有均匀概率密度的图像,扩展像素取值的动态范围,达到了图象增强的目的。
3、直方图均衡化的效果:
1)变换后直方图趋向平坦,灰级减少,灰度合并。
2)原始象含有象素数多的几个灰级间隔被拉大了,压缩的只是象素数少的几个灰度级,实际视觉能够接收的信息量大大地增强了,增加了图象的反差。
同时,也增加了图象的可视粒度。
4、离散情况下的直方图均衡化的算法:
A、列出原始图像的灰度级 fj,j=0,1,Λ,L-1
B、统计各灰度级的像素数目 nj,j=0,1,Λ,L-1
C、计算原始图像直方图各灰度级的频数 Pf(fj)=nj/n,j=0,1,Λ,L-1
kD、计算累积分布函数 C(f)=j=0Pf(fj),j=0,1,Λ,k,ΛL-1
F、应用以下公式计算映射后的输出图像的灰度级,P为输出图像灰度级的个数,其中INT为取整符号:
gi=INT[(gmax-gmin)C(f)+gmin+0.5] G、用的映射关系修改原始图像的灰度级,从而获得直方图近似为均匀分布的输出图像。
∑
四、实验内容及源程序
1、灰度分布密度的统计程序代码如下:
/*********************************************** *函数名称:ZhiFangTu(float *tongji)*函数类型:void *变量说明:tongji,灰度分布密度统计 *功能:对图像进行灰度直方图统计
***********************************************/ void CAAAView::OnZhifangtu(float *tongji){ // TODO: Add your command handler code here
int huidu[256];//灰度计数
CAAADoc* pDoc = GetDocument();
LPSTR lpDIB;LPSTR
lpDIBBits;
lpDIB =(LPSTR)::GlobalLock((HGLOBAL)pDoc->GetHDIB());
lpDIBBits = ::FindDIBBits(lpDIB);//原图数据区指针
int iH,iW;memset(huidu,0,sizeof(huidu));//变量初始化
iH = ::DIBHeight(lpDIB);//宽
iW = ::DIBWidth(lpDIB);//长
LPBYTE temp1=new BYTE[iH*iW];//新图像缓冲区
memcpy(temp1,lpDIBBits,iH*iW);//复制原图像到缓冲区
for(int i=0;i
{ for(int j=0;j
{
unsigned char temp;
temp=temp1[iW*i+j];//灰度统计计数
huidu[temp]++;} } for(i=0;i<256;i++)//统计灰度分布密度
tongji[i]=huidu[i]/(iH*iW*1.0f);}
2、直方图分布的均衡化
(1)统计直方图数组,用一个数组p记录p[i];(2)i从1开始,令s[i]=s[i-1]+p[i];
(3)一个数组L记录新的s的索引值,即令L[i]=s[i]*(256-1);
(4)依次循环每个像素,取原图的像素值作为数组L的下标值,取该下标值对应的数组值作为均衡化之后的像素值。
程序代码如下:/*********************************************** *函数名称:zhifangtujunheng *函数类型:void *变量说明:无
*功能:对图像进行灰度分布均衡化处理
***********************************************/ void CAAAView::OnZhifangtujunheng(){ // TODO: Add your command handler code here CAAADoc* pDoc = GetDocument();
LPSTR lpDIB;LPSTR
lpDIBBits;
lpDIB =(LPSTR)::GlobalLock((HGLOBAL)pDoc->GetHDIB());
lpDIBBits = ::FindDIBBits(lpDIB);//原图数据区指针
float Hdmd[256];//灰度密度
float temp[256];//中间变量
int a[256];long i,j;memset(temp,0,sizeof(temp));//初始化
OnZhifangtu(Hdmd);//获取图像的灰度密度分布
for(i=0;i<256;i++)//进行均衡化处理
{
if(i==0)
{
temp[0]=Hdmd[0];
}
else
{
temp[i]=temp[i-1]+Hdmd[i];
}
a[i]=(int)(255.0f*temp[i]+0.5f);}
long iH,iW;
iH = ::DIBHeight(lpDIB);//宽
iW = ::DIBWidth(lpDIB);//长
for(i=0;i
{ for(j=0;j
{ unsigned char temp1;//将转换后的灰度分布写入dib图像
temp1=*(lpDIBBits+i*iW+j);
*(lpDIBBits+i*iW+j)=a[temp1];} } pDoc->UpdateAllViews(NULL);::GlobalUnlock((HGLOBAL)pDoc->GetHDIB());EndWaitCursor();}
五、实验结果的分析与比较
a原图如下所示:
b均衡后的结果如下:
结论:图像直方图趋于平坦化,且灰度间隔被拉大,从而有利于图像的分析和识别。
对于较为暗淡的图像,采用直方图均衡化能够增强其整体对比度,获的较为理想的观察效果。
六、参考文献
VC++图像处理程序设计(第二版)(杨淑莹等编著)
第二篇:数字图像处理实验报告
数字图像处理
实验报告
目录
1.数字图像处理简介
2.实验目的
3.实验内容
4.实验结果及代码展示
5.算法综述
6.Matlab优势
7.总结
8.存在问题
一、数字图像处理简介
图像处理,是对图像进行分析、加工、和处理,使其满足视觉、心理以及其他要求的技术。
图像处理是信号处理在图像域上的一个应用。
目前大多数的图像是以数字形式存储,因而图像处理很多情况下指数字图像处理。
此外,基于光学理论的处理方法依然占有重要的地位。
图像处理是信号处理的子类,另外与计算机科学、人工智能等领域也有密切的关系。
传统的一维信号处理的方法和概念很多仍然可以直接应用在图像处理上,比如降噪、量化等。
然而,图像属于二维信号,和一维信号相比,它有自己特殊的一面,处理的方式和角度也有所不同。
二、实验目的
巩固所学知识,提高所学能力
三、实验内容
利用matlab的GUI程序设计一个简单的图像处理程序,并含有如下基本功能:1.读入一幅RGB图像,变换为灰度图像和二值图像,并在同一个窗口内分成三个子窗口来分别显示RGB图像和灰度图像,注上文字标题 2.对给定图像进行旋转
3.对给定的图像添加噪声(椒盐噪声、高斯噪声)
四、实验结果及代码展示
1.软件设计界面
2.各模块功能展示以及程序代码
(1)读入一幅RGB图像,变换为灰度图像和二值图像,并在同一个窗口内分成三个子窗口来分别显示RGB图像和灰度图像,注上文
字标题
效果展示:
代码:
a = imread('C:Documents and SettingsAdministrator桌面数字图像舞美.JPG');
i = rgb2gray(a);I = im2bw(a,0.5);
subplot(3,1,1);imshow(a);title('源图像')subplot(3,1,2);imshow(i);title('灰度图像')subplot(3,1,3);imshow(I);title('二值图像')
(2)图像旋转原图
效果展示:
代码:
clc;clear all;close all;
Img=imread('D:My DocumentsMy Pictures5.JPG');Img=double(Img);[h w]=size(Img);alpha=pi/4;
wnew=w*cos(alpha)+h*sin(alpha);hnew=w*sin(alpha)+h*co s(alpha);wnew=ceil(wnew);
hnew=ceil(hnew);u0=w*sin(alpha);
T=[cos(alpha),sin(alpha);-
sin(alpha),cos(alpha)];Imgnew2=zeros(hnew,wnew);Imgnew1=ze ros(hnew,wnew);for u=1:hnew
for v=1:wnew
tem=T*([u;v]-[u0;0]);x=tem(1);y=tem(2);if
x>=1&&x<=h&&y>=1&&y<=w
x_low=floor(x);x_up=ceil(x);y_low=floor(y);y_up=ceil(y);if(x-
x_low)<=(x_up-x)x=x_low;
else
x=x_up;
end
if(y-y_low)<=(y_up-y)y=y_low;
else
y=y_up;
end
p1=Img(x_low,y_low);p2=Img(x_up,y_low);p3=Img(x_low,y_l ow);p4=Img(x_up,y_up);s=x-x_low;t=y-
y_low;Imgnew1(u,v)=Img(x,y);
Imgnew2(u,v)=(1-s)*(1-t)*p1+(1-s)*t*p3+(1-
t)*s*p2+s*t*p4;end
end end
figure;imshow(Imgnew2,[]);B=imrotate(Img,alpha/pi*180);fi gure;imshow(B,[]);
(3)对给定的图像添加噪声(斑点噪声、高斯噪声)效果展示:代码:
I= imread('D:My DocumentsMy Pictures5.JPG');figure,subplot(211);imshow(I);title('原图');J1=imnoise(I,'gaussian',0,0.02);
subplot(223);imshow(J);title('添加高斯噪声');J=imnoise(I,'speckle',0.04);
subplot(224);imshow(J);title('添加斑点噪声');
五、算法综述灰度图像:
一幅完整的图像,是由红色、绿色、蓝色三个通道组成的。
红色、绿色、蓝色三个通道的缩览图都是以灰度显示的。
用不同的灰度色阶来表示“ 红,绿,蓝”在图像中的比重。
通道中的纯白,代表了该色光在此处为最高亮度,亮度级别是255。
通道是整个Photoshop显示图像的基础。
色彩的变动,实际上就是间接在对通道灰度图进行调整。
通道是Photoshop处理图像的核心部分,所有的色彩调整工具都是围绕在这个核心周围使用的。
在计算机领域中,灰度数字图像是每个像素只有一个采样颜色的图像。
这类图像通常显示为从最暗黑色到最亮的白色的灰度,尽管理论上这个采样可以任何颜色的不同深浅,甚至可以是不同亮度上的不
同颜色。
灰度图像与黑白图像不同,在计算机图像领域中黑白图像只有黑色与白色两种颜色;灰度图像在黑色与白色之间还有许多级的颜色深度。
但是,在数字图像领域之外,“黑白图像”也表示“灰度图像”,例如灰度的照片通常叫做“黑白照片”。
在一些关于数字图像的文章中单色图像等同于灰度图像,在另外一些文章中又等同于黑白图像。
灰度图像经常是在单个电磁波频谱如可见光内测量每个像素的亮度得到的。
用于显示的灰度图像通常用每个采样像素8 位的非线性尺度来保存,这样可以有256 级灰度。
这种精度刚刚能够避免可见的条带失真,并且非常易于编程。
在医学图像与遥感图像这些技术应用中经常采用更多的级数以充分利用每个采样 10 或 12 位的传感器精度,并且避免计算时的近似误差。
在这样的应用领域每个采样 16 位即 65536 级得到流行。
二值图像:
是指每个像素不是黑就是白,其灰度值没有中间过渡的图像。
二值图像一般用来描述文字或者图形,其优点是占用空间少,缺点是,当表示人物,风景的图像时,二值图像只能描述其轮廓,不能描述细节。
这时候要用更高的灰度级。
二值图像是每个像素只有两个可能值的数字图像。
人们经常用黑白、B&W、单色图像表示二值图像,但是也可以用来表示每个像素只有一个采样值的任何图像,例如灰度图像等。
二值图像中所有的像素只能从0和1这两个值中取,因此在MATLAB中,二值图像用一个由0和1组成的二维矩阵表示。
这两个可取的值分别对应于关闭和打开,关闭表征该像素处于背景,而打开表征该像素处于前景。
以这种方式来操作图像可以更容易识别出图像的结构特征。
二值图像操作只返回与二值图像的形式或结构有关的信息,如果希望对其他类型的图像进行同样的操作,则首先要将其转换为二进制的图像格式,可以通过调用MATLAB提供的im2bw()来实现。
二值图像经常出现在数字图像处理中作为图像掩码或者在图像分
割、二值化和dithering的结果中出现。
一些输入输出设备,如激光打印机、传真机、单色计算机显示器等都可以处理二值图像。
二值图像经常使用位图格式存储。
二值图像可以解释为二维整数格Z,图像变形处理领域很大程度上就是受到这个观点启发。
图像旋转:
图像旋转是指图像以某一点为中心旋转一定的角度,形成一幅新的图像的过程。
当然这个点通常就是图像的中心。
既然是按照中心旋转,自然会有这样一个属性:旋转前和旋转后的点离中心的位置不变.根据这个属性,我们可以得到旋转后的点的坐标与原坐标的对应关系。
由于原图像的坐标是以左上角为原点的,所以我们先把坐标转换为以图像中心为原点。
假设原图像的宽为w,高为h,(x0,y0)为原坐标内的一点,转换坐标后的点为(x1,y1)。
那么不难得到: x1 = x0-w/2;y1 =-y0 + h/2;在新的坐标系下,假设(x0,y0)距离原点的距离为r,点与原点之间的连线与x轴的夹角为b,旋转的角度为a,旋转后的点为(x1,y1)噪声:
是电路或系统中不含信息量的电压或电流。
在工业与自然界中,存在着各种干扰源(噪声源),如大功率电力电子器件的接入、大功率用电设备的开启与断开、雷击闪电等都会使空间电场和磁场产生有序或无序的变化,这些都是干扰源(或噪声源)。
这些源产生的电磁波或尖峰脉冲通过磁、电耦合或是通过电源线等路径进入放大电路,各种电气设备,形成各种形式的干扰。
斑点噪声:
斑点噪声是SAR成像系统的一大特色,源自基本分辨单元内地物的随机散射,在图像上表现为信号相关(如在空间上相关)的小斑点,它既降低了图像的画面质量,又严重影响图像的自动分割、分类、目标检测以及其它定量专题信息的提取。
SAR图像斑点噪声的去除一方面要抑制图像均匀区域斑点噪声,另一方面要保持图像边缘和纹理细节信息。
SAR斑点噪声的抑制可通过非相干多视处理,也可使用空间域滤波实现。
非相干多视处理会降
低图像的地面分辨率。
因此,涌现出了一系列空间域滤波方法,如均值滤波、中值滤波、Lee滤波、Kuan滤波、Frost滤波、Sigma滤波以及Gamma Map滤波等。
但这类算法存在自身无法克服的矛盾:一方面为增强斑点去噪效果需选较大的滤波窗口,另一方面为保持图像的实际分辨率要求所选的窗口较小。
高斯噪声:
所谓高斯噪声是指它的概率密度函数服从高斯分布(即正态分布)的一类噪声。
如果一个噪声,它的幅度分布服从高斯分布,而它的功率谱密度又是均匀分布的,则称它为高斯白噪声。
高斯白噪声的二阶矩不相关,一阶矩为常数,是指先后信号在时间上的相关性。
高斯白噪声包括热噪声和散粒噪声。
实验中是通过MATLAB自带的函数产生噪声,各函数如下:J1=imnoise(I,'salt & pepper',0.05);%添加椒盐噪声
J2=imnoise(I,'gaussian',0,0.03);
%添加均值为0,方差为0.03的高斯噪声。
六、Matlab优势
MATLAB是一个包含大量算法的集合。
其可以快捷的实现用户所需的各种计算功能。
函数中所使用的算法都是科研和工程计算中的最新研究成果,而前经过了各种优化和差错处理。
在通常情况下,可以用它来代替底层编程语言,如C和C++。
在计算要求相同的情况下,使用MATLAB的编程工作量会大大减少。
MATLAB的这些函数集包括从最简单最基本的函数到诸如矩阵,特征向量、快速傅立叶变换的复杂函数。
函数所能解决的问题其大致包括矩阵运算和线性方程组的求解、微分方程及偏微分方程的组的求解、符号运算、傅立叶变换和数据的统计分析、工程中的优化问题、稀疏矩阵运算、复数的各种运算、三角函数和其他初等数学运算、多维数组操作以及建模动态仿真等。
图形处理功能
图形处理功能MATLAB自产生之日起就具有方便的数据可视化功能,以将向量和矩阵用图形表现出来,并且可以对图形进行标注和打印。
高层次的作图包括二维和三维的可视化、图象处理、动画和表达
式作图。
可用于科学计算和工程绘图。
新版本的MATLAB对整个图形处理功能作了很大的改进和完善,使它不仅在一般数据可视化软件都具有的功能(例如二维曲线和三维曲面的绘制和处理等)方面更加完善,而且对于一些其他软件所没有的功能(例如图形的光照处理、色度处理以及四维数据的表现等),MATLAB同样表现了出色的处理能力。
同时对一些特殊的可视化要求,例如图形对话等,MATLAB也有相应的功能函数,保证了用户不同层次的要求。
另外新版本的MATLAB还着重在图形用户界面(GUI)的制作上作了很大的改善,对这方面有特殊要求的用户也可以得到满足
模块集合工具箱
MATLAB对许多专门的领域都开发了功能强大的模块集和工具箱。
一般来说,它们都是由特定领域的专家开发的,用户可以直接使用工具箱学习、应用和评估不同的方法而不需要自己编写代码。
目前,MATLAB已经把工具箱延伸到了科学研究和工程应用的诸多领域,诸如数据采集、数据库接口、概率统计、样条拟合、优化算法、偏微分方程求解、神经网络、小波分析、信号处理、图像处理、系统辨识、控制系统设计、LMI控制、鲁棒控制、模型预测、模糊逻辑、金融分析、地图工具、非线性控制设计、实时快速原型及半物理仿真、嵌入式系统开发、定点仿真、DSP与通讯、电力系统仿真等,都在工具箱(Toolbox)家族中有了自己的一席之地。
七、总结
运用matlab软件对图像进行处理,让我巩固了之前所学的知识,同时也在这次作业中更加了解到matlab语言在生活中的运用环境和掌握这门语言的重要性
八、存在问题
1.在进行图像增强时要不要讲图像先进行平滑处理?
2.如何增加这个算法的准确度
3.在此次作业中,为何添加椒盐噪声时无法显示
第三篇:数字图像处理实验报告
数字图像处理
实验报告
班级:通信103 学号:201027201 姓名:计富威指导教师:孙洁
实验一 MATLAB数字图像处理初步
一、实验目的与要求
1.熟悉及掌握在MATLAB中能够处理哪些格式图像。
2.熟练掌握在MATLAB中如何读取图像。
3.掌握如何利用MATLAB来获取图像的大小、颜色、高度、宽度等等相关信息。
4.掌握如何在MATLAB中按照指定要求存储一幅图像的方法。
5.图像间如何转化。
二、实验内容及步骤
1.利用imread()函数读取一幅图像,假设其名为”第一个.tif”,存入一个数组中;
>>I=imread('第一个.tif');2.利用whos命令提取该读入图像”第一个.tif”的基本信息; >>whos I 3.利用imshow()函数来显示这幅图像; >>imshow(I);
第一个.tif 4.利用imfinfo函数来获取图像文件的压缩,颜色等等其他的详细信息;
>>imfinfo('第一个.tif');5.利用imwrite()函数来压缩这幅图象,将其保存为一幅压缩了像素的jpg文件,设为flower.jpg;语法:imwrite(原图像,新图像,‘quality’,q), q取0-100。
>>imwrite(I,'第一个.jpg','quality',50)6.同样利用imwrite()函数将最初读入的tif图象另存为一幅bmp图像,设为flower.bmp。
>>imwrite(I,'第一个.bmp');7.用imread()读入图像:Lenna256.jpg 和camemaman.jpg;>>b=imread('lena256.bmp');>>c=imread('c ameraman.tif');8.用imfinfo()获取图像Lenna256.jpg和camemaman.jpg 的大小;>>imfinfo('lena256.bmp');>>imfinfo('cameraman.tif');9.用figure,imshow()分别将Lenna256.jpg和camemaman.jpg显示出来,
观察两幅图像的质量。
>>figure >>imshow(b);>>figure >>imshow(c);
(Lena256.jpg图像截图)
(cameraman.jpg图像截图)
10.用im2bw将一幅灰度图像转化为二值图像,并且用imshow 显示出来观察图像的特征。
>> d=im2bw(b);>>figure >>imshow(b);>>figure >>imshow(d);
(二值化截图)
三、实验总结
通过实验MatLab软件的基本使用有了基本的了解,学会了使用MatLab软件来读取一个特定格式的图像,并通过相关的命令语句对图像进行格式转换、图像压缩、二值化等的处理,掌握了利用MATLAB 来获取图像的大小、颜色、高度、宽度等等相关信息,掌握在MATLAB中如何通过imshow()语句来读取图像等等。
第二图像基本运算
一、实验目的
1.了解图像的算术运算在数字图像处理中的初步应用。
2.体会图像算术运算处理的过程和处理前后图像的变化。
二、实验原理
图像的代数运算是图像的标准算术操作的实现方法,是两幅输入图像之间进行的点对点的加、减、乘、除运算后得到输出图像的过程。
如果输入图像为A(x,y)和B(x,y),输出图像为C(x,y),则图像的代数运算有如下四种形式:
C(x,y)= A(x,y)+ B(x,y)C(x,y)= A(x,y)-B(x,y)C(x,y)= A(x,y)* B(x,y)C(x,y)= A(x,y)/ B(x,y)
三、实验步骤 1.图像的加法运算
在MATLAB中,如果要进行两幅图像的加法,或者给一幅图像加上一个常数,可以调用imadd函数来实现。
imadd函数将某一幅输入图像的每一个像素值与另一幅图像相应的像素值相加,返回相应的像素值之和作为输出图像。
imadd函数的调用格式如下:
Z = imadd(X,Y)首先读入两幅图像
>>a=imread('第二个原图1.jpg');>>b=imread('第二个原图2.jpg')通过一个加法操作:>> c=imadd(a,b);
给图像的每一个像素加上一个常数可以使图像的亮度增加。
如截图
第一张为原图,第二张为亮度加50,第三张为亮度减50 2.图像的减法运算
在MATLAB中,使用imsubtract函数可以将一幅图像从另一幅图像中减去,或者从一幅图像中减去一个常数。
imsubtract函数将一幅输入图像的像素值从另一幅输入图像相应的像素值中减去,再将这个结果作为输出图像相应的像素值。
imsubtract函数的调用格式如下:Z = imsubtract(X,Y);读入一幅画后通过减法 >>a3=imsubtract(a,50);
3.图像的乘法运算
在MATLAB中,使用immultiply函数实现两幅图像的乘法。
immultiply函数将两幅图像相应的像素值进行元素对元素的乘法操作(MATLAB点乘),并将乘法的运算结果作为输出图形相应的像素值。
immulitply函数的调用格式如下:
Z = immulitply(X,Y)读入一幅图后通过乘法操作>> a=imread('cameraman.tif');>> b=immultiply(a,1.5);
4.图像的除法运算
在MATLAB中使用imdivide函数进行两幅图像的除法。
imdivide函数对两幅输入图像的所有相应像素执行元素对元素的除法操作(点除),并将得到的结果作为输出图像的相应像素值。
imdivide函数的调用格式如下:
Z = imdivide(X,Y)读入一幅图后通过除法操作
四、实验总结
通过对图像的四则运算了结图像的不同变化过程,对软件的进一步使用也有了更加深刻的认识。
实验三图像增强—空域滤波
一、实验目的
进一步了解MatLab软件/语言,学会使用MatLab对图像作滤波处理,使学生有机会掌握滤波算法,体会滤波效果。
了解几种不同滤波方式的使用和使用的场合,培养处理实际图像的能力,并为课堂教学提供配套的实践机会。
二、实验设备与软件
(1)IBM-PC计算机系统
(2)MatLab软件/语言包括图像处理工具箱(Image Processing Toolbox)
(3)实验所需要的图片
三、实验内容与步骤
a)调入并显示原始图像“原图像.jpg”。
>>I=imread('原图像.jpg');b)利用imnoise命令在图像“原图像.jpg”上加入高斯(gaussian)噪声
>>J = imnoise(I,'gauss',0.02);
%添加高斯噪声c)利用预定义函数fspecial命令产生平均(average)滤波器 d)分别采用3x3和5x5的模板,分别用平均滤波器以及中值滤波器,对加入噪声的图像进行处理并观察不同噪声水平下,上述滤波器处理的结果;
>>ave1=fspecial('average',3);
%产生3×3的均值模版 >>ave2=fspecial('average',5);
%产生5×5的均值模版 >>K = filter2(ave1,J)/255;
%均值滤波3×3 >>L = filter2(ave2,J)/255;
%均值滤波5×5 e)选择不同大小的模板,对加入某一固定噪声水平噪声的图像进行处理,观察上述滤波器处理的结果。
>>M = medfilt2(J,[3 3]);
%中值滤波3×3模板 >>N = medfilt2(J,[4 4]);
%中值滤波4×4模板
f)利用imnoise命令在图像Sample2-1.jpg 上加入椒盐噪声(salt & pepper)>>J = imnoise(I,'salt& pepper',0.02);
%添加椒盐噪声
四、实验总结
椒盐噪声是由图像传感器,传输信道,解码处理等产生的黑白相间的亮暗点噪声。
椒盐噪声往往由图像切割引起,去除脉冲干扰及椒盐噪声最常用的算法是中值滤波。
椒盐噪声是指两种噪声,一种是盐噪声,另一种是胡椒噪声。
盐=白色,椒=黑色。
前者是高灰度噪声,后者属于低灰度噪声。
一般两种噪声同时出现,呈现在图像上就是黑白杂点。
这点我们通过实验结果可以明显看到。
中值滤波对于滤除图像的椒盐噪声非常有效。
实验四图像分割
一、实验目的
使用MatLab 软件进行图像的分割。
使学生通过实验体会一些主要的分割算子对图像处理的效果,以及各种因素对分割效果的影响。
二、实验要求
要求学生能够自行评价各主要算子在无噪声条件下和噪声条件下的分割性能。
能够掌握分割条件(阈值等)的选择。
完成规定图像的处理并要求正确评价处理结果,能够从理论上作出合理的解释。
三、实验内容与步骤
(1)使用Roberts 算子的图像分割实验,使用的原图是cameraman.jpg,截图如下
(2)使用Prewitt 算子的图像分割实验截图如下
(3)使用Sobel 算子的图像分割实验
(4)使用LoG(拉普拉斯-高斯)算子的图像分割实验
四、实验结果
对Roberts算子、Prewitt 算子、Sobel 算子、LoG(拉普拉斯-高斯)算子的运算对图像的结果有了基本的认识,加深学习效果。
实验五形态学运算
1、实验目的
学习常见的数学形态学运算基本方法,了解腐蚀、膨胀、开运算、闭运算取得的效果,培养处理实际图像的能力,并为课堂教学提供配
套的实践机会。
2、实验要求
利用MatLab工具箱中关于数学形态学运算的函数,计算本指导书中指定二值图像进行处理。
3、实验设备与软件
1.LC-PC计算机系统
2.MatLab软件/语言包括图像处理工具箱(Image Processing Toolbox)
3.实验所需要的图片
4、实验内容与步骤
1.调入并显示图像“原图.jpg”;
2.调入并显示图像“原图.jpg”;
3.选取合适的阈值,得到二值化图像“原图.jpg”;>>bw = im2bw(I,level);
%二值化 4.设置结构元素;
5.对得到的二值图像“原图.jpg”进行腐蚀运算;>>BW2 = imerode(bw,SE1);
%腐蚀 6.对得到的二值图像“原图.jpg”进行膨胀运算; >>BW1 = imdilate(bw,SE);
%膨胀 7.对得到的二值图像“原图.jpg”进行开运算;
>>BW3 = bwmorph(bw, 'open');
%开运算 8.对得到的二值图像“原图.jpg”进行闭运算; >>BW4 = bwmorph(bw, 'close');
%闭运算 9.将两种处理方法的结果作比较;
五、实验总结
通过本次实验,学习了常见的数学形态学运算基本方法,了解腐蚀、膨胀、开运算、闭运算取得的效果,培养处理实际图像的能力,通过自己动手的实验,对课本上的知识有了更加深刻的理解。
第四篇:数字图像处理实验报告
实验一数字图像的获取
一、实验目的
1、了解图像的实际获取过程。