0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

OpenCV4中SIFT算法概述

OpenCV学堂 来源:OpenCV学堂 作者:gloomyfish 2022-11-23 09:48 次阅读

SIFT概述

SIFT特征是非常稳定的图像特征,在图像搜索、特征匹配、图像分类检测等方面应用十分广泛,但是它的缺点也是非常明显,就是计算量比较大,很难实时,所以对一些实时要求比较高的常见SIFT算法还是无法适用。

如今SIFT算法在深度学习特征提取与分类检测网络大行其道的背景下,已经越来越有鸡肋的感觉,但是它本身的算法知识还是很值得我们学习,对我们也有很多有益的启示,本质上SIFT算法是很多常见算法的组合与巧妙衔接,这个思路对我们自己处理问题可以带来很多有益的帮助。

特别是SIFT特征涉及到尺度空间不变性与旋转不变性特征,是我们传统图像特征工程的两大利器,可以扩展与应用到很多图像特征提取的算法当中,比如SURF、HOG、HAAR、LBP等。

夸张一点的说SIFT算法涵盖了图像特征提取必备的精髓思想,从特征点的检测到描述子生成,完成了对图像的准确描述,早期的ImageNet比赛中,很多图像分类算法都是以SIFT与HOG特征为基础,所有SIFT算法还是值得认真详细解读一番的。SIFT特征提取归纳起来SIFT特征提取主要有如下几步:

构建高斯多尺度金字塔

关键点精准定位与过滤

关键点方向指派

描述子生成

构建高斯多尺度金字塔

常见的高斯图像金字塔是每层只有一张图像,大致如下:

7707d8c8-6a72-11ed-8abf-dac502259ad0.jpg

上述的是通过图像金字塔实现了多分辨率,如果我们在每一层高斯金字塔图像生成的时候,给予不同的sigma值,这样不同的sigam就会产生不同模糊版本的图像,在同一层中就是实现不同尺度的模糊图像,再结合高斯金字塔,生成多个层多个尺度的金字塔,就是实现了图像的多尺度金字塔。同一张图像不同尺度高斯模糊如下:

7727b68e-6a72-11ed-8abf-dac502259ad0.jpg

为了在每层图像中检测 S 个尺度的极值点,DoG 金字塔每层需 S+2 张图像,因为每组的第一张和最后一张图像上不能检测极值,DoG 金字塔由高斯金字塔相邻两张相减得到,则高斯金字塔每层最少需 S+3 张图像,实际计算时 S 通常在2到5之间。SIFT算法中生成高斯金字塔的规则如下(尺度空间不变性):

774c854a-6a72-11ed-8abf-dac502259ad0.jpg

关键点精准定位与过滤

对得到的每层DOG图像,计算窗口3x3x3范围除去中心点之外的26点与中心点比较大小,寻找最大值或者最小值(极值点),如下图:

777c1ff8-6a72-11ed-8abf-dac502259ad0.jpg

即周围26个点(青色)要小于或者大于中心像素点,这样就得到初步的极值点候选,然后进行亚像素级别的精准定位。

原因在于图像得到像素坐标是离散的,尺度空间也是离散的间隔,每个极值点P(x, y, s)三维空间中不一定是真正的连续空间的极值点,以二维的曲线为例,得到蓝色是离散空间极值点,实际极值点是红色点,如下图所示:

77a44ca8-6a72-11ed-8abf-dac502259ad0.jpg

从上图我们也可以看出,在连续空间的极值点必然是导数过零点,

77d73e6a-6a72-11ed-8abf-dac502259ad0.jpg

对于|D(extremal)| < 0.03可以作为低对比度点或者弱边缘舍弃。

关键点方向指派

前面我们已经详细解释了SIFT特征点是如何提取的,有了特征点之后,我们对特征点周围的像素块计算角度方向直方图,在计算直方图之前首先需要对图像进行梯度计算,这里可以使用SOBEL算子,然后根据dx与dy计算梯度和与角度,这里使用的高斯权重,所以在梯度之前,首先需要对ROI区域进行高斯模糊,然后再计算角度(x轴,Bins)-梯度(Y轴)直方图,直方图的最高峰(max peak)对应的角度就是关键点的角度方向,对于大于max peak*85%的bin也作为方向指派给关键点,这样同一个关键点因为有多个方向在描述子生成的时候就会生成多个描述子,从而增加了特征的稳定性与抗干扰能力。图示如下:

77f94564-6a72-11ed-8abf-dac502259ad0.jpg

描述子生成

选择关键点小区域,根据窗口大小不同可以分为4x4大小不同的Cell,每个Cell生成一个角度方向直方图(8个BIN),对它们进行排序以后(旋转不变性描述子),生成128个向量特征数据,作为该关键点的唯一描述

782be938-6a72-11ed-8abf-dac502259ad0.jpg

根据排序以后生成描述子的规则不同,又可以分为

原图正常顺序描述子

水平反射顺序描述子

垂直反射顺序描述子

如下图所示:

784e5626-6a72-11ed-8abf-dac502259ad0.jpg

OpenCV中调用

OpenCV已经实现了SIFT算法,但是在OpenCV3.0之后因为专利授权问题,该算法在扩展模块xfeature2d中,需要自己编译才可以使用。

但是在OpenCV4.4之后因为专利过期,SIFT算法又回到了正式发布安装包中,无需编译源码,即可使用!首先需要创建一个SIFT检测器对象,通过调用

通过detect方法提取对象关键点

用drawKeypoints绘制关键点

通过compute提取描述子,

通过暴力匹配根据描述子匹配

代码演示如下

importcv2ascv

box=cv.imread("D:/images/box.png");
box_in_sence=cv.imread("D:/images/box_in_scene.png");
cv.imshow("box",box)
cv.imshow("box_in_sence",box_in_sence)

#创建SIFT特征检测器
sift=cv.xfeatures2d.SIFT_create()

#特征点提取与描述子生成
kp1,des1=sift.detectAndCompute(box,None)
kp2,des2=sift.detectAndCompute(box_in_sence,None)

#暴力匹配
bf=cv.DescriptorMatcher_create(cv.DescriptorMatcher_BRUTEFORCE)
matches=bf.match(des1,des2)

#绘制最佳匹配
matches=sorted(matches,key=lambdax:x.distance)
result=cv.drawMatches(box,kp1,box_in_sence,kp2,matches[:15],None)
cv.imshow("-match",result)
cv.waitKey(0)
cv.destroyAllWindows()

SIFT算法启示

多尺度金字塔,特征金字塔技术,迁移不变性与旋转不变性特征,这两点现在卷积神经网络及其变种的网络中也是很常见的特征工程技术。






审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • OpenCV
    +关注

    关注

    29

    文章

    611

    浏览量

    40789
  • LBP
    LBP
    +关注

    关注

    0

    文章

    14

    浏览量

    8928
  • SIFT算法
    +关注

    关注

    0

    文章

    8

    浏览量

    7393

原文标题:OpenCV4中 SIFT特征算法详解与使用

文章出处:【微信号:CVSCHOOL,微信公众号:OpenCV学堂】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    Python下使用SIFT算法描绘两张图片的相似特征点有哪些

    Python下使用SIFT算法描绘两张图片的相似特征点
    发表于 06-02 13:16

    鲁班猫0 -安装opencv

    ON OPENCV_GENERATE_PKGCONFIG 因为opencv4默认不生成.pc文件,所以加上这句用于生成opencv4.pc文件,支持pkg-config功能。opencv4
    发表于 04-09 13:29

    CMake在Linux 6.1.1-1.0.0搜索包opencv损坏了吗?

    imx-image-multimedia 的 SDK,我收到以下错误: sysroots/armv8a-poky-linux/usr/lib/cmake/opencv4/OpenCVModules.cmake
    发表于 05-09 11:32

    基于SIFT的三视图像特征匹配算法

    提出一种基于SIFT的三视图像特征匹配算法。采用SIFT算法对三视图像进行特征匹配,引入计算机视觉中的三线性关系和基于三焦张量的像素转移误差计算方法,对
    发表于 04-18 09:49 24次下载

    基于改进SIFT算法的图像匹配方法研究

    SIFT算法具有旋转、平移、尺度缩放和亮度的变化保持不变性的优点,也有算法复杂、计算时间长的缺点。本文提出了以街区距离代替欧式距离的新方法,来提高SIFT特征匹配效率,缩短
    发表于 08-13 16:07 37次下载
    基于改进<b class='flag-5'>SIFT</b><b class='flag-5'>算法</b>的图像匹配方法研究

    基于对比度阈值的改进SIFT算法

    为了提高基于SIFT(Scale Invariant Feature Transform)图像匹配算法对于图像对比度变化的鲁棒性和算法效率,提出了一种具有可变系数的自适应对比度阈值SIFT
    发表于 10-26 15:11 0次下载

    基于改进SIFT的图像拼接算法

    针对目前基于SIFT的图像拼接算法复杂度较高和特征点匹配不准等问题,提出了一种基于改进SIFT的图像拼接算法算法利用改进的
    发表于 02-21 16:04 0次下载
    基于改进<b class='flag-5'>SIFT</b>的图像拼接<b class='flag-5'>算法</b>

    基于LDA的SIFT算法在图像配准中的应用

    针对SIFT算法复杂程度高,实时性差,在维数较高的图像配准中并不实用的问题,提出了一种基于线性鉴别分析(LDA)的SIFT算法SIFT-L
    发表于 07-24 16:30 22次下载

    一种优化的SIFT配准算法

    针对SIFT算法在生成特征向量和进行特征匹配过程中存在的计算量较大、容易产生误匹配等不足,提出一种优化的SIFT配准算法。优化算法首先引入拉
    发表于 12-05 13:46 0次下载
    一种优化的<b class='flag-5'>SIFT</b>配准<b class='flag-5'>算法</b>

    sift算法原理详解及应用

    Sift算法是David Lowe于1999年提出的局部特征描述子,并于2004年进行了更深入的发展和完善。Sift特征匹配算法可以处理两幅图像之间发生平移、旋转、仿射变换情况下的匹配
    发表于 02-26 11:06 6.8w次阅读

    基于GPU 的SIFT实时优化算法综述

    针对SIFT特征提取算法过程复杂且实时性低的缺陷,提出了一种基于GPU的实时尺度不变特征变换( Scale-invariant feature transform,SIFT)的优化算法
    发表于 05-13 11:31 11次下载

    基于改进SIFT和RANSAC图像拼接算法研究_马强

    基于改进SIFT和RANSAC图像拼接算法研究_马强(怎样测监控电源电流)-基于改进SIFT和RANSAC图像拼接算法研究_马强这是一份非常不错的资料,欢迎下载,希望对您有帮助!
    发表于 07-26 12:53 12次下载
    基于改进<b class='flag-5'>SIFT</b>和RANSAC图像拼接<b class='flag-5'>算法</b>研究_马强

    基于opencv4和Yolo-Fastest,实现PC和单片机通信,控制步进电机捕获目标

    效果视频 基于opencv4和yolo,实现PC和单片机通信,控制步进电机捕获目标
    发表于 11-23 17:36 15次下载
    基于<b class='flag-5'>opencv4</b>和Yolo-Fastest,实现PC和单片机通信,控制步进电机捕获目标

    如何在Raspberry Pi 3上安装OpenCV4

    今天我们将学习如何在 Raspberry Pi 3 上安装 OpenCV4 库,以便我们可以将其用于计算机视觉应用程序。这将允许 OpenCV 在像 Pi 这样的便携式设备上运行,从而打开许多可能性的大门。所以让我们开始吧
    的头像 发表于 09-08 16:09 1370次阅读
    如何在Raspberry Pi 3上安装<b class='flag-5'>OpenCV4</b>库

    学习OpenCV4的系统化路线图

    OpenCV4发布测试版本开始,作者就一直关注!根据自己近十年图像处理OpenCV开发相关工作经验,花了七个月的时间,针对OpenCV4、精心选择OpenCV中常用模块与知识点,构建
    的头像 发表于 07-05 11:30 370次阅读
    学习<b class='flag-5'>OpenCV4</b>的系统化路线图