




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、word数字图像处理期末大作业一、问题描述实现第十章中采用Hough变换来检测图像中圆的过程。,通过包括平滑把细节去除,边缘检测得到轮廓以及Hough变换得到的圆,并把结果叠加到原来的灰度图像上。给出具体的过程,中间结果,最后结果,实现的代码,并写出报告。二、图片的获取以及预处理针对老师提供的一副硬币图片,要求检测出其中的hough圆,并叠加到原图像上以便增强图像。在检测hough圆之前,首先要对图像进行平滑处理,进行拉普拉斯变换,然后检测垂直方向,水平方向,+45度和-45度方向的边缘,将四个方向的边缘叠加起来,得到总的边缘,对该图像进行二值化,然后对得到的图像检测其hough圆,得到圆形边
2、缘,将该图像叠加到原图像上,就实现了图像边缘增强的目的。3、 图像处理算法的根本原理以及处理结果本实验流程图如下: 开始 读取图像图像预处理 边缘检测 二值化 Hough变换Hough变换结果与原图像相加 结束1.读取图像图像处理的第一步就是对所采集的图像进行读入,本次实验的输入图像是一幅灰度图像,不需要将图像转换成为灰度图像,直接利用函数imread完成。原图像如下所示: 2. 图像预处理在图像预处理中,我们完成了两步工作,首先使用方差为1的高斯噪声对图像进行平滑,然后进行拉普拉斯变换,即,为方差为的高斯噪声,本实验中。又,其中,将和分别进行傅里叶别换,将其逐点相乘,再进行傅里叶反变换,就得
3、到了预处理后的图像。3. 边缘检测对水平,垂直,+45度,-45度方向进行边缘检测,本实验中我们采用了Prewitt梯度算子,它用于检测水平方向,垂直方向,+45度方向和-45度方向的掩膜分别如下: 水平掩膜 垂直掩膜 +45度掩膜 -45度掩膜 使用这四个掩膜分别对上一步得到的图像逐点进行处理,就可以得到四个方向的边缘了本实验中边缘的一个像素都不处理,再将它们加起来,就得到了总的边缘,实验结果如下: 总的边缘如下列图所示:4. 二值化 对上图得到的图像进行二值化,这里我采用的是循环方式确定图像全局阈值,即首先以图像的平均值作为阈值,将图像分成两局部,分别求两局部的平均值,新的阈值为这两个平均
4、值的均值,重复上述过程,直到两次阈值之差小于特定的值时停止,并以最后一次得到的阈值对图像进行二值化,本实验中我要求两次阈值之差小于0.5时停止,最后得到的全局阈值为 -102.1332,二值化后的图像如下所示:5. Hough变换检测圆形边界 Hough 变换的原理就是利用图像全局特征将边缘像素连接起来组成区域封闭边界,它将图像空间转换到参数空间,在参数空间对点进行描述,到达检测图像边缘的目的。该方法把所有可能落在边缘上的点进行统计计算,根据对数据的统计结果确定属于边缘的程度。其实质就是对图像进行坐标变换,把平面坐标变换为参数坐标,使变换的结果更易识别和检测。 Hough变换的根本原理在于,利
5、用点与线的对偶性,将图像空间的线条变为参数空间的聚集点,从而检测给定图像是否存在给定性质的曲线。圆的方程为:(x-a)2+(y-b)2=r2,通过Hough变换,将图像空间对应到参数空间。 把X-Y平面上的圆转换到a-b-r参数空间,那么图像空间中过(x, y)点圆对应参数空间中,高度r变化下的一个三维锥面,如下 同理,过图像空间中任意一点的圆对应于参数空间中的一个三维锥面。因此,过图像空间上同一圆上的点,对应的参数空间中的三维锥面,在r高度必然相交于一点(a, b, r)。这样通过检测这一点可以得到圆的参数,相应的圆也可求得了。图像平面的方程转化为参数平面上的示意图如下图: Hough变换是
6、基于通过提取分布于目标圆周上的参数及点的特征值的来检测圆或圆弧的。为了检测目标外形,对图像上的每点定义一个参数空间的映射。Hough变换通过在参数空间找寻特征(峰值或最大值点)得到位于图像空间中的特征(目标形状)来转换问题。对于半径的圆Hough变换可以检测任意表达形式的曲线,关键在于选择适宜的参数空间。我们可以根据曲线的表达形式决定其参数空间。当检测某一半径的圆时,可以使用与原图像空间相同的空间作为其参数空间。那么原图像空间中的一个圆对应参数空间中的一个点,参数空间的一个点对应图像空间中一个圆,原图像空间中在同一圆上的点,它们的参数相同即a,b相同,它们在参数空间对应的圆就会过同一点a,b,
7、因此,将原图像中的所有点变换到参数空间之后,依据参数空间中点的聚集度就可判断出原图像空间中有无近似于圆的图形。对于未知半径的圆,在一个xy平面图像中确定一个圆至少需要三个元素,即圆心的x轴和y轴坐标,圆的半径,因此Hough变换检测圆的目的就是检测出图像中各个圆的圆心坐标以及圆的半径。其根本思想是将原图像空间中边缘点映射至参数空间中,再将参数空间中得到的全部坐标点元素所对应的累加值进行统计,并根据此累加值来判断圆的大小和圆心的位置。例如,在xy平面上的方程为(x-a)2+(y-b)2=r2 其中点a,b为圆心坐标,r为圆半径,点x,y为圆周上的一点,将其转换为参数坐标系a,b,r,方程为(a-
8、x)2+(b-y)2=r2,可看出次方程为圆锥面,对于原图像中任意确定的一个点在参数空间都有一个三维锥面与其对应。在Hough变换检测圆时,可以利用梯度信息在很大程度上加快圆检测的速度。对圆周而言,其梯度方向只有背离圆心或者指向圆心,当梯度指向圆心,圆心就在梯度的延长线上,而当梯度背离圆心,圆心那么在梯度的反向延长线上。所以,边缘梯度信息的参加可以预估圆心的位置,这样可以使算法的运算量明显减少,并且可以有效抑制虚假局部最大值。圆心位置可以用极坐标方程形式表达: a= x - rco s ( (x , y ) ), a=y - rsin ( (x , y ) )或者a= x+ rco s ( (
9、x , y ) ), a=y+rsin ( (x , y ) ),边缘像素x,y处的梯度方向为 (x , y )。前一组公式是梯度方向背离圆心,后一组为梯度方向指向圆心。以前一种情况为例,边缘图像中每个边缘像素点x,y都可以算出其相应的梯度方向 (x , y )。通过前一个公式可算出圆心坐标a0,b0,对于参数空间可能的半径r0,其相应的参数空间累加器单元加一,最后找到累加器的局部最大值,就得到一个圆。 本实验中,我们检测的圆半径范围为10-100,半径步长为1,角度步长为/18,p=0.7。得到的结果如下: 6. Hough变换结果与原图像相加上一步得到的图像是一副逻辑图像,这一步我们首先判
10、断上一步得到的图像每一个像素是否为1,如果是那么相加后该点的像素值为255,否那么该点的像素值为原图像在该点的像素值,这样就得到了hough变换后图像与原图像相加的图像,结果如下所示:4、 源程序本实验采用matlab来实现,原程序如下所示:clear all;%1.读入图像并显示S=imread(E:Sweden-coins.bmp);figure;imshow(S);title(原图像); %2.引入均值为零,方差为a的高斯噪声对图像进行平滑,然后进行拉普拉斯变换m,n=size(S);a=1;h=zeros(m,n);h=double(h);for i=1:m for j=1:n t=i
11、2+j2; h(i,j)=(t-2*a)*exp(-(t/(2*a)/a2; endendH=fftshift(fft2(h);G=fftshift(fft2(S);W=H.*G;w=ifft2(ifftshift(W);figure;imshow(w);title(平滑后进行拉普拉斯变换后的图像); %3.对水平,垂直,+45度,-45度方向进行边缘检测,采用Prewitt梯度算子IMG=double(w);H1=zeros(m,n);H2=zeros(m,n);G1=zeros(m,n);G2=zeros(m,n);for i=2:m-1 for j=2:n-1 H1(i,j)=-IMG(
12、i-1,j-1)-IMG(i-1,j)-IMG(i-1,j+1)+IMG(i+1,j-1)+IMG(i+1,j)+IMG(i+1,j+1); H2(i,j)=-IMG(i-1,j-1)-IMG(i,j-1)-IMG(i+1,j-1)+IMG(i-1,j+1)+IMG(i,j+1)+IMG(i+1,j+1); G1(i,j)=IMG(i-1,j)+IMG(i-1,j+1)+IMG(i,j+1)-IMG(i,j-1)-IMG(i+1,j-1)-IMG(i+1,j); G2(i,j)=-IMG(i-1,j-1)-IMG(i-1,j)-IMG(i,j-1)+IMG(i+1,j)+IMG(i,j+1)+
13、IMG(i+1,j+1); endendfigure;imshow(H1);title(水平边缘);figure;imshow(H2);title(垂直边缘);figure;imshow(G1);title(-45度边缘);figure;imshow(G2);title(+45度边缘);Z=zeros(m,n);for i=1:m for j=1:n Z(i,j)=H1(i,j)+H2(i,j)+G1(i,j)+G2(i,j); endendfigure;imshow(Z);title(提取的边缘);%4.对提取的边缘进行二值化T=sum(Z(:)/(m*n);T2=20;while T20.
14、5Y1=0;Y2=0;N1=0;N2=0;N1=double(N1);N2=double(N2);Y1=double(Y1);Y2=double(Y2);for i=1:m for j=1:n if(Z(i,j)T) Y1=Y1+double(Z(i,j); N1=N1+1; else Y2=Y2+double(Z(i,j); N2=N2+1; end endendt1=Y1/N1;t2=Y2/N2;T1=(t1+t2)/2;T2=abs(T-T1);T=T1endGS=zeros(m,n);for i=1:m for j=1:n if Z(i,j)T GS(i,j)=0; else GS(i
15、,j)=255; end endendfigure;imshow(GS);title(二值化后的图像); %5.进行hough变换,检测圆形边界BW=double(GS);r_max=100;r_min=10;step_r=1;step_angle=pi/18;p=0.7;size_r = round(r_max-r_min)/step_r)+1;size_angle = round(2*pi/step_angle);hough_space = zeros(m,n,size_r);rows,cols = find(BW);ecount = size(rows);for i=1:ecount f
16、or r=1:size_r for k=1:size_angle a = round(rows(i)-(r_min+(r-1)*step_r)*cos(k*step_angle); b = round(cols(i)-(r_min+(r-1)*step_r)*sin(k*step_angle); if(a0&a0&b=max_para*p);length = size(index);hough_circle = false(m,n);for i=1:ecount for k=1:length par3 = floor(index(k)/(m*n)+1; par2 = floor(index(k
17、)-(par3-1)*(m*n)/m)+1; par1 = index(k)-(par3-1)*(m*n)-(par2-1)*m; if(rows(i)-par1)2+(cols(i)-par2)2(r_min+(par3-1)*step_r)2-5) hough_circle(rows(i),cols(i) = true; end endendfor k=1:length par3 = floor(index(k)/(m*n)+1; par2 = floor(index(k)-(par3-1)*(m*n)/m)+1; par1 = index(k)-(par3-1)*(m*n)-(par2-
18、1)*m; par3 = r_min+(par3-1)*step_r; fprintf(1,Center %d %d radius %dn,par1,par2,par3); para(:,k) = par1,par2,par3;endfigure;imshow(hough_circle);title(hough变化后的图像); %6.将hough变化后提取的图像与原图像相加,增强其边缘LST=zeros(m,n);for i=1:m for j=1:n if hough_circle(i,j)=1; LST(i,j)=255; else LST(i,j)=S(i,j); end endendfigure;imshow(LST,);title(最终的结果);5、 心得体会我们选择用MATLAB来编写,因为感觉自己对C等其他语言掌握的不是最熟练的。刚拿到题目的时候我们三个感觉还挺简单的,平滑、边缘检测以及霍夫变换都是上课时候讲过的,可是到真正着手做的时候感觉理论与实践搭不上,很多在理论想清楚,可是一旦到编程实践,有些地方就会无从下手,我们又仔细研究了一下算法,首先使用高斯函数对图像进行平滑,然后进行拉普拉斯变换,对于得到的图像,为了进行边缘检测,经过讨论之后我们选择了Prewi
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 医院新员工入职培训体系
- 城市交通规划历史重点基础知识点
- JavaScript实现网页五子棋小游戏
- 《矿物质与健康》课件
- 《企业数字化转型之课件解决方案》课件
- 【培训课件】如何提升顾问单位的满意度与服务品质
- 进校陪读协议书范本
- 车站管理协议书范本
- 湖北中考英语试题单选题100道及答案
- 足浴店购销合同协议
- 献血法知识试题及答案
- 高通量透析与血液透析滤过介绍
- 宁波2025年宁波海洋经济发展示范区象山县高层次紧缺人才选聘笔试历年参考题库附带答案详解
- T-WSJD 21-2022 内镜储存干燥柜卫生要求
- 煤矿井下辅助运输设计规范
- 2025-2030中国聚丙烯三元共聚物行业市场发展趋势与前景展望战略研究报告
- 2025年上半年苏州太仓临港投资发展集团限公司公开招聘工作人员易考易错模拟试题(共500题)试卷后附参考答案
- 工业自动化控制系统调试与维护题库
- 2025届广东省佛山市高三语文二模高分范文12篇:“成长最大的悲哀是失去了想象力”
- 2025年合肥高新美城物业有限公司招聘30人笔试参考题库附带答案详解
- 2025届陕西省高考适应性检测(三)物理试题+答案
评论
0/150
提交评论