用于角点检测的FAST算法

使用FAST进行特征检测

1.选择图像中是否要识别为兴趣点的像素 p p p,使其强度为 I p I_p Ip
2.选择适当的阈值 t t t
3.考虑被测像素周围有16个像素的圆圈。(见下图)
在这里插入图片描述
4.现在,如果圆中存在一组(共16个像素) n n n个连续的像素,它们均比 I p + t I_p + t Ip+t亮,或者比 I p − t I_p-t Ipt都暗,则像素 p p p是一个角。(在上图中显示为白色虚线)。n被选为12。
5.建议使用高速测试以排除大量的非角区域。此测试仅检查1、9、5和13处的四个像素(如果第一个1和9太亮或太暗,则对其进行测试。如果是,则检查5和13)。如果p是一个角,则其中至少三个必须全部比 I p + t I_p + t Ip+t亮或比 I p − t I_p-t Ipt暗。如果以上两种情况都不是,则 p p p不能为角。然后,可以通过检查圆中的所有像素,将完整的分段测试标准应用于通过的候选项。该检测器本身具有很高的性能,但有几个缺点:
6.它不会拒绝n <12的候选对象。
7.像素的选择不是最佳的,因为其效率取决于问题的顺序和角落外观的分布。
8.高速测试的结果被丢弃了。
9.彼此相邻地检测到多个特征。
机器学习的方法解决了前三点。使用非最大抑制来解决最后一个问题。
让机器学习一个角检测器

1.选择一组图像进行训练(最好从目标应用程序域中进行训练)
2.在每个图像中运行FAST算法以查找特征点。
3.对于每个特征点,将其周围的16个像素存储为矢量。对所有图像执行此操作以获得特征向量P。
4.这16个像素中的每个像素(例如 x x x)可以具有以下三种状态之一:
在这里插入图片描述

1.取决于这些状态,特征矢量 P P P被细分为3个子集, P d P_d Pd, P s P_s Ps, P b P_b Pb
2.定义一个新的布尔变量 K p K_p Kp,如果 p p p是一个角,则为true,否则为false。
3.使用ID3算法(决策树分类器)使用变量 K p K_p Kp查询每个子集,以获取有关真实类的知识。它选择x,该x通过 K p K_p Kp的熵测得的有关候选像素是否为角的信息最多。
4.递归地将其应用于所有子集,直到其熵为零为止。
5.这样创建的决策树用于其他图像的快速检测。
非最大抑制

在相邻位置检测多个兴趣点是另一个问题。通过使用非极大抑制来解决。

1.计算所有检测到的特征点的得分函数 V V V V V V p p p与16个周围像素值之间的绝对差之和。
2.考虑两个相邻的关键点并计算它们的 V V V值。
3.丢弃较低 V V V值的那个。
OpenCV中的高速拐角检测器

它被称为OpenCV中的任何其他特征检测器。 如果需要,您可以指定阈值,是否要应用非极大抑制,要使用的邻域等。 对于邻域,定义了三个标志,分别为cv.FAST_FEATURE_DETECTOR_TYPE_5_8,cv.FAST_FEATURE_DETECTOR_TYPE_7_12和cv.FAST_FEATURE_DETECTOR_TYPE_9_16。 以下是有关如何检测和绘制FAST特征点的简单代码。

import numpy as np
import cv2 as cv
from matplotlib import pyplot as plt
img = cv.imread('simple.jpg',0)
# 用默认值初始化FAST对象
fast = cv.FastFeatureDetector_create()
# 寻找并绘制关键点
kp = fast.detect(img,None)
img2 = cv.drawKeypoints(img, kp, None, color=(255,0,0))
# 打印所有默认参数
print( "Threshold: {}".format(fast.getThreshold()) )
print( "nonmaxSuppression:{}".format(fast.getNonmaxSuppression()) )
print( "neighborhood: {}".format(fast.getType()) )
print( "Total Keypoints with nonmaxSuppression: {}".format(len(kp)) )
cv.imwrite('fast_true.png',img2)
# 关闭非极大抑制
fast.setNonmaxSuppression(0)
kp = fast.detect(img,None)
print( "Total Keypoints without nonmaxSuppression: {}".format(len(kp)) )
img3 = cv.drawKeypoints(img, kp, None, color=(255,0,0))
cv.imwrite('fast_false.png',img3)

查看结果。第一张图片显示了带有nonmaxSuppression的FAST,第二张图片显示了没有nonmaxSuppression的FAST.

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值