绑定完请刷新页面
取消
刷新

分享好友

×
取消 复制
OpenCV-Python Shi-tomas拐角检测器和益于跟踪的特征 | 三十八
2020-02-10 14:55:04

目标

在本章中,

  • 我们将学习另一个拐角检测器:Shi-Tomasi拐角检测器
  • 我们将看到以下函数:cv.goodFeaturesToTrack()

理论

在上一章中,我们看到了Harris Corner Detector。1994年下半年,J。Shi和C. Tomasi在他们的论文《有益于跟踪的特征》中做了一个小修改,与Harris Harris Detector相比,显示了更好的结果。哈里斯角落探测器的计分功能由下式给出:

$$R = lambda1 lambda2 - k(lambda1+lambda2)^2$$

取而代之的是,史托马西提出:

$$R = min(lambda1, lambda2)$$

如果大于阈值,则将其视为拐角。如果像在Harris Corner Detector中那样在$lambda1-lambda2$空间中绘制它,则会得到如下图像:

从图中可以看到,只有当$lambda1$和$lambda2$大于小值$lambda_{min}$时,才将其视为拐角(绿色区域)。

代码

OpenCV有一个函数cv.goodFeaturesToTrack()。它通过Shi-Tomasi方法(或哈里斯角检测,如果指定)找到图像中的N个强角。像往常一样,图像应该是灰度图像。然后,指定要查找的角数。然后,您指定质量级别,该值是介于0-1之间的值,该值表示每个角落都被拒绝的低拐角质量。然后,我们提供检测到的角之间的小欧式距离。利用所有这些信息,该功能可以找到图像中的拐角。低于平均质量的所有拐角点均被拒绝。然后,它会根据质量以降序对剩余的角进行排序。然后函数首先获取佳拐角,然后丢弃小距离范围内的所有附近拐角,然后返回N个佳拐角。在下面的示例中,我们将尝试找到25个佳弯角:

import numpy as np
import cv2 as cv
from matplotlib import pyplot as plt
img = cv.imread('blox.jpg')
gray = cv.cvtColor(img,cv.COLOR_BGR2GRAY)
corners = cv.goodFeaturesToTrack(gray,25,0.01,10)
corners = np.int0(corners)
for i in corners:
    x,y = i.ravel()
    cv.circle(img,(x,y),3,255,-1)
plt.imshow(img),plt.show()复制代码

查看以下结果:

此功能更适合跟踪。我们将看到使用它的时机

磐创AI技术博客资源汇总站:http://docs.panchuang.net/PyTorch官方中文教程站:http://pytorch.panchuang.net/OpenCV中文官方文档: http://woshicver.com/

分享好友

分享这个小栈给你的朋友们,一起进步吧。

优质文章
创建时间:2020-06-09 15:14:35
分享大家优质文章
展开
订阅须知

• 所有用户可根据关注领域订阅专区或所有专区

• 付费订阅:虚拟交易,一经交易不退款;若特殊情况,可3日内客服咨询

• 专区发布评论属默认订阅所评论专区(除付费小栈外)

栈主、嘉宾

查看更多
  • highhand
    栈主

小栈成员

查看更多
  • huijinrutu
  • 扒掉你的内内
  • bingo666
  • 朱杰
戳我,来吐槽~