SURF算法分析
机器视觉中基于SURF算法的目标识别研究
![机器视觉中基于SURF算法的目标识别研究](https://img.taocdn.com/s3/m/ad0d49a2534de518964bcf84b9d528ea80c72f46.png)
机器视觉中基于SURF算法的目标识别研究第一章:引言随着计算机技术的不断发展,机器视觉技术逐渐应用于各种领域。
其中,目标识别是机器视觉技术的重要应用之一,可以在自动控制、工业制造、军事等领域中发挥重要作用。
在目标识别中,特征点检测和匹配是关键技术。
SURF算法是一种快速有效的特征点检测和匹配算法,已经得到广泛应用。
本文将介绍机器视觉中基于SURF算法的目标识别研究,具体包括SURF算法原理、SURF算法在目标识别中的应用及其优劣势分析、SURF算法在实际系统中的应用及其发展趋势等。
第二章:SURF算法原理SURF算法是加速稳健特征(Speeded Up Robust Feature)的缩写。
它是基于尺度空间理论的特征点检测和匹配算法。
SURF算法主要包括三个步骤:尺度空间构建、特征点检测和特征描述。
尺度空间构建是指先将原始图像进行高斯滤波,得到不同尺度下的图像金字塔,然后通过差分的方式得到尺度不变的DoG (Difference of Gaussian)图像组。
特征点检测是指在DoG图像组中检测出极值点,SURF算法中采用的是Hessian矩阵。
特征描述是指在检测到的特征点周围的邻域内,计算一组具有较强区分度的局部特征描述子,SURF算法中采用的是基于积分图像的Haar小波特征描述子。
第三章:SURF算法在目标识别中的应用及其优劣势分析SURF算法在目标识别中的应用主要包括两个方面:特征点检测和匹配。
特征点检测是指在图像中寻找具有独特性、稳定性和可重复性的特征点,SURF算法对尺度空间建立和特征点检测都有良好的性能,能够有效地检测到目标物体中的关键点。
匹配是指在两个图像中寻找相似的特征点,SURF算法具有较高的匹配准确率和速度,能够实现快速准确地目标匹配。
但是,SURF算法也存在一些不足之处,比如对图像旋转、缩放、变形等变化不够鲁棒,需要额外的操作来进行补偿。
第四章:SURF算法在实际系统中的应用及其发展趋势SURF算法在实际系统中的应用非常广泛,例如在工业机器人、自动驾驶、安防监控等领域中都得到了应用。
SURF算法分析
![SURF算法分析](https://img.taocdn.com/s3/m/aeae8a62492fb4daa58da0116c175f0e7dd11964.png)
2021/10/10
15
标出特征点的图像
2021/10/10
16
二.特征点 匹配
2021/10/10
17
特征点匹配
步骤1. 在检测特征点的过程中,计算了 Hessian 矩阵
的行列式,与此同时,计算得到了 Hessian 矩阵的迹,矩
阵的迹为对角元素之和。
按照亮度的不同,可以将特征点分为两种,第一种为
用stitching算法 进行图像拼接
2021/10/10
1
• 第一部分:用surf算法提 取特征点
• 第二部分:特征点匹配
• 第三部分:构建透视矩阵 完成拼接
• 第四部分 : 图像融合
2021/10/10
2
一.用SURF算法 提取特征点
1.SURF 介绍
SURF (Speeded Up Robust Feature)是一种高鲁棒性的局 部特征点检测器。由Herbert Bay 等人在2006年提出。该算法 可以用于计算机视觉领域例如物体识别或者三维重建。根据 作者描述该算法比SIFT更快更加具有鲁棒性。该算法中采用 积分图像、Haar小波变换和近似的Hessian矩阵运算来提高时 间效率,采用Haar小波变换增加鲁棒性。
给定图像f(x,y)中一个点 (x,y),其Hessian矩阵H(x,o) 定义如下:
2021/10/10
位置 尺度
快速 Hessian
5
• Lxx(x, ϭ )是高斯二阶微分在点X=(x,y)处与图像I的卷积 。
• Bay指出,高斯函数虽然是最佳的尺度空间分析工具, 但由于在实际应用中总要对高斯函数进行离散化和剪 切处理,从而损失了一些特性(如重复性)。这一因 素为我们用其他工具代替高斯函数对尺度空间的分析 提供了可能,只要误差不大就可以。所以就引入了盒 装滤波器。
surf算法代码 -回复
![surf算法代码 -回复](https://img.taocdn.com/s3/m/a186e7c08662caaedd3383c4bb4cf7ec4afeb604.png)
surf算法代码-回复什么是Surf算法Surf算法(Speeded Up Robust Features)是一种用于图像特征检测和描述的计算机视觉算法。
它是在2006年由Herbert Bay等人提出的,旨在提高图像处理中的特征点检测与匹配的速度和准确性。
Surf算法在计算机视觉和图像处理领域中得到广泛应用,它的主要目标是在图像中找到稳定且唯一的局部特征点。
Surf算法的步骤1. 尺度空间构建:Surf算法在图像中使用多尺度空间来有效地检测特征点。
它通过不断模糊图像,并计算模糊后的图像与原始图像的差异来构建多尺度空间。
算法使用一个高斯滤波器来进行图像模糊,并通过逐渐增加滤波器的方差来构建不同尺度下的图像。
这样做的目的是使得算法能够在不同尺度下检测到特征点,而不受图像缩放的影响。
2. 关键点检测:在构建好尺度空间后,Surf算法会在每个尺度中检测关键点。
关键点是那些在图像中具有稳定尺度和位置,并且对缩放、旋转和光照变化具有不变性的点。
Surf算法使用Hessian矩阵来检测关键点。
Hessian矩阵是一个用于测量图像局部变化的矩阵,在Surf算法中,它被用来检测图像中的高强度点。
3. 关键点定位:在检测到关键点后,Surf算法会对关键点进行精确定位。
它使用一个Haar 小波响应来定位关键点的位置和方向。
Haar小波是一种多尺度基函数,它能够识别出图像中的边缘和纹理特征。
Surf算法利用Haar小波响应来定位出关键点的具体位置和方向,以便后续的特征描述步骤。
4. 特征描述:在完成关键点定位后,Surf算法会对每个关键点进行描述,以便后续的特征匹配。
Surf算法使用了一种叫做加速权重积分(Fast Hessian)的方法来生成特征描述子。
特征描述子是一个向量,它能够描述关键点周围区域的结构和纹理信息。
Surf算法会通过计算关键点周围区域的灰度变化来生成特征描述子。
5. 特征点匹配:在完成特征描述后,Surf算法会使用一种叫做KD树的数据结构来进行特征点的匹配。
S U R F 算 法
![S U R F 算 法](https://img.taocdn.com/s3/m/771cbcb3b4daa58da0114ad9.png)
特征点检测学习(surf算法)网上有些文章对surf做了介绍,比如:surf算法原理,有一些简单介绍.对surf的某些细节做了通俗易懂的解释.一、Surf描述子形成步骤1. 构造高斯金字塔尺度空间其实surf构造的金字塔图像与sift有很大不同,就是因为这些不同才加快了其检测的速度。
Sift采用的是DOG图像,而surf采用的是Hessian矩阵行列式近似值图像。
首先来看看图像中某个像素点的Hessian 矩阵,如下:即每一个像素点都可以求出一个Hessian矩阵。
但是由于我们的特征点需要具备尺度无关性,所以在进行Hessian矩阵构造前,需要对其进行高斯滤波。
这样,经过滤波后在进行Hessian的计算,其公式如下:公式中的符号,估计有点数学基础的朋友都能够猜到,这里就不多解释了。
最终我们要的是原图像的一个变换图像,因为我们要在这个变换图像上寻找特征点,然后将其位置反映射到原图中,例如在sift中,我们是在原图的DOG图上寻找特征点的。
那么在surf中,这个变换图是什么呢?从surf的众多资料来看,就是原图每个像素的Hessian矩阵行列式的近似值构成的。
其行列式近似公式如下:由于求Hessian时要先高斯平滑,然后求二阶导数,这在离散的像素点是用模板卷积形成的,这2中操作合在一起用一个模板代替就可以了,比如说y方向上的模板如下:该图的左边即用高斯平滑然后在y方向上求二阶导数的模板,为了加快运算用了近似处理,其处理结果如右图所示,这样就简化了很多。
并且右图可以采用积分图来运算,大大的加快了速度,关于积分图的介绍,可以去查阅相关的资料。
同理,x和y方向的二阶混合偏导模板如下所示:上面讲的这么多只是得到了一张近似hessian行列式图,这例比sift中的DOG图,但是在金字塔图像中分为很多层,每一层叫做一个octave,每一个octave中又有几张尺度不同的图片。
在sift算法中,同一个octave层中的图片尺寸(即大小)相同,但是尺度(即模糊程度)不同,而不同的octave层中的图片尺寸大小也不相同,因为它是由上一层图片降采样得到的。
S U R F 算 法
![S U R F 算 法](https://img.taocdn.com/s3/m/646a33bebcd126fff6050b87.png)
opencv之SURF算法原理及关键点检测在基础篇里面讲模板匹配的时候已经介绍过,图像匹配主要有基于灰度和基于特征两种方法。
基于特征匹配的方法有很多种如:FAST、HARRIS、SIFT、SURF、SUSAN等。
其中SIFT算法由D.G.Lowe于1999年提出,2004年完善总结。
SIFT是一种鲁棒性好的尺度不变特征描述方法,但SIFT算法计算数据量大、时间复杂度高、算法耗时长。
针对上述缺点许多研究者对SIFT算法做了不同的改进,Yanke等人提出用PCA-SIFT方法对特征描述进行数据降维,但在没有任何先验知识的情况下反而增加了计算量;Delpont等人提出用SVD方法进行特征匹配,但匹配过程计算复杂,且不能用于宽基线匹配;Grabner等人用积分图像虽提高了SIFT的计算速度,但是降低了SIFT方法的优越性。
Herbert Bay等人于2006年提出了SIFT算法的改进算法SURF算法,其性能超过了SIFT算法且能够获得更快的速度。
SURF在光照变化和视角变化不变性方面的性能接近SIFT算法,尤其对图像严重模糊和旋转处理得非常好。
且标准的SURF算子比SIFT算子快好几倍,SURF算法最大的特征在于采用了harr特征以及积分图像的概念,这大大加快了程序的运行速度。
SURF算法和SIFT算法在opencv中是一种很高级的算法,opencv提供了SURF算法的API接口。
需要说明的是SURF和SIFT算法在OpenCV提供的nonfree中,而且在OpenCV3.x后不再集成到OpenCV发行版中,同意存放到opencv_contrib中,需要去opencv github页面手动下载编译。
点击跳转,编译方法网上有很多教-程。
2.Surf原理特征点的提取基于尺度空间理论,我们通过检测图像局部极值点来锁定特征点坐标,即局部的最亮点或最暗点。
2.1构建Hessian矩阵SURF算法检测特征点是基于Hessian矩阵实现的,Hessian矩阵是SURF 算法的核心。
S U R F 算 法
![S U R F 算 法](https://img.taocdn.com/s3/m/320e87f7561252d381eb6e81.png)
SURF算法详解Speeded Up Robust Features(SURF,加速稳健特征)一.积分图像什么是积分图像积分图像是输入的灰度图像经过一种像素间的累加运算得到种新的图像媒介。
对于一幅灰度的图像,积分图像中的任意一点(x,y)的值是指从图像的左上角到这个点的所构成的矩形区域内所有的点的灰度值之和积分图像的作用积分图像是SURF算法减小计算量的关键,从SIFT到SURF算法的性能提升很大程度归功于积分图像的使用积分图像与原始图像的关系a.相同点:积分图像与原始图像的尺寸相同,积分图像中每个位置坐标与原始灰度图像的像素坐标相对应。
b.不同点:不同的是,在原始图像采用灰度图像的情况下,灰度图像每个像素使用8bit表示,而积分图像由于像素的累加运算,或者由于图像尺度的变化,积分图像中每个像素位宽将会需要积分的像素尾款来表示如何得到积分图像a.积分像素值1.坐标系的建立对于一幅原始的灰度图像,以图像中的第一个像素位置作为坐标原点,向右为轴正向,向下为轴正向建立坐标系。
2.积分像素值的确定将任意像素与坐标原点之间围成的矩形区域内所有像素值相加得到一个新的值,在这里我们把它定义为积分像素值。
b.积分图像的确定原始图像中每个像素经过运算都会得到新的积分像素值,最终构成一幅新的积分图像。
c.积分图像的作用有了积分图像的概念,在原始图像中我们可以计算任意矩形区域内的像素之和。
这种运算方式有效的减少了运算量,因为矩形的面积大小不会影响到运算量。
任意矩形内的像素累加只需要使用矩形四个顶角位置的积分像素值进行加减运算即可得到。
如果要计算矩形内的所有像素的累加值只需要再积分图像中找到对应,,,四个位置的积分像素的值进行加减运算:二.Hessian矩阵0.与SIFT算法对比a. SIFT算法采用的是DoG图像,而SURF采用的是Hessian矩阵行列式近似值图像b. SIFT算法中使用高斯差分对、和进行近似估计,使用、和函数代替高斯拉普拉斯函数,即Hessian矩阵通过高斯差分后得到近似估计的Hessian矩阵高斯函数的高阶微分与离散的图像函数做卷积运算时相当于使用高斯滤波模板对图像做滤波处理其行列式为a.图像中某个像素点Hessian矩阵即每一个像素点都可以求出一个Hessian矩阵。
SURF算法
![SURF算法](https://img.taocdn.com/s3/m/745ded3bcec789eb172ded630b1c59eef8c79a3e.png)
SURF算法⼀、原理:Sift算法的优点是特征稳定,对旋转、尺度变换、亮度保持不变性,对视⾓变换、噪声也有⼀定程度的稳定性;缺点是实时性不⾼,并且对于边缘光滑⽬标的特征点提取能⼒较弱。
Surf(Speeded Up Robust Features)改进了特征的提取和描述⽅式,⽤⼀种更为⾼效的⽅式完成特征的提取和描述。
⼆、Surf实现流程如下:1. 构建Hessian(⿊塞矩阵),⽣成所有的兴趣点,⽤于特征的提取⿊塞矩阵(Hessian Matrix)是⼀个多元函数的⼆阶偏导数构成的⽅阵,描述了函数的局部曲率。
由德国数学家Ludwin Otto Hessian于19世纪提出。
surf构造的⾦字塔图像与sift有很⼤不同,Sift采⽤的是DOG图像,⽽surf采⽤的是Hessian矩阵⾏列式近似值图像。
Hessian矩阵是Surf算法的核⼼,构建Hessian矩阵的⽬的是为了⽣成图像稳定的边缘点(突变点),为下⽂的特征提取做好基础。
每⼀个像素点都可以求出⼀个Hessian矩阵。
Hessian矩阵的判别式为:当Hessian矩阵的判别式取得局部极⼤值时,判定当前点是⽐周围邻域内其他点更亮或更暗的点,由此来定位关键点的位置。
在SURF算法中,图像像素l(x,y)即为函数值f(x,y)。
但是由于我们的特征点需要具备尺度⽆关性,所以在进⾏Hessian矩阵构造前,需要对其进⾏⾼斯滤波,选⽤⼆阶标准⾼斯函数作为滤波器。
H矩阵的三个矩阵元素L_xx, L_xy, L_yy从⽽计算出H矩阵:Surf使⽤了盒式滤波器来近似替代⾼斯滤波器,提⾼运算速度。
盒式滤波器(Boxfilter)对图像的滤波转化成计算图像上不同区域间像素和的加减运算问题,只需要简单⼏次查找积分图就可以完成。
每个像素的Hessian矩阵⾏列式的近似值:2. 构建尺度空间同Sift⼀样,Surf的尺度空间也是由O组L层组成,不同的是,Sift中下⼀组图像的尺⼨是上⼀组的⼀半,同⼀组间图像尺⼨⼀样,但是所使⽤的⾼斯模糊系数逐渐增⼤;⽽在Surf中,不同组间图像的尺⼨都是⼀致的,但不同组间使⽤的盒式滤波器的模板尺⼨逐渐增⼤,同⼀组间不同层间使⽤相同尺⼨的滤波器,但是滤波器的模糊系数逐渐增⼤。
SIFTSURFORBFAST特征提取算法比较
![SIFTSURFORBFAST特征提取算法比较](https://img.taocdn.com/s3/m/613ab1ac4bfe04a1b0717fd5360cba1aa8118ce6.png)
SIFTSURFORBFAST特征提取算法比较在计算机视觉领域中,SIFT(Scale-Invariant Feature Transform,尺度不变特征转换)、SURF(Speeded Up Robust Features,加速鲁棒特征)、ORB(Oriented FAST and Rotated BRIEF,方向性的快速特征和旋转的BRIEF)、FAST(Features from Accelerated Segment Test,加速线段测试特征)都是常用的特征提取算法。
本文将对这四种算法进行比较,主要从算法原理、特点以及在不同应用场景的优缺点进行分析。
1.SIFT算法SIFT算法是由Lowe在1999年提出的一种获取图像局部特征的算法。
其主要兴趣点在于尺度不变特征的提取,通过尺度空间构建和关键点提取和描述来实现图像匹配。
SIFT算法的特点是具有旋转不变性、尺度不变性和光照不变性。
然而,SIFT算法计算复杂度较高,不适合实时应用。
2.SURF算法SURF算法是由Bay等人在2024年提出的一种加速鲁棒特征提取算法。
与SIFT算法相比,SURF算法主要优化了尺度空间构建、关键点检测和描述子生成等步骤。
SURF算法利用图像的Hessian矩阵来检测尺度空间的极值点,并通过Haar小波响应计算描述子。
该算法具有较好的尺度不变性和旋转不变性,同时计算速度更快。
然而,SURF算法对于局部对比度较低的图像特征提取效果较差。
3.ORB算法ORB算法是由Rublee等人在2024年提出的一种速度和描述能力兼具的特征提取算法。
该算法结合了FAST关键点检测和BRIEF描述子生成算法,并引入了旋转和尺度不变性。
ORB算法在FAST检测关键点时,通过计算像素灰度和检测周围点的弧长度来提高检测的稳定性。
在描述子生成过程中,ORB算法利用了方向梯度直方图(DOG)来提取关键点的旋转信息。
ORB算法具有快速、简单和可靠的特点,适合于实时应用。
多种角度比较SIFT、SURF、BRISK、ORB、FREAK算法
![多种角度比较SIFT、SURF、BRISK、ORB、FREAK算法](https://img.taocdn.com/s3/m/bdcb797f3868011ca300a6c30c2259010302f316.png)
多种角度比较SIFT、SURF、BRISK、ORB、FREAK算法一、本文概述随着计算机视觉技术的飞速发展,特征点检测与描述算法在图像匹配、目标识别、三维重建等领域扮演着举足轻重的角色。
在众多特征点算法中,SIFT(Scale-Invariant Feature Transform,尺度不变特征变换)、SURF(Speeded Up Robust Features,加速鲁棒特征)、BRISK(Binary Robust Invariant Scalable Keypoints,二进制鲁棒不变可伸缩关键点)、ORB(Oriented FAST and Rotated BRIEF,带方向性的FAST和旋转的BRIEF)以及FREAK(Fast Retina Keypoint,快速视网膜关键点)等算法因其优秀的性能而备受关注。
本文旨在对这五种算法进行多角度的比较分析,以便读者更全面地了解它们的性能特点,为实际应用提供参考。
我们将从算法原理、计算效率、特征点稳定性、抗噪声干扰能力、旋转不变性、尺度不变性等多个维度对五种算法进行深入探讨。
通过理论分析和实验验证,本文将揭示各算法在不同应用场景下的优势和不足,为算法的选择和优化提供有力依据。
本文还将结合实际应用案例,展示各算法在图像匹配、目标跟踪、全景拼接等领域的实际应用效果,以便读者更好地理解各算法在实际应用中的表现。
通过本文的阅读,读者将能够全面掌握五种主流特征点检测与描述算法的核心原理、性能特点和应用场景,为计算机视觉领域的深入研究和实践应用提供有力支持。
二、算法原理比较在深入了解SIFT、SURF、BRISK、ORB和FREAK这五种算法的原理之后,我们可以从多个角度对它们进行比较。
首先是特征点检测与描述子生成。
SIFT(尺度不变特征变换)通过DOG(差分高斯)金字塔来检测关键点,并使用128维向量进行描述。
SURF(加速鲁棒特征)则使用Hessian矩阵和积分图像进行关键点检测,并生成64维描述子。
Surf算法原理
![Surf算法原理](https://img.taocdn.com/s3/m/73dc00fb541810a6f524ccbff121dd36a32dc4b2.png)
Surf算法原理Surf算法是对Sift算法的⼀种改进,主要是在算法的执⾏效率上,⽐Sift算法来讲运⾏更快!1、算法原理;2、源码简析;3、OpenCV中Demo分析;4、⼀些关于Surf算法的剖析。
Surf算法原理:参考资料:作为尺度不变特征变换算法(Sift算法)的加速版,Surf算法在适中的条件下完成两幅图像中物体的匹配基本实现了实时处理,其快速的基础实际上只有⼀个——积分图像haar求导。
我们先来看介绍Sift算法的基本过程,然后再介绍Surf算法。
1、Sift算法简介Sift算法是David Lowe于1999年提出的局部特征描述⼦,并于2004年进⾏了更深⼊的发展和完善。
Sift特征匹配算法可以处理两幅图像之间发⽣平移、旋转、仿射变换情况下的匹配问题,具有很强的匹配能⼒。
总体来说,Sift算⼦具有以下特性:(1) 、Sift特征是图像的局部特征,对平移、旋转、尺度缩放、亮度变化、遮挡和噪声等具有良好的不变性,对视觉变化、仿射变换也保持⼀定程度的稳定性。
(2) 、独特性好,信息量丰富,适⽤于在海量特征数据库中进⾏快速、准确的匹配。
(3) 、多量性,即使少数的⼏个物体也可以产⽣⼤量Sift特征向量。
(4) 、速度相对较快,经优化的Sift匹配算法甚⾄可以达到实时的要求。
(5) 、可扩展性强,可以很⽅便的与其他形式的特征向量进⾏联合。
其 Sift算法的三⼤⼯序为,(1)提取关键点;(2)对关键点附加详细的信息(局部特征)也就是所谓的描述器;(3)通过两⽅特征点(附带上特征向量的关键点)的两两⽐较找出相互匹配的若⼲对特征点,也就建⽴了景物间的对应关系。
提取关键点和对关键点附加详细的信息(局部特征)也就是所谓的描述器可以称做是Sift特征的⽣成,即从多幅图像中提取对尺度缩放、旋转、亮度变化⽆关的特征向量,Sift特征的⽣成⼀般包括以下⼏个步骤:(1) 、构建尺度空间,检测极值点,获得尺度不变性;(2) 、特征点过滤并进⾏精确定位;(3) 、为特征点分配⽅向值;(4) 、⽣成特征描述⼦。
找特征点的算法SIFT和SURF算法
![找特征点的算法SIFT和SURF算法](https://img.taocdn.com/s3/m/a737158edb38376baf1ffc4ffe4733687e21fccb.png)
找特征点的算法SIFT和SURF算法SIFT算法和SURF算法是用于图像特征点的检测与描述的两种经典算法。
它们在图像处理、计算机视觉和模式识别等领域得到广泛应用。
下面将分别介绍SIFT算法和SURF算法,并对其原理和应用进行详细阐述。
一、SIFT算法(Scale-Invariant Feature Transform)SIFT算法是由Lowe于1999年提出的一种用于图像特征点检测与描述的算法。
它通过分析图像的局部特征来提取与尺度无关的特征点,具有尺度不变性、旋转不变性和仿射不变性等优点。
1.特征点检测SIFT算法首先通过高斯差分金字塔来检测图像中的特征点。
高斯差分金字塔是由一系列模糊后再进行差分操作得到的,通过不同尺度的高斯核函数对图像进行卷积,然后对结果进行差分运算,得到图像的拉普拉斯金字塔。
在拉普拉斯金字塔上,通过寻找局部最大值和最小值来确定特征点的位置。
2.特征点描述在确定特征点的位置后,SIFT算法使用梯度直方图表示特征点的局部特征。
首先,计算特征点周围邻域内每个像素点的梯度幅值和方向,然后将邻域分为若干个子区域,并统计每个子区域内的梯度幅值和方向的分布,最后将这些统计结果组合成一个向量作为特征点的描述子。
3.特征点匹配SIFT算法通过计算特征点描述子之间的欧式距离来进行特征点的匹配。
欧式距离越小表示两个特征点越相似,因此选择距离最近的两个特征点作为匹配对。
二、SURF算法(Speeded Up Robust Features)SURF算法是由Bay等人于2024年提出的一种在SIFT算法的基础上进行改进的图像特征点检测与描述算法。
它通过加速特征点的计算速度和增强特征点的稳定性来提高算法的实时性和鲁棒性。
1.特征点检测SURF算法使用Hessian矩阵来检测图像中的特征点。
Hessian矩阵是图像的二阶导数矩阵,通过计算Hessian矩阵的行列式和迹来确定图像的局部最大值和最小值,从而找到特征点的位置。
SURF原理及源码解析
![SURF原理及源码解析](https://img.taocdn.com/s3/m/22acc2a5d0f34693daef5ef7ba0d4a7302766c00.png)
SURF原理及源码解析版权声明:本⽂为CSDN博主「zhaocj」的原创⽂章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原⽂出处链接及本声明。
原⽂链接:SURF (Speeded Up Robust Features)是⼀种具有鲁棒性的局部特征检测算法,它⾸先由Herbert Bay等⼈于2006年提出,并在2008年进⾏了完善。
其实该算法是Herbert Bay在博⼠期间的研究内容,并作为博⼠毕业论⽂的⼀部分发表。
SURF算法的部分灵感来⾃于SIFT算法,但正如它的名字⼀样,该算法除了具有重复性⾼的检测器和可区分性好的描述符特点外,还具有很强的鲁棒性以及更⾼的运算速度,如Bay所述,SURF⾄少⽐SIFT快3倍以上,综合性能要优于SIFT算法。
与SIFT算法⼀样,SURF算法也在美国申请了专利。
与我的上⼀篇SIFT⽂章⼀样,该⽂分为原理解释、源码分析和应⽤实例。
但该⽂的内容也较多,对公式和图表的粘贴复制太⿇烦,所以我也把这篇⽂章上传到了百度⽂库和csdn,这样更⽅便⼤家阅读,⽹址为:在这⾥我仅把源码分析部分复制到这⾥,建议⼤家还是把原理和源码结合着看,这样更容易理解,所以最好还是看详细的全⽂。
实现SURF算法的⽂件为sources/modules/nonfree/src/surf.cppSURF类的构造函数为:SURF::SURF()SURF::SURF(doublehessianThreshold, int nOctaves=4, int nOctaveLayers=2, bool extended=true,bool upright=false )参数的含义为:hessianThreshold为Hessian矩阵⾏列式响应值的阈值nOctaves为图像堆的组数nOctaveLayers为图像堆中每组中的中间层数,该值加2等于每组图像中所包含的层数extended表⽰是128维描述符,还是64维描述符,为true时,表⽰128维描述符upright表⽰是否采⽤U-SURF算法,为true时,采⽤U-SURF算法SURF类的重载运算符( )为:void SURF::operator()(InputArray _img, InputArray _mask,CV_OUT vector<KeyPoint>& keypoints,OutputArray _descriptors,bool useProvidedKeypoints) const//_img表⽰输⼊8位灰度图像//_mask为掩码矩阵//keypoints为特征点⽮量数组//_descriptors为特征点描述符//useProvidedKeypoints表⽰是否运⾏特征点的检测,该值为true表⽰不进⾏特征点的检测,⽽只是利⽤输⼊的特征点进⾏特征点描述符的运算。
surf算法原理
![surf算法原理](https://img.taocdn.com/s3/m/b082318dafaad1f34693daef5ef7ba0d4a736de5.png)
surf算法原理宝子们!今天咱们来唠唠这个超有趣的SURF算法原理呀。
SURF呢,它全名叫加速稳健特征(Speeded - Up Robust Features)。
这名字听起来就感觉很厉害的样子,就像一个超级英雄,有着加速的超能力,还特别稳健呢。
咱先说说这个算法为啥要被搞出来。
你想啊,在图像的世界里,有那么多图像,就像有好多好多不同的小世界一样。
我们有时候想在这些图像里找到一些特别的东西,比如说两张照片里相同的物体啦,或者是在一张很复杂的图像里找到我们感兴趣的部分。
要是靠人工去一点点找,那可不得累死人,而且效率超低。
所以呢,就有了像SURF这样的算法。
那SURF算法到底是咋工作的呢?这就像是一场奇妙的探险之旅。
它先得把图像变得有规律起来。
就好比把一个乱糟糟的房间先简单整理一下,这样才能更好地找东西。
它会构建图像的积分图像。
这个积分图像可不得了,就像是给图像做了一个快速索引一样。
比如说你想知道图像里某个小方块的像素总和,要是没有这个积分图像,你得一个一个像素加起来,那得多慢呀。
但是有了积分图像,就可以一下子算出来,就像开了挂一样。
然后呢,SURF算法要找图像里的那些关键点。
这些关键点就像是图像里的小明星,是很特别的存在。
它怎么找呢?它会用一种类似小探测器的东西,在图像里到处探测。
这个探测器可不是随便探测的哦,它是根据图像的一些特性来的。
比如说图像里有些地方的亮度变化很特别,就像在一片平地上突然有个小土坡一样,这种地方就很可能是关键点。
找到这些关键点之后呢,SURF算法还得给它们做个标记,就像给小明星们戴上专属的小名牌一样,这样以后才能准确地找到它们。
接下来呀,SURF算法要描述这些关键点。
这就好比是给每个小明星写个小传一样。
它会根据关键点周围的像素信息来描述。
比如说关键点周围的像素是怎么分布的呀,是像星星一样散开,还是像小团子一样聚在一起呢。
它会用一些数学的方法把这些信息变成一串数字,这串数字就是这个关键点的独特描述啦。
计算机视觉:SIFT和SURF的比较
![计算机视觉:SIFT和SURF的比较](https://img.taocdn.com/s3/m/ec98b7e8370cba1aa8114431b90d6c85ed3a8876.png)
计算机视觉:SIFT和SURF的比较SIFT和SURF是计算机视觉中的两种不同的特征检测算法,它们都是在图像处理和计算机视觉中广泛使用的算法。
本文将会对这两个算法进行详细的比较分析。
一、算法概述SIFT算法(Scale-Invariant Feature Transform)是由David Lowe在1999年发表的一篇论文中提出的。
它是一种基于尺度空间理论和高斯差分算子的特征检测算法,可以在不同的尺度和旋转情况下提取出稳定的特征点。
SIFT算法的主要步骤包括:尺度空间构建、高斯差分金字塔、极值点检测、方向分配和特征描述。
SURF算法(Speeded-Up Robust Features)是在2006年由Herbert Bay等人提出的一种快速的特征检测算法。
它采用了Hessian 矩阵来检测特征点,并使用了一种加速技术,称为“积分图像”。
SURF算法的主要步骤包括:尺度空间构建、Hessian矩阵计算、特征点筛选、方向分配和特征描述。
二、算法优劣分析1.性能SIFT算法和SURF算法虽然都是图像处理和计算机视觉中非常常用的技术,但它们在性能方面存在着一些不同。
首先,相对于SIFT算法,SURF算法的计算速度更快。
SURF算法中使用的积分图像技术,能够大大提高算法的计算速度。
其次,SURF算法的特征点数量相对于SIFT算法来说较少,因此SURF算法的性能表现在低纬度特征点检测的任务上,要优于SIFT算法。
但是,在高维度的图像特征检测任务中,SIFT算法表现要比SURF算法好。
2.稳定性尺度不变性是计算机视觉中一个非常重要的性质。
在图像处理过程中,图像的尺度、旋转等条件的变化会给特征检测带来很大的困难。
在这方面,SIFT算法和SURF算法都能够很好的解决这个问题。
SIFT算法具有较好的稳定性,能够在不同的尺度下检测到相同的特征点,同时还能够检测出旋转不变性的特征点。
SURF算法在大多数情况下具备SIFT算法的稳定性,但在高纬度特征检测任务中,SURF算法的稳定性不如SIFT算法。
SURF算法
![SURF算法](https://img.taocdn.com/s3/m/7e003f82680203d8ce2f24f7.png)
SURF算法SURF是一种尺度、旋转不变的detector和descriptor。
最大的特点是快!在快的基础上保证性能(repeatability,distinctiveness 和robustness)。
SURF采用有效策略的主要有:1)积分图像(用于对图像卷积)2)detector 是基于Hessian矩阵,descriptor是基于分布的。
下面是SURF算法的具体实现:1.兴趣点检测SURF对于兴趣点的检测是基于最基本的Hessian近似矩阵。
1.1积分图像1.2 用于检测兴趣点的Hessian矩阵中得到启发,采用了盒子型滤波器(box filter)对上面的滤波器进行近似。
盒子型滤波器见图1.3.再根据filter的大小做一个归一化。
这对于尺度不变性是有必要的。
有了前面的着一些准备工作,就可以对一幅图像I计算每个点的近似Hessian矩阵的行列式值,将这些值存储,备用!1.3尺度空间表示算法的尺度不变性主要靠不同尺度下寻找感兴趣点。
谈到不同尺度就不得不说‘金字塔’。
Lowe在其SIFT大作中是这样构造尺度空间的:对原图像不断地进行Gauss平滑+降采样。
得到金字塔图像后,又进一步得到了DOG图,边和斑状结构就是通过DOG图得到其在原图的位置。
SURF中的做法与SIFT是有所不同的。
SIFT算法在构造金字塔图层时Gauss滤波器大小不变,改变的是图像的大小;而SURF则恰恰相反:图像大小保持不变,改变的是滤波器的大小。
之所以这么做的目的考虑的主要目的还是效率问题(这样可以利用积分图有关的快速计算,用不同size的Mask进行卷积运算,复杂度是一样的,仅仅是三个加减法而已)。
而且,由于没有对图像进行降采样,所以不存在混叠现象。
与SIFT类似,SURF的尺度空间也是按组(Octaves)划分的。
每一个Octave 里是对输入图像用size不断增加的filter进行滤波后得到的一系列响应。
总的来说,一组包含了一个缩放因子。
基于SURF算法的实时拼接研究
![基于SURF算法的实时拼接研究](https://img.taocdn.com/s3/m/661a4cb4d1d233d4b14e852458fb770bf78a3b9b.png)
基于SURF算法的实时拼接研究基于SURF算法的实时拼接研究摘要:图像拼接是计算机视觉领域中一个重要的研究方向,它可以将多幅图像无缝地拼接在一起,以形成一个更大的视觉场景。
本文主要研究了基于SURF算法的实时图像拼接技术。
首先介绍了SURF算法的原理和特点,然后详细讨论了SURF算法在图像匹配和特征点提取上的应用。
接着,提出了一种基于SURF算法的实时图像拼接方法,并进行了实验验证。
最后,对实验结果进行了分析和讨论,并展望了该技术在实际应用中的潜力。
1. 引言在计算机视觉中,图像拼接是一个热门的研究领域,它主要涉及将多个相机或者同一个相机的不同视角下拍摄的图像拼接在一起,以形成一个更大的视觉场景。
图像拼接技术在航空航天、地理测绘、虚拟现实等领域具有广泛的应用前景。
然而,实时图像拼接一直是一个挑战,因为它需要快速准确地检测和匹配特征点,并且进行高效的图像融合。
2. SURF算法原理和特点SURF(Speeded Up Robust Features)算法是一种用于图像特征点检测和描述的快速和鲁棒的方法,它基于稳定的尺度空间极值检测和快速的特征描述子构建。
相比于传统的SIFT算法,SURF算法具有更快的计算速度和更好的尺度不变性。
3. SURF算法在图像匹配和特征点提取上的应用图像匹配是图像拼接中的核心问题之一,而特征点的提取是图像匹配的基础。
本节主要介绍了SURF算法在图像匹配和特征点提取上的应用。
在图像匹配中,SURF算法通过计算特征向量之间的欧氏距离,得到两幅图像的匹配对。
而在特征点提取中,SURF算法通过计算Hessian矩阵的行列式来检测稳定的尺度空间极值点,并根据主曲率方向计算特征点的唯一描述子。
4. 基于SURF算法的实时图像拼接方法在本节中,我们提出了一种基于SURF算法的实时图像拼接方法。
首先,对输入图像进行SURF特征点提取和描述子计算。
然后,通过匹配特征点对来确定图像之间的对应关系。
SURF算法介绍
![SURF算法介绍](https://img.taocdn.com/s3/m/2118df587375a417866f8fa1.png)
蒙娜丽莎的图像匹配---SURF算法1.图像匹配1.1.图像匹配的概念图像匹配成为计算机视觉和图像处理中的一个重要技术。
其方法思想就是根据己知的图像在其他图像中查找出含有己知图像的过程。
图像匹配的架构流程如图1.1。
该技术的研究涉及到许多相关的知识领域,如图像预处理、图像采样、特征提取等,同时将计算机视觉、多维信号处理和数值计算等紧密结合在一起。
图像匹配技术还与图像融合、图像匹配等研究方向系系相关,为图像理解和图像复原等相关领域的研究提供基础。
图1.1图像匹配流程图图像匹配技术作为图像处理的关键技术之一,在国防领域和医学领域等得到广泛的研究和应用[2]。
如果在不同视角,或是不同时间,或是使用了不同的传感器获取到的两幅或多幅图像间存在共同区域,如何寻找到图像间的共同区域,就是图像匹配需要解决的问题。
1.2.图像匹配的算法组成图像匹配技术的分支很多,对图像匹配提出的构架也是千姿百态,根据布朗提出了图像匹配的组成要素,将图像匹配的要素主要分为四个方面,分别是图像的特征空间,为求取变换参数定义的搜索空间和搜索策略,图像匹配的相似性度量。
特征空间是指在待配图像和参考图像上提取到的一系列特征集合。
将提取到的特征进行描述后参与最后的匹配,因此特征选取的好坏直接影响匹配的可行性和匹配的效果。
好的特征是满足自动匹配的前提,因此选取的特征一般包含图像的关键信息,此类特征存在以下特性:首先,此类特征具有公有性、唯一性和显著性,保证匹配的顺利进行和匹配的精度;其次,此类特征具有多量性,而且分布合理,保证匹配的稳定性。
合理的特征空间会降低匹配算法的计算量,提高算法的性能。
相似性度量是指评判待匹配图像和参考图像上特征的相似程度,它很大程度上决定了参与匹配的因素,一般采用某种代价函数或者是距离函数来进行度量。
好的相似性度量不仅可以减少算法的计算量,而且对于算法的匹配性能和鲁棒性起着重要的作用。
搜索空间为求取图像变换参数的空间。
surf算法基本原理
![surf算法基本原理](https://img.taocdn.com/s3/m/e4c1bd58e97101f69e3143323968011ca300f7b2.png)
surf算法基本原理嘿,朋友们,今天咱们聊聊一个有趣的话题,SURF算法。
听起来像是什么神秘的黑科技,其实它是一种非常实用的图像处理算法。
说到图像处理,大家肯定会想起那些花里胡哨的滤镜,或者是手机上那些能把你自拍变得美美哒的应用。
可是,SURF可不是单纯的美颜,它在图像识别和计算机视觉方面可是大显身手的哦。
想象一下,你在拍照的时候,手机能迅速识别出照片里的物体,那背后就有可能有SURF在默默奉献。
SURF,全名叫加速稳健特征(SpeededUp Robust Features),听起来就很酷炫,对吧?这个算法的核心思想其实很简单。
它主要是通过检测和描述图像中的特征点,让计算机能够识别出图像的关键部分。
就好比你见到一个老朋友,虽然他换了发型,但一眼就能认出他来,这就是特征点在起作用。
SURF就是利用这些特征点,帮助计算机进行图像匹配和识别。
SURF是怎么实现的呢?它会找到图像中的特征点。
这就像在一大堆照片中找到最吸引眼球的那一张,难度可想而知。
但SURF可不是一般的算法,它使用了一种叫做“Hessian矩阵”的数学工具,能快速找出图像中的高对比度区域。
这些区域就是我们所说的特征点。
哎,这就像是在人群中找出最亮眼的星星,大家都想看嘛。
找到特征点之后,SURF可没闲着。
它会对这些点进行描述,生成一组特征向量。
简单说,就是给每个特征点贴上一个“标签”,告诉计算机这个点有什么特点。
这种描述方法又快又稳,确保在各种光照、旋转和缩放的情况下都能可靠地识别出这些特征点。
想象一下,风吹草动,照片的背景换了个样子,但你依然能认出那是你最爱的小狗。
这种可靠性真是令人赞叹!再说说SURF在实际应用中的表现。
比如在自动驾驶技术中,车载摄像头需要不断识别周围环境。
SURF帮助车辆识别路标、行人甚至其他车辆,确保安全驾驶。
就好像你在繁忙的街道中,灵活躲避那些横冲直撞的行人,这可不是简单的事儿。
但有了SURF,这一切都变得简单多了。
surf算法详解
![surf算法详解](https://img.taocdn.com/s3/m/06ec22dd195f312b3169a5f9.png)
SURF学习笔记Speed-Up Robust Features(SURF)SURF 是一种尺度,旋转不变的detector和descriptor.最大的特点是快!在快的基础上保证性能(repeatability,distinctiveness 和robustness)。
SURF采用有效策略的主要有:1)积分图(用于对图像卷积)2)detector是基于Hessian矩阵,descriptor是基于分布的下面是SURF算法的具体实现:1.兴趣点检测SURF 对于兴趣点的检测是基于最基本的Hessian近似矩阵。
1.1积分图像(由于不会在这里编辑公式,直接截图了)PS:这里加一点自己的一点个人理解:关于矩形区域内像素点的求和应该是一种简单重复性运算,采用这种思路总体上提高了效率。
为什么这么说呢?假设一幅图片共有n个像素点,则计算n个位置的积分图总共的加法运算有n-1次(注意:可不是次哦,要充分利用递推思想),将这些结果保存在一个跟原图对应的矩阵M中。
当需要计算图像中某个矩形区域内的所有像素之和是直接像查表一样,调出A,B,C,D四点的积分图值,简单的加减法(注意只需要三次哦)即可得到结果。
反之,如果采用naive的方式直接在原图像中的某个矩形区域内求和,你想想,总共可能的矩形组合有多少?!!且对于一幅图像n那是相当大啊,所以2^n那可是天文数字,而且这里面绝大部分的矩形有重叠,重叠意味着什么?在算求和的时候有重复性的工作,其实我们是可以有效的利用已经计算过的信息的。
这就是积分图法的内在思想:它实际上是先计算n个互不重叠(专业点说是不相交)的矩形区域内的像素点求和,充分利用这些值(已有值)计算未知值,有点类似递推的味道...这就完全避免了重复求和运算。
1.2 用于检测兴趣点的Hessian矩阵作者Herbert Bay利用Hessian矩阵来检测兴趣点,具体是用Hessian矩阵行列式的最大值标记斑状结构(blob-like structure)的位置。
SURF原理分析
![SURF原理分析](https://img.taocdn.com/s3/m/e8e5eb082379168884868762caaedd3383c4b51f.png)
SURF原理分析SURF (Speed Up Robust Features)是SIFT改进版也是加速版,提⾼了检测特征点的速度,综合性能要优于SIFT。
1.积分图像SURF是对积分图像进⾏操作,从⽽实现了加速,采⽤盒⼦滤波器计算每个像素点的Hessian矩阵⾏列式时,只需要⼏次加减法运算,⽽且运算量与盒⼦滤波器⼤⼩⽆关,所以能够快速的构成出SURF的尺度⾦字塔。
积分图像中每个像元的值,是原图像上对应位置的左上⾓所有元素之和如上图:我们要得到绿⾊矩形区域内的矩形像素之和S,只需要在积分图上,运算S=D-B-C+A就可以得到。
2.尺度空间的构造2.1对DoH的近似SIFT采⽤了对LoG的近似算法DoG,⽽SURF (Speed Up Robust Features) 采⽤对DoH近似进⾏特征点检测,LoG与DoH是检测特征点的两种常⽤⽅法。
连续函数f(x,y)的⼆阶微分Hessian矩阵。
我们可以利⽤Hessian矩阵的⾏列式值判断点(x,y)是否是极值点在离散空间上,为了得到Hessian矩阵的四个元素,SURF采⽤⼆阶标准⾼斯核函数的对图像卷积运算,因为⾼斯核可以构造出不同尺度下的响应图像。
在尺度σ下,点 X=(x,y) 处,对应的Hessian矩阵。
Lxx是标准⾼斯函数g(x,y,σ)的⼆阶偏导数与图像在点(x,y)处卷积的结果;同理,Lyy,Lxy的计算⽅法。
这样可以计算出图像上所有点的Hessian⾏列式值。
为了能加速运算,Bay等⼈采⽤盒⼦滤波器对⾼斯⼆阶微分模板近似处理。
Lyy Lxy Dyy Dxy如图所⽰,图1是y⽅向的⼆阶⾼斯微分模板,图3采⽤盒⼦滤波器对其进⾏近似,数字表⽰对应颜⾊区域的权值,灰⾊区域权值为0,采⽤盒⼦滤波器与图像卷积的结果记为Dxx,Dyy,Dxy。
因为盒⼦滤波器在积分图像上计算⾮常快。
由于是对原Hessian矩阵的近似,由相关推导可以证明采⽤下⾯的公式,更接近真实值。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
极值点 抑制
SURF 提取特征点
为了保证特征矢量具有旋转不变形,需要对每一个特征点 分配一个主要方向。需要以特征点为中心,以6s(s为特正点 的尺度)为半径的圆形区域内,对图像进行Haar小波响应运 算。这样做实际就是对图像进行了梯度运算,但是利用积分 图像,可以提高计算图像梯度的效率。为了求取主方向值, 需要设计一个以方向为中心,张角为PI/3的扇形滑动窗口,以 步长为0.2弧度左右,旋转这个滑动窗口,并对窗口内的图像 Haar小波的响应值进行累加。 主方向为最大的Haar响应累加 值对应的方向 。
式中,S(i,j)表示一列的积分,且S(i,-1)=0,n(-1,j)=0。 求积分图像,只需对原图像的所有像素进行一遍扫描。
积分图像
SURF 提取特征点
盒子滤波结构: ShotHessianTemplate[]={
3,0,2,2,6,15,1, 3,2,5,6,15,-2, 6,2,8,6,15,1, 0,0,0,0,0,0,
如果行列式的结果符号为负,则特征值有不 同的符号,则不是局部极值点。 如果行列式的符号为正,则该行列式的两个 特征值同为正或负,所以该店可以归类为极值 点。
快速 Hessian
SURF 提取特征点
由于采用的盒子滤波和积分图像,不需要像SIFT算法 那样去直接建立金字塔图像,而是采用不断增大的盒子滤 波模板的尺寸的间接方法。通过不同尺寸盒子滤波模板和 积分图像求取Hessian矩阵行列式的响应图像,然后,在 响应图像上采用3D非最大值抑制,求取各种不同尺度的斑 点。 模板
旋转到主方向
主方向 5s*5s
生成特 征矢量
SURF 匹配特征点
步骤1. 在检测特征点的过程中,计算了 Hessian 矩阵 的行列式,与此同时,计算得到了 Hessian 矩阵的迹,矩 阵的迹为对角元素之和。 按照亮度的不同,可以将特征点分为两种,第一种为 特征点及其周围小邻域的亮度比背景区域要亮,Hessian 矩阵的迹为正;另外一种为特征点及其周围小邻域的亮度 比背景区域要暗,Hessian 矩阵为负值。根据这个特性, 首先对两个特征点的 Hessian 的迹进行比较。如果同号, 说明两个特征点具有相同的对比度;如果是异号的话,说 明两个特征点的对比度不同,放弃特征点之间后续的相似 特征点 性度量。
匹配
SURF 匹配特征点
步骤2.对于两个特征点描述子的相似性度量,我们采用 欧式距离进行计算:
式中,Xik表示待配准图中第 i 个特征描述子的第 k 个元素, Xjk是参考图中第 j个特征描述子的第k 个元素, n表示特征向量的维数。 。
特征点 匹配
SURF 匹配特征点
对于待配准图上的特征点,计算它到参考图像上所有 特征点的欧氏距离,得到一个距离集合。通过对距离集 合进行比较运算得到小欧氏距离和次最小欧式距离。设 定一个阈值,一般为 0.8,当最小欧氏距离和次最小欧式 距离的比值小于该阈值时,认为特征点与对应最小欧氏 距离的特征点是匹配的,否则没有点与该特征点相匹配。 阈值越小,匹配越稳定,但极值点越少。
特征点 匹配
i ' i , j ' j
p ( i ' , j ' ) 式中,P(i’,j’)表
A
B
D
SABCD=D-C-B+A
C
积分图像
SURF 提取特征点
上式子中n(i,j)可以用以下两式子迭代计算得到 S(i,j)=S(i,j-1)+p(i,j) n(i,j)=n(i-1,j)+S(i,j)
……}
第1位:滤波器盒子数量 第4、5位:第1个盒子右下角坐标 第7位:盒子填充值 第2、3位:第1个盒子左上角坐标 第6位:RF 提取特征点
在SURF中,采用近似的Hessian矩阵的行列式的局部 最大值来定位感兴趣点的位置。当Hessian行列式的局部值 最大的时候,所检测出来的就是感兴趣点。感兴趣点的特 征为比周围邻域更亮或者更暗一些。 给定图像f(x,y)中一个点 (x,y),其Hessian矩阵H(x,o) 定义如下:
构建尺 度空间
图片 SIFT构建尺度空间 SURF构建尺度空间
SURF 提取特征点
与SIFT相类似,SURF也将尺度空间划分成若干组 (Octaves)。一个组代表了逐步放大的滤波模板对同一个 输入图像进行滤波的一系列响应图像。每一组又有若干 固定的层组成。
变 化 量
51 27 15 27 15 51
特征点 方向分配
旋转窗口
SURF 提取特征点
生成特征点的特征矢量需要计算图像的Haar小波响应。 在一个矩形的区域内,以特征点为中心,沿主方向将 20s*20s的图像划分成4*4个子块,每个子块利用尺寸2s 的Haar小波模板进行响应计算,然后对响应值进行统 计 d x , d x , d y , d y 形成的特征矢量 。
99
147 195
Octaves
6*n
75 99 构建尺 度空间
39 51
变化量 n*6
9
21 27
Scale
SURF 提取特征点
为了在目标影像上确定SURF特征点,我们使用了 3*3*3的模板在3维尺度空间进行非最大化抑制,根据 预设的Hessian阈值H,当h大于H,而且比临近的26 个点的响应值都大的点才被选为兴趣点。最后进行插 值精确。
SURF算法分析
SURF 介绍
SURF (Speeded Up Robust Feature)是一种高鲁 棒性的局部特征点检测器。由Herbert Bay 等人在2006 年提出。该算法可以用于计算机视觉领域例如物体识 别或者三维重建。根据作者描述该算法比SIFT更快更 加具有鲁棒性。该算法中采用积分图像、Haar小波变 换和近似的Hessian矩阵运算来提高时间效率,采用 Haar小波变换增加鲁棒性。 参考程序:
/computer-vision-opensurf.html
SURF 提取特征点
积分图像中任意一点I(i,j)的值n(i,j),为原图像左上 角到该任意点I(i,j)相应的对角线区域灰度值的总和,即:
n(i,j)= 示原图像中(i’,j’)的灰度值
2 f 2 f 2 x xy H ( f ( x , y )) 2 f 2 f 2 xy y
位置
尺度
快速 Hessian
SURF 提取特征点
加权系数 Lxx是高斯模板与图像卷积 Dxx是盒子模板与图像卷积 用Dxx近似代替Lxx