- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
一.题目
统计图像中火柴的根数
这是我在网上找到火柴的图片。经过我的计数,一共有十五根火柴。
摘要
输入原图像 边缘化 hough变换 合并直线 重构火柴 得出结论
三.理论知识:
边缘化
不同图像灰度不同,边界处一般会有明显的边缘,利用此特征可以分割图像。需要说明的是:边缘和物体间的边界并不等同,边缘指的是图像中像素的值有突变的地方,而物体间的边界指的是现实场景中的存在于物体之间的边界。有可能有边缘的地方并非边界,也有可能边界的地方并无边缘另外,成像过程中的光照和噪声也是不可避免的重要因素。对噪声有抑制作用
?? Prewitt算子是一种一阶微分算子的边缘检测,利用像素点上下、左右邻点的灰度差,在边缘处达到极值检测边缘,去掉部分伪边缘,对噪声具有平滑作用 。其原理是在图像空间利用两个方向模板与图像进行邻域卷积来完成的,这两个方向模板一个检测水平边缘,一个检测垂直边缘。
Hough变换检测直线
Hough变换是图像处理中从图像中识别几何形状的基本方法之一。Hough变换的基本原理在于利用点与线的对偶性,将原始图像空间的给定的曲线通过曲线表达形式变为参数空间的一个点。这样就把原始图像中给定曲线的检测问题转化为寻找参数空间中的峰值问题。也即把检测整体特性转化为检测局部特性,比如直线。
设已知一黑白图像上画了一条直线,要求出这条直线所在的位置。直线的方程是用y=k*x+b来表示,其中k和b是参数,分别是斜率和截距。过某一点(x0,y0)的所有直线的参数都会满足方程y0=kx0+b。即点(x0,y0)确定了一族直线。方程y0=kx0+b在参数k--b平面上是一条直线,(你也可以是方程b=-x0*k+y0对应的直线)。这样,图像x-y平面上的一个前景像素点就对应到参数平面上的一条直线。我们举个例子说明解决前面那个问题的原理。设图像上的直线是y=x,?我们先取上面的三个点:A(0,0),?B(1,1),?C(2,2)。可以求出,过A点的直线的参数要满足方程b=0,?过B点的直线的参数要满足方程1=k+b,?过C点的直线的参数要满足方程2=2k+b,?这三个方程就对应着参数平面上的三条直线,而这三条直线会相交于一点(k=1,b=0)。同理,原图像上直线y=x上的其它点(如(3,3),(4,4)等)?对应参数平面上的直线也会通过点(k=1,b=0)。
Hough变换检测直线思想为:在原始图像坐标系下的一个点对应了参数坐标系中的一条直线,同样参数坐标系的一条直线对应了原始坐标系下的一个点,然后,原始坐标系下呈现直线的所有点,它们的斜率和截距是相同的,所以它们在参数坐标系下对应于同一个点。这样在将原始坐标系下的各个点投影到参数坐标系下之后,看参数坐标系下有没有聚集点,这样的聚集点就对应了原始坐标系下的直线。
合并直线——相似判据
合并的方法是这样的:在检测出已经属于同一根火柴棒的前提下,检测到的长得那根代替短的那根。这样确保一根火柴只有一根线。这样我们在统计火柴个数的时候不会出错。
实验结果分析:
首先读入原始图像
然后利用边缘检测算子Prewitt算子分割图像。虽然有可能有边缘的地方并非边界,也有可能边界的地方并无边缘
第三步:利用hough变换将曲线问题转化为提取峰值点的提取,峰值点个数对应了线段的个数。但是图像经过边缘检测之后所得的图像并不是完美平滑的直线,可能两个峰值代表的是同一根火柴,只是从上图看,他们是断开的。所以提取的峰值点数并不能完全代表火柴的根数,只能算是线段的条数。
在这里,我们可以利用houghlines()函数:
?lines=houghlines(M,theta,rho,peaks,FillGap,35,MinLength,25);
将峰值所对应的线段找到。
?
在这里就需要我们检验同一直线上的线段并将它们合并为一条直线。我们知道火柴是有一定的宽度,换句话说一根火柴可能会检测出两根直线,那么我们就要合并他。如果两个直线两个峰值点对应的rho之差小于某个值约为70,并且两个峰值点对应的theta角度之差小于大概10度,则认为这两个线段是在同一根火柴棒上的。我们这样做还能将火柴提取出来的平行边缘合并,并且合并了属于同一条直线上的间断的线段。
合并的方法是这样的:在检测出已经属于同一根火柴棒的前提下,检测到的长得那根代替短的那根。这样确保一根火柴只有一根线。这样我们在统计火柴个数的时候不会出错。
最后,重构火柴,得出火柴数。我们将保留的线段标记为1,舍弃的标记为0,相加所有的值相加即为火柴的根数。最终火柴数目num=15。
总结感受:
这次大作业让我全面的了解了图像处理,将以前所学只是融汇贯通。就这一次用了很多原理,比如hough变换,边缘提取。尤其是hough变换,将图像平面的点对应到参数平面上的线让我大开眼界。而边
文档评论(0)