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

理论在前一章中,我们看到角是图像中各个方向上亮度变化很大的区域。早在1988年,克里斯哈里斯(Chris Harris)和迈克斯蒂芬斯(Mike Stephens)在他们的论文《一种结合角点和边缘的检测器》(A Detector combined Corners and Edges)中就试图找到这些角点,所以现在被称为“哈里斯...

理论

在前一章中,我们看到角是图像中各个方向上亮度变化很大的区域。早在1988年,克里斯·哈里斯(Chris Harris)和迈克·斯蒂芬斯(Mike Stephens)在他们的论文《一种结合角点和边缘的检测器》(A Detector combined Corners and Edges)中就试图找到这些角点,所以现在被称为“哈里斯角点检测器”。他将这个简单的想法转化为数学模型。它基本上可以求出(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坐标图来表示:

因此,哈里斯角检测的结果是分级灰度图像。适当的阈值设置将获得图像中的角度。我们将使用一个简单的图像进行测试。

OpenCV的Harris角点检测

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

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

为了说明该函数的用法:

import numpy as npimport cv2 as cvfilename = 'ches***oard.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 ***rking the corners, not importantdst = cv.dilate(dst,None)# Threshold for an opti***l value, it ***y vary depending on the i***ge.img[dst>0.01*dst.***x()]=[0,0,255]cv.imshow('dst',img)if cv.waitKey(0) & 0xff == 27: cv.destroyAllWindows()

以下是测试结果:

亚像素角点检测

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

import numpy as npimport cv2 as cvfilename = 'ches***oard2.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.***x(),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)

这是结果。缩放每个角以显示不同的红色和绿色位置标记。该功能明显提高了精确度:

本文来自半邊陽光投稿,不代表舒华文档立场,如若转载,请注明出处:https://www.chinashuhua.cn/24/506400.html

打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
() 0
上一篇 04-16
下一篇 04-16

相关推荐

  • 图灵测试是什么(图灵测试内容、过程、原理)

    人工智能一直是科技发展的前沿课题之一,世界各地的科学家都在努力开发机器的人工智能,以便更好地服务于人类。但是,如何判断机器是否具有人工智能呢?为此,科学界有一个非常简单的测试方法,那就是图灵测试。我们来谈谈图灵测试。图灵测试的内容、过程和原理。1.什么是图灵

    2023-07-29 06:04:01
    250 0
  • 淘宝购物返利平台(京东购物返利原理)

    双12快到了,肯定有很多购物需求!让我告诉你一个小秘密。有一些返利app。你在淘宝、JD.COM、拼多多等购买商品后。,你还是可以按比例拿一些佣金的。绝对是省钱利器。1.多多的头是拼多多的返利APP在品多多享受低价的基础上,又能拿到返利,不是很美好吗?报名方式:下载多多头

    2023-07-29 01:47:01
    863 0
  • 数据挖掘概念与技术第三版pdf 数据挖掘原理与算法第三版

    前不久我们的推荐算法还不够精准?让知识图谱解决”和“如何将知识图谱特征学习应用于推荐系统”的系列文章受到了同学们的广泛欢迎。大家都很关心推荐系统及其相关的底层数据挖掘技术。为了帮助朋友们更好地学习相关内容,我们邀请了微软亚洲研究院社会计算组研究员张福正为大

    2023-07-28 06:09:01
    984 0
  • 百度seo排名点击器平台 原理和使用方法

    之前我说过不打算写这个快递排了。第一,我自己的网站没有运营过所谓的快递排。第二,我不能像很多网上的一样透露百度快递排。(老实说,你可以透露所有的方法。真的有用吗?真正懂的人都在低调赚钱)。我只是站在一个白人的角度,让更多的白人知道所谓的百度快递排列是什么,同

    2023-07-27 15:14:02
    269 0

评论列表

联系我们

在线咨询: QQ交谈

邮件:admin@qq.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信