在本章中,将学习另一个角点检测器:
在上一章中,学习了Harris Corner Detector。1994年下半年,J.Shi和C. Tomasi在论文《Good Features to Track》中做了一个小修改,与Harris Harris Detector相比,展示了更好的结果。哈里斯角落探测器的计分功能由下式给出:
R = λ 1 λ 2 − k ( λ 1 + λ 2 ) 2 R = lambda_1 lambda_2 - k(lambda_1+lambda_2)^2 R=λ1λ2−k(λ1+λ2)2
取而代之的是,C. Tomasi提出:
R = m i n ( λ 1 , λ 2 ) R=min(lambda_1, lambda_2) R=min(λ1,λ2)
如果大于阈值,则将其视为拐角。如果像在Harris Corner Detector中那样在 λ 1 − λ 2 lambda_1-lambda_2 λ1−λ2 空间中绘制它,则会得到如下图像:
从图中可以看到,只有当 λ 1 lambda_1 λ1 和 λ 2 lambda_2 λ2 大于最小值 λ m i n lambda_{min} λmin时,才将其视为拐角(绿色区域)。
OpenCV有一个函数
利用所有这些信息,该函数可以找到图像中的拐角,低于平均质量的所有拐角点均被拒绝。然后,会根据质量以降序的方式对剩余的角进行排序。然后函数首先获取最佳拐角,然后丢弃最小距离范围内的所有附近拐角,然后返回N个最佳拐角。
corners = cv.goodFeaturesToTrack( image, maxCorners, qualityLevel, minDistance, mask, blockSize, gradientSize[, corners[, useHarrisDetector[, k]]] )
- image 输入单通道图片
- corners 输出的角点结果
- maxCorners 最大的角点数量 maxCorners <= 0表示不限制
- qualityLevel 最小的能接受的质量分数For example, if the best corner has the quality measure = 1500, and the qualityLevel=0.01 , then all the corners with the quality measure less than 15 are rejected.
- minDistance 返回的角落之间的最小可能的欧几里德距离
- mask 可选的兴趣区域。如果图像不为空(需要具有类型CV_8UC1和与图像相同的大小),则指定检测到角落的区域
- blockSize 用于计算每个像素邻域的衍生协变矩阵的平均块的大小
- useHarrisDetector 参数指示是否使用Harris检测器
- 哈里斯检测器的免费参数
在下面的示例中,将尝试找到24个最佳角点:
import cv2
import numpy as np
from matplotlib import pyplot as pltimg = cv2.imread('shi.png')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)corners = dFeaturesToTrack(gray, 24, 0.01, 10) # 四个参数,图像,个数,分数,距离
corners = np.int0(corners)for i in corners:x, y = i.ravel()cv2.circle(img, (x,y), 3, 255, -1)plt.imshow(img)
plt.show()
本文发布于:2024-02-03 02:57:33,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170690025148193.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |