当前位置:首页 > 生活百科

harris角点检测原理(harris角点响应函数)

栏目:生活百科日期:2024-11-26浏览:0

理论

在上一章中,我们看到角是图像中各个方向上强度变化较大的区域。早在1988年,克里斯·哈里斯和迈克·斯蒂芬斯就在他们的论文《一种结合了角和边缘的探测器》中试图找到这些角,所以现在它被称为“哈里斯角探测器”。他把这个简单的想法转化为数学模型。它基本上可以求出(u,v)在所有方向上的位移的强度差。这表示如下:

窗口函数可以是矩形窗口,也可以是高斯窗口(它为下面的像素赋予权重)。

我们需要最大化这个函数E(u,v)来检测拐角。这意味着,我们要使第二项最大化。将泰勒展开应用于上述方程,并使用一些数学步骤(如需完整推导,请参考您喜欢的任何标准课本),得到最终方程为:

这里的 Ix 和 Iy 分别是图像在 x 和 y 上的导数。(可以很容易的通过函数 cv.Sobel()得到)。

接下来是主要部分。在这之后,他们创建了一个分数,基本上是一个方程,它将决定一个窗口是否可以包含一个角。

其中:

det(M)=λ1λ2trace(M)=λ1+λ2λ1 和 λ2 是M的特征值

因此,这些特征值决定了该区域是角,边沿还是平台区。

当 |R| 较小时(当 λ1 和 λ2 都小时出现),则该区域就是平台区。当 R&<0 时(一般当 λ1&>&>λ2 远大于或相反时出现),则该区域是边沿。当 R 较大时(一般 λ1 和 λ2 都较大且 λ1~λ2趋近),则该区域是角。

可以用下图 λ1 和 λ2 坐标图来表示:

因此,Harris角检测的结果是一个带评分的灰度图像。适当的阈值设置会得到图像中的角。我们将用一个简单的图像来做测试。

OpenCV的Harris角点检测实现

OpenCV 有一个函数 cv.cornerHarris() 就是用于此目的,包括一下参数:

img &– 输入图像,该图像必须是float32 类型的灰度图。blockSize &– 角点检测的邻近域大小ksize &– 用于Sobel导数的孔径参数。k &– 方程中Harris 检测自由参数。

举例说明该函数的使用:

import numpy as npimport cv2 as cvfilename = 'chessboard.png'img = cv.imread(filename)gray = cv.cvtColor(img,cv.COLOR_BGR2GRAY)gray = np.float32(gray)dst = cv.cornerHarris(gray,2,3,0.04)#result is dilated for marking the corners, not importantdst = cv.dilate(dst,None)# Threshold for an optimal value, it may vary depending on the image.img[dst&>0.01*dst.max()]=[0,0,255]cv.imshow('dst',img)if cv.waitKey(0) && 0xff == 27: cv.destroyAllWindows()

以下就是检测结果:

亚像素精度的角点检测

有时候,你可能需要找到最精确的角。OpenCV附带一个函数cv.cornersubpix(),它进一步细化了以亚像素精度检测到的角。下面是一个例子。像往常一样,我们需要先找到哈里斯角。然后我们通过这些角的质心(可能在一个角上有一堆像素,我们取它们的质心)来细化它们。Harris角用红色像素标记,精制角用绿色像素标记。对于这个函数,我们必须定义何时停止迭代的条件。我们在指定的迭代次数或达到一定的精度后停止它,无论先发生什么。我们还需要定义搜索拐角的邻域的大小。

import numpy as npimport cv2 as cvfilename = 'chessboard2.jpg'img = cv.imread(filename)gray = cv.cvtColor(img,cv.COLOR_BGR2GRAY)# find Harris cornersgray = np.float32(gray)dst = cv.cornerHarris(gray,2,3,0.04)dst = cv.dilate(dst,None)ret, dst = cv.threshold(dst,0.01*dst.max(),255,0)dst = np.uint8(dst)# find centroidsret, labels, stats, centroids = cv.connectedComponentsWithStats(dst)# define the criteria to stop and refine the cornerscriteria = (cv.TERM_CRITERIA_EPS + cv.TERM_CRITERIA_MAX_ITER, 100, 0.001)corners = cv.cornerSubPix(gray,np.float32(centroids),(5,5),(-1,-1),criteria)# Now draw themres = np.hstack((centroids,corners))res = np.int0(res)img[res[:,1],res[:,0]]=[0,0,255]img[res[:,3],res[:,2]] = [0,255,0]cv.imwrite('subpixel5.png',img)

以下是结果,每个角经过缩放后显示红绿不同位置标识,该函数明显提升了精度:

“harris角点检测原理(harris角点响应函数)” 的相关文章

12123外地罚款怎么缴纳罚款(交管12123实名注册及罚款缴

前提:现在驾驶机动车违章已是常态,除了本地违章外,还有大部分小伙伴都有异地违章,本地违章处理可以去车管所咨询办理。异地违章对于不经常去异地的朋友来说异常头疼,还...

微信清除聊天记录有哪些方法,教你一招彻底删除

有时候因为手机内存不足,需要清理一些手机中的数据,来保障手机更流畅地运行。特别是安卓手机,使用时间长了手机中会积攒很多的数据。而微信是我们日常使用频率很高的一个...

小米电视好不好耐不耐用(小米电视真实评价)

6月底,小米举行了画质双旗舰电视的发布会,正式发布小米电视6至尊版和小米电视ES2022款。这也是小米电视数字系列电视阔别一年多之久后,在此与大家见面。不过,今...

2020现在什么买卖比较好做(适合年轻人做的生意有哪些)

在绝大多数人看来,在当前的就业环境下,挣钱这个概念几乎就等同于打工了,毕竟打工来钱更直接,不需要什么成本,也没有什么风险。相比之下,人人都说创业做生意可以赚大钱...

jquery文件上传插件(ajax异步上传多个文件方法)

今天给大家分享一款优秀的文件拖拽上传及图片预览开源类库DropZoneJS。dropzonejs基于Javascript构建的轻量级web文件拖拽上传插件,st...

公益创业项目案例,公益创业和传统创业有什么区别

不同于经济领域的商业创业,近年来,一种新形式的创业实践初露端倪,那就是社会领域的公益创业。今年“两会”期间,《中华人民共和国慈善法》表决通过,国家主席习近平签署...

如何保存整个网页(用以下这个方法简单又管用)

我们身处信息爆发的时代,我们可以通过搜索引擎搜索到我们需要的内容,经过日积月累,我们浏览过的网页和保存的书签都变得很多!浏览器自带的“书签”功能应该是大家最常使...

如何营销自己的产品给别人(免费分享销货秘诀)

在这个纷繁复杂的时代,我们每天都穿梭在拥挤的城市中,每天面对着很早起来做早餐,排队买早餐的形势,然后去挤只要你上了车就不能挪动身体的地铁,每天的上下班都像是打了...

学校门口适合做什么生意,学校门口暴利生意介绍

在学校门口做生意,在人们以往的认知中,主要是以经营零食小吃、文具用品等方式来赚学生的钱,其实除了以上的几种方式以外还有下面几种可以在学校门口赚钱的小本生意。特色...

华为手机照片怎么恢复,恢复手机照片最简单的方法

华为发布了他们的年度高端旗舰机,价格首次超越5000元,而且华为这次还和保时捷合作了,设计了保时捷6GB+256GB版,价格甚至达到了8999元,看来这次华为是...