SIFT算法小结

合集下载

sift算法的原理和步骤

sift算法的原理和步骤

sift算法的原理和步骤SIFT算法的原理和步骤SIFT算法是一种用于图像特征提取的算法,它能够从图像中提取出具有独特性、稳定性和可重复性的关键点,用于图像匹配、目标跟踪等任务。

本文将介绍SIFT算法的原理和步骤。

一、原理1. 尺度空间尺度空间是指同一物体在不同尺度下的表现形式。

SIFT算法采用高斯金字塔来实现尺度空间的构建,即将原始图像不断缩小并平滑处理,得到一系列模糊程度不同的图像。

2. 关键点检测在尺度空间中,SIFT算法采用DoG(Difference of Gaussian)来检测关键点。

DoG是指两个不同尺寸的高斯滤波器之间的差值,可以有效地提取出具有高斯拉普拉斯变换极值点(LoG)特征的区域。

3. 方向确定对于每个关键点,在其周围区域内计算梯度幅值和方向,并统计梯度直方图。

最终确定该关键点最显著的梯度方向作为其主方向。

4. 描述子生成以关键点为中心,生成一个16x16的方形区域,并将其分为4x4的小块。

对于每个小块,计算其内部像素的梯度方向直方图,并将其串联成一个128维的向量,作为该关键点的描述子。

5. 匹配通过计算不同图像之间的关键点描述子之间的距离来进行匹配。

采用最近邻法(Nearest Neighbor)和次近邻法(Second Nearest Neighbor)来进行筛选,从而得到最终的匹配结果。

二、步骤1. 构建高斯金字塔对于原始图像,采用高斯滤波器进行平滑处理,并将其缩小一定比例后再次平滑处理,得到一系列不同尺度下的图像。

这些图像构成了高斯金字塔。

2. 构建DoG金字塔在高斯金字塔中,相邻两层之间做差得到一组DoG金字塔。

通过在DoG金字塔上寻找局部极值点来检测关键点。

3. 确定关键点主方向对于每个关键点,在其周围区域内计算梯度幅值和方向,并统计梯度直方图。

最终确定该关键点最显著的梯度方向作为其主方向。

4. 生成描述子以关键点为中心,生成一个16x16的方形区域,并将其分为4x4的小块。

sift算法原理

sift算法原理

sift算法原理SIFT算法原理。

SIFT(Scale-invariant feature transform)算法是一种用于图像处理和计算机视觉领域的特征提取算法。

它能够在不同尺度和旋转角度下提取出稳定的特征点,并且对光照、噪声等干扰具有较强的鲁棒性。

SIFT算法由David Lowe于1999年提出,至今仍被广泛应用于图像拼接、目标识别、三维重建等领域。

本文将介绍SIFT算法的原理及其关键步骤。

1. 尺度空间极值检测。

SIFT算法首先通过高斯滤波构建图像的尺度空间金字塔,然后在不同尺度空间上寻找局部极值点作为关键点。

这些关键点在不同尺度下具有不变性,能够在不同大小的目标上被检测到。

2. 关键点定位。

在尺度空间极值点的基础上,SIFT算法通过对尺度空间进行插值,精确定位关键点的位置和尺度。

同时,为了提高关键点的稳定性,还会对梯度方向进行进一步的精确计算。

3. 方向分配。

为了使关键点对旋转具有不变性,SIFT算法会计算关键点周围像素点的梯度方向直方图,并选择主方向作为关键点的方向。

这样可以使得关键点对于图像的旋转具有不变性。

4. 特征描述。

在确定了关键点的位置、尺度和方向后,SIFT算法会以关键点为中心,提取周围区域的梯度信息,并将其转换为具有较强区分度的特征向量。

这些特征向量可以很好地描述关键点周围的图像信息,从而实现对图像的匹配和识别。

5. 特征匹配。

最后,SIFT算法使用特征向量进行特征匹配,通常采用欧氏距离或者余弦相似度进行特征匹配。

通过匹配不同图像的特征点,可以实现图像的配准、目标的识别等应用。

总结。

SIFT算法作为一种经典的特征提取算法,在图像处理和计算机视觉领域具有重要的应用价值。

其关键在于通过尺度空间极值点的检测和特征描述子的构建,实现了对图像的稳健特征提取。

同时,SIFT算法对于光照、噪声等干扰具有较强的鲁棒性,能够应对复杂环境下的图像处理任务。

因此,SIFT算法在目标识别、图像拼接、三维重建等领域有着广泛的应用前景。

(完整word版)SIFT算法分析

(完整word版)SIFT算法分析

SIFT算法分析1 SIFT主要思想SIFT算法是一种提取局部特征的算法,在尺度空间寻找极值点,提取位置,尺度,旋转不变量。

2 SIFT算法的主要特点:a) SIFT特征是图像的局部特征,其对旋转、尺度缩放、亮度变化保持不变性,对视角变化、仿射变换、噪声也保持一定程度的稳定性。

b)独特性(Distinctiveness)好,信息量丰富,适用于在海量特征数据库中进行快速、准确的匹配.c) 多量性,即使少数的几个物体也可以产生大量SIFT特征向量。

d) 高速性,经优化的SIFT匹配算法甚至可以达到实时的要求。

e) 可扩展性,可以很方便的与其他形式的特征向量进行联合.3 SIFT算法流程图:4 SIFT 算法详细1)尺度空间的生成尺度空间理论目的是模拟图像数据的多尺度特征。

高斯卷积核是实现尺度变换的唯一线性核,于是一副二维图像的尺度空间定义为: ),(),,(),,(y x I y x G y x L *=σσ 其中 ),,(σy x G 是尺度可变高斯函数,2)(22/21),,(22σπσσy xe y x G +-=(x,y )是空间坐标,σ是尺度坐标。

σ大小决定图像的平滑程度,大尺度对应图像的概貌特征,小尺度对应图像的细节特征。

大的σ值对应粗糙尺度(低分辨率),反之,对应精细尺度(高分辨率)。

为了有效的在尺度空间检测到稳定的关键点,提出了高斯差分尺度空间(DOG scale —space )。

利用不同尺度的高斯差分核与图像卷积生成。

),,(),,(),()),,(),,((),,(σσσσσy x L k y x L y x I y x G k y x G y x D -=*-= DOG 算子计算简单,是尺度归一化的LoG 算子的近似。

图像金字塔的构建:图像金字塔共O 组,每组有S 层,下一组的图像由上一组图像降采样得到。

图1由两组高斯尺度空间图像示例金字塔的构建, 第二组的第一副图像由第一组的第一副到最后一副图像由一个因子2降采样得到.图2 DoG算子的构建:图1 Two octaves of a Gaussian scale-space image pyramid with s =2 intervals. The first image in the second octave is created by down sampling to last image in the previous图2 The difference of two adjacent intervals in the Gaussian scale—space pyramid create an interval in the difference—of—Gaussian pyramid (shown in green)。

sift算法报告

sift算法报告
1.对图像做降采样(隔点采样)
2.对图像做不同尺度的高斯模糊
高斯差分金字塔

DOG函数:

高斯差分金字塔通过高斯金字塔每组中相邻上下两层图 像相减得到
极值检测

一个点如果在DOG尺度空间本层以及上下两层的26个 领域中像素是最大或最小值时,就认为该点是图像在该 尺度下的一个关键点。
二、关键点定位
sift特征特点

是图像的局部特征,其对旋转、尺度缩放、亮 度变化保持不变性,对视角变化、仿射变换、 噪声也保持一定程度的稳定性
独特性,适用于在海量特征数据库中进行快速、 准确的匹配 多量性,即使是一个很小的物体也可以产生大 量的SIFT特征 高速性,经优化的SIFT匹配算法可以达到实 时的要求

SIFT特征提取介绍
Scale-invariant feature transform,尺度不变特征变换
CONTENTS
sift特征概述
sift特征特点
sift特征提取过程
sift特征匹配
sift特征概述

SIFT是基于尺度空间的,对图像平移、旋转、缩放、 甚至仿射变换保持不变性的图像局部特征描述算子
④将关键点描述子向量归一化为单位向量


所有的关键点都用128维特征向量表示,至此, 就得到了SIFT特征描述子。
SIFT特征匹配

采用两幅图像关键点特征向量的欧氏距离作为关键点相 似性判定度量

d(Ri,Sj)/d(Ri,Sp)<某个阀值,则接受这一对匹配点

计算关键点邻域内图像梯度的模值和方向:


用梯度直方图统计邻域内像素的梯度和方向:
直方图以每10方向为一个柱,共36个柱

找特征点的算法SIFT和SURF算法

找特征点的算法SIFT和SURF算法

找特征点的算法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矩阵的行列式和迹来确定图像的局部最大值和最小值,从而找到特征点的位置。

SIFT特征提取算法

SIFT特征提取算法

SIFT特征提取算法SIFT(Scale-Invariant Feature Transform)特征提取算法是一种用于图像的局部特征分析的算法。

它能够提取出图像中的关键点,并对这些关键点进行描述,从而可以用于图像匹配、物体识别等应用领域。

本文将详细介绍SIFT算法的原理和过程。

1.尺度空间构建SIFT算法首先通过使用高斯滤波器来构建图像的尺度空间,以便在不同尺度下检测关键点。

高斯滤波器可以通过一系列的高斯卷积操作实现,每次卷积之后对图像进行下采样(降低分辨率),得到不同尺度的图像。

2.关键点检测在尺度空间构建完成后,SIFT算法使用差分运算来检测关键点。

差分运算可以通过对图像进行高斯平滑操作来实现,然后计算相邻尺度之间的差分图像。

对差分图像进行极值检测,即寻找局部最大和最小值的像素点,这些像素点就是图像中的关键点。

3.关键点精确定位关键点的精确定位是通过拟合关键点周围的局部图像来实现的。

SIFT算法使用了一种高度鲁棒的方法,即利用关键点周围梯度的方向和大小来进行拟合。

具体来说,SIFT算法在关键点周围计算图像的梯度幅值和方向,并构建梯度直方图。

然后通过在梯度直方图中寻找局部极值来确定关键点的方向。

4.关键点描述关键点的描述是为了提取关键点周围的特征向量,用于后续的匹配和识别。

SIFT算法使用了一种局部特征描述算法,即将关键点周围的图像区域划分为小的子区域,并计算每个子区域的梯度方向直方图。

然后将这些直方图组合起来,构成一个维度较高的特征向量。

5.特征向量匹配在完成关键点描述之后,SIFT算法使用一种近似的最近邻方法来进行特征向量的匹配。

具体来说,使用KD树或者暴力匹配的方法来寻找两幅图像中最相似的特征向量。

通过计算特征向量之间的距离,可以找到最相似的匹配对。

6.尺度不变性SIFT算法具有尺度不变性的特点,即对于图像的缩放、旋转和视角变化等变换具有较好的鲁棒性。

这是因为在特征提取的过程中,SIFT算法对图像进行了多尺度的分析,并利用了关键点周围的梯度信息进行描述。

SIFT算法原理

SIFT算法原理

SIFT算法原理SIFT(Scale-Invariant Feature Transform,尺度不变特征变换)是一种用于图像处理和计算机视觉中的特征提取算法。

SIFT算法最初由David Lowe于1999年提出,它的核心思想是通过检测图像中的关键点,并提取这些关键点周围的局部特征描述子来进行图像匹配、物体识别、图像拼接等应用。

1.尺度空间构建首先,为了使SIFT算法对图像特征具有尺度不变性,需要构建一系列尺度空间图像。

这是通过将原始图像应用高斯模糊,然后进行下采样得到不同尺度的图像来实现的。

在每个尺度级别上,通过使用高斯差分金字塔(Difference of Gaussian,DoG)来提取图像中的关键点。

2.极值点检测在尺度空间中,通过在DoG金字塔中寻找局部极值点来检测关键点。

这些局部极值点通常表示图像中的显著特征点。

3.关键点定位对于每个检测到的极值点,需要通过拟合其周围的梯度方向来确定更加精确的位置和尺度。

这可以找到关键点的精确位置,并且作为后续步骤的输入。

4.方向分配为了使SIFT算法具有旋转不变性,需要为每个关键点分配一个主方向。

这可以通过计算关键点周围区域的梯度方向直方图来实现。

选择直方图中峰值最高的方向作为主方向。

5.特征描述在关键点的周围区域内,通过计算局部区域的梯度幅值和方向来构建特征描述子。

这些特征描述子对尺度、旋转和光照等变化都具有较强的鲁棒性,可以用来进行匹配和识别。

总的来说,SIFT算法通过构建尺度空间,检测局部极值点,定位关键点,分配主方向以及构建特征描述子等步骤,提取出图像中的稳定且具有鲁棒性的特征点。

这些特征点可以用于图像匹配、物体识别、图像拼接等计算机视觉任务,并且对尺度、旋转以及光照等变化具有一定的不变性。

SIFT算法在实际应用中具有广泛的应用价值,并成为计算机视觉领域中最经典的特征提取算法之一1.尺度空间构建2.关键点检测3.关键点定位对于检测到的关键点,SIFT算法通过拟合其周围的梯度方向来定位关键点的精确位置和尺度。

SIFT算法详解及应用

SIFT算法详解及应用

SIFT算法详解及应用SIFT(Scale-Invariant Feature Transform)是一种在计算机视觉中常用的特征点提取算法,由David Lowe在1999年提出,并在2004年的论文中进行了详细阐述。

SIFT算法可以在不同尺度和旋转下保持图像的特征点不变性,因此在图像拼接、目标识别、图像匹配等领域具有广泛的应用。

1.尺度空间构建:SIFT算法使用高斯差分函数来检测不同尺度下的特征点。

通过在图像中采用不同尺度的高斯滤波,构建尺度空间,从而检测到不同尺度的图像特征。

2.关键点提取:在构建的尺度空间中,SIFT算法通过在每个像素点检测局部极值点来获取关键点。

具体的做法是对每个像素点在尺度空间上进行比较,找出该点与它相邻像素点和尺度上的极值,从而得到关键点。

3. 关键点定位:在关键点提取后,SIFT算法通过利用二阶偏导数的Hessian矩阵来对关键点进行进一步定位。

Hessian矩阵可以描述图像对灰度变化的响应,通过计算关键点周围像素点的Hessian矩阵,可以对关键点进行精确定位。

4.方向分配:在关键点定位后,SIFT算法为每个关键点分配一个主导方向。

通过对关键点周围的图像梯度进行统计,找到梯度方向分布最大的方向作为主导方向,以此来保证关键点对旋转具有不变性。

5.特征描述:在分配了主导方向后,SIFT算法使用局部图像梯度的方向直方图来描述关键点的局部特征。

将关键点周围的16x16邻域划分为4x4的小格子,计算每个小格子内的梯度方向直方图,最终得到一个128维的特征向量来表示关键点的局部特征。

1.尺度不变性:SIFT算法通过在不同尺度下检测特征点,使得算法对于图像缩放具有不变性。

这一特性使得SIFT在目标识别和图像匹配等领域具有广泛应用,可以应对不同尺寸的目标和场景。

2.旋转不变性:SIFT算法通过为每个关键点分配主导方向,使得算法对于图像旋转具有不变性。

这一特性使得SIFT在图像拼接和图像匹配中能够应对图像的旋转变换。

sift(尺度不变特征变换)的原理

sift(尺度不变特征变换)的原理

sift(尺度不变特征变换)的原理尺度不变特征变换(Scale-Invariant Feature Transform,简称SIFT)是一种用于图像处理和计算机视觉领域的特征提取算法,由David Lowe在1999年首次提出。

与其他特征提取算法相比,SIFT具有尺度不变性、旋转不变性、光照不变性和局部性等特点,因此在许多应用领域中得到了广泛应用,如物体识别、图像匹配和三维重建等。

SIFT算法主要包括四个关键步骤:尺度空间极值点检测、关键点定位、关键点方向分配和局部特征描述。

第一步,尺度空间极值点检测。

图像中的一个关键点应该能在不同尺度的图像中被检测到。

为了实现尺度不变性,SIFT算法采用高斯差分函数(Difference of Gaussian, DoG)来检测尺度空间中的极值点。

高斯差分图像是通过两个不同尺度的高斯模糊图像相减得到的。

在不同的尺度和位置上,对差分图像进行非极大值抑制和阈值处理,得到稳定的关键点。

第二步,关键点定位。

在每个尺度空间中检测到的极值点需要进行精确定位,以提取具有稳定性和鲁棒性的关键点。

SIFT算法引入了尺度空间的二阶偏导数来计算关键点的位置和尺度。

通过建立高斯金字塔,利用图像的不同分辨率,通过差分图像计算尺度。

然后,在关键点周围的邻域内,通过二阶偏导数来确定关键点的位置。

第三步,关键点方向分配。

为了使计算机具有旋转不变性,SIFT算法需要为每个关键点分配一个主方向。

在关键点周围的邻域内,计算梯度幅值和方向,构建梯度直方图。

然后,在梯度直方图中寻找主方向,选取梯度幅值最大的方向作为关键点的主方向。

第四步,局部特征描述。

SIFT算法通过关键点的局部邻域计算局部特征描述子,以实现光照不变性和局部性。

在关键点周围的邻域内,通过建立一个统一的坐标系,将关键点归一化为固定大小的邻域。

然后,在归一化的邻域内计算梯度幅值和方向。

为了增强鲁棒性,SIFT采用了高斯加权窗口来抑制噪声和光照变化的影响。

SIFT算法详解及应用

SIFT算法详解及应用

SIFT算法详解及应用SIFT(Scale-Invariant Feature Transform)是一种用于图像处理和计算机视觉中的特征提取算法。

它的主要目标是提取具有尺度和旋转不变性的局部特征点。

SIFT算法的独特之处在于它不依赖于特定的图像属性,而是通过一系列处理步骤构建出具有稳定性和描述性的特征点。

1. 尺度空间极值检测(Scale Space Extrema Detection):通过在不同的尺度上使用高斯差分函数,找到图像中的极值点作为潜在特征点。

2. 关键点定位(Keypoint Localization):在尺度空间中找到极值点后,使用插值方法精确定位特征点的位置。

同时,通过计算Hessian矩阵的主曲率来排除边缘响应。

3. 方向分配(Orientation Assignment):为每个特征点分配一个主要的方向,使得后续的特征描述能够具有旋转不变性。

4. 特征描述(Feature Description):根据每个特征点的主方向,构建特征描述子。

描述子被构建为一个128维的向量,它具有对尺度、旋转和光照变化的不变性。

5. 特征匹配(Feature Matching):通过比较特征描述子,找到两幅图像中具有相似特征的匹配点。

常用的方法是计算特征向量之间的欧式距离或相似性度量。

1.目标识别:SIFT算法可以检测并描述图像中的关键点,通过与预先训练好的模板特征进行匹配,可以在输入图像中快速准确地定位和识别目标物体。

2.图像拼接:SIFT算法可以提取图像中的特征点,并通过对这些特征点进行匹配来确定它们之间的对应关系。

这样,可以将多张图像拼接在一起,生成一个大的全景图像。

3.目标跟踪:SIFT算法可以提取图像中的关键点,并构建其特征描述子。

通过与之前的图像帧进行匹配,可以实现目标的跟踪和定位。

4.三维重建:使用多个图像拍摄同一场景,并通过SIFT算法提取特征点并进行匹配,可以推断出相机的位置和场景的结构,从而实现三维重建。

尺度空间理论和SIFT算法小结

尺度空间理论和SIFT算法小结

尺度空间理论尺度空间(scalesPace)思想最早由Iijima 于1962年提出([l]),但当时并未引起算机视觉领域研究者们的足够注意,直到上世纪八十年代,witkin([2])Koenderink([3])等人的奠基性工作使得尺度空间方法逐渐得到关注和发展。

此后,随着非线性扩散方程、变分法和数学形态学等方法在计算机视觉领域中的广泛应用,尺度空间方法进入了快速发展阶段。

尺度空间方法本质上是偏微分方程对图像的作用。

尺度空间方法的基本思想是:在视觉信息(图像信息)处理模型中引入一个被视为尺度的参数,通过连续变化尺度参数获得不同尺度下的视觉处理信息,然后综合这些信息以深入地挖掘图像的本质特征。

尺度空间方法将传统的单尺度视觉信息处理技术纳入尺度不断变化的动态分析框架中,因此更容易获得图像的本质特征。

尺度空间的生成目的是模拟图像数据的多尺度特征。

高斯卷积核是实现尺度变换的唯一线性核。

尺度空间是一个用来控制观察尺度或表征图像数据多尺度自然特性的框架;信号的尺度空间表征是信号的特征结构集合并包含有一个连续的尺度参量(即观察尺度)。

尺度空间理论[8]是通过对原始图像进行尺度变换,获得图像多尺度下的尺度空间表示序列,对这些序列进行尺度空间主轮廓的提取,并以该主轮廓作为一种特征向量,实现边缘、角点检测和不同分辨率上的特征提取等。

尺度空间表示是一种基于区域而不是基于边缘的表达,它无需关于图像的先验知识。

与通过减小图像尺寸而提高计算效率的其他多尺度或多分辨率表达相比,尺度空间表示由平滑获得,在多由尺度上都保持了不变的空间取样,但对同一特征而言,它在粗糙尺度上对应更多的像素点,这样就使得对这些数据的计算任务得到连续的简化。

尺度空间表示的另一个重要特征,就是基于尺度的结构特性能以一种简单的方式解析的表达,不同尺度上的特征可以一种精确的方式联系起来。

作为尺度空间理论中的一个重要概念,尺度空间核被定义为:in out f K f *= (1)对于所有的信号in f ,若它与变换核K 卷积后得到的信号out f 中的极值(一阶微分过零点数)不超过原图像的极值,则称K 为尺度空间核,所进行的卷积变换称为尺度变换。

SIFT特征提取算法

SIFT特征提取算法

SIFT特征提取算法SIFT特征提取算法(Scale-Invariant Feature Transform)是一种计算机视觉领域广泛应用的特征提取算法,它具有尺度不变性和旋转不变性的特点,能够在图像中鲁棒地提取出关键点,并生成与这些关键点相关的描述子,以实现图像特征的匹配和识别。

SIFT特征提取算法包含以下几个重要的步骤:尺度空间极值检测、关键点定位、关键点方向确定、关键点描述子生成等。

首先,SIFT特征提取算法从一幅图像中构建尺度空间。

为了实现尺度不变性,SIFT算法利用高斯金字塔模拟不同尺度下的图像,通过对图像进行多次高斯模糊操作得到一系列尺度不同的图像。

然后,通过对这些图像进行差分运算,得到一组差分图像用于尺度空间极值检测。

接下来,SIFT算法从尺度空间极值检测结果中选取稳定的关键点。

在差分图像中,极值点表示着尺度空间中的局部最大值或最小值,这些极值点对应着图像中的关键点。

为了保证关键点的稳定性,SIFT算法会过滤掉一些不稳定的候选关键点,例如低对比度的关键点和边缘响应较大的关键点。

然后,对于选取的关键点,SIFT算法会计算它们的主方向。

利用关键点附近的梯度直方图,SIFT算法可以确定关键点的方向。

这个主方向可以提高后续描述子生成的旋转不变性。

最后,SIFT算法根据关键点的位置和主方向生成关键点的描述子。

在关键点周围的邻域内,SIFT算法通过计算邻域内像素的梯度幅值和方向,生成一个特征向量来描述关键点的外观特征。

这个特征向量被称为SIFT特征描述子,通常是一个128维的向量。

为了保证描述子的不变性,SIFT算法对特征向量进行了归一化和方向旋转等处理。

总结来说,SIFT特征提取算法通过尺度空间极值检测、关键点定位、关键点方向确定和关键点描述子生成等步骤,能够从图像中提取出具有尺度不变性和旋转不变性的关键点和描述子。

SIFT特征提取算法在计算机视觉领域有着广泛的应用,例如图像匹配、物体识别和三维重建等任务中都能够发挥重要作用。

SIFT特征提取算法详解

SIFT特征提取算法详解

SIFT特征提取算法详解SIFT(Scale-Invariant Feature Transform)特征提取算法是一种用于在图像中寻找关键点的方法,该算法具有尺度不变性,能够提取出能够对图像进行描述的稳定的局部特征。

本文将从算法原理、关键步骤以及优缺点等方面进行详细解析。

一、算法原理SIFT算法的主要思想是通过寻找关键点和计算这些关键点的特征向量,来描述图像中的局部特征,并实现对尺度、旋转和亮度的不变性。

1.尺度空间极值检测SIFT算法首先通过DoG(Difference of Gaussian)来检测图像中的关键点。

DoG是指在不同尺度下的高斯平滑图像之间的差异,这样可以有效地检测出图像中的尺度空间极值点。

2.关键点精确定位通过在DoG金字塔中精确定位关键点,SIFT算法可以找到图像中的关键点。

该算法使用了Hessian矩阵的近似来计算特征点的位置和尺度,并用Taylor展开来精确计算特征点的位置。

3.方向分配为了使特征具有旋转不变性,SIFT算法通过计算特征点周围的梯度方向直方图来分配特征点的主方向。

具体步骤是确定特征点周围像素的梯度幅值和方向,并将方向分配到主方向上。

4.特征描述在计算了特征点的尺度和方向之后,SIFT算法通过计算特征点周围的局部图像块的梯度直方图来描述特征。

这些梯度直方图能够描述特征点周围的领域特征,并且具有尺度和旋转不变性。

二、关键步骤详解1.构建高斯金字塔SIFT算法首先对输入的图像进行平滑处理,然后通过不断降采样生成高斯金字塔。

高斯金字塔能够提供多尺度图像。

2.构建差分金字塔利用高斯金字塔计算DoG金字塔。

通过对相邻两层高斯图像进行差分操作,可以得到相应的两层DoG图像。

3.检测尺度空间极值点在DoG金字塔上,通过比较每一个像素点与其8邻域和相邻的26个像素点的像素值来确定极值点。

具体方法是通过比较每一层图像的像素值与周围像素值进行判定。

4.精确定位关键点通过利用Taylor展开公式来精确定位关键点的位置,这可以减小特征点在尺度和位置上的误差。

特征点匹配——SIFT算法详解

特征点匹配——SIFT算法详解

特征点匹配——SIFT算法详解SIFT(Scale-Invariant Feature Transform)是一种用于在图像中寻找关键点并进行匹配的算法。

该算法由David Lowe在1999年发布,并且一直被广泛应用于计算机视觉领域。

SIFT算法具有尺度不变性和旋转不变性,可以在不同的图像尺度和旋转角度下进行特征点的匹配。

SIFT算法的主要步骤包括关键点检测、关键点描述和特征点匹配。

关键点检测:在一张图像中,关键点通常是指存在于不同尺度和方向上的局部最大值或局部最小值。

SIFT使用高斯差分金字塔来检测关键点。

首先,通过对原始图像进行高斯模糊,创建一个金字塔,然后在每一组金字塔中计算高斯差分图像。

接着,通过比较每个像素周围的8个像素和自身像素的差值,找到局部极值点。

最后,使用尺度空间极大值抑制来进一步过滤出稳定的关键点。

关键点描述:在关键点检测后,需要对每个关键点进行描述。

SIFT使用局部图像梯度的直方图来描述关键点。

首先,在每个关键点周围的16x16像素块上计算梯度的幅值和方向。

然后将这个块分成16个4x4的子块,并在每个子块上计算一个8方向的直方图。

最后,将这些直方图连接起来形成一个128维的向量,用来表示该关键点。

在对两幅图像提取出关键点并进行描述后,需要对这些特征点进行匹配。

SIFT使用欧式距离来计算特征向量之间的相似性。

对于每个特征点,将其描述子与另一幅图像中的所有描述子进行比较,选择最佳匹配的特征点对。

SIFT算法在匹配过程中还引入了RANSAC算法来排除错误的匹配。

RANSAC(Random Sample Consensus)是一种迭代的鲁棒性估计方法,可以通过随机选择一个小子集来估计模型参数,并通过计算剩余误差和阈值来确定最终的模型。

总结一下,SIFT算法通过关键点检测、关键点描述和特征点匹配三个步骤来实现对图像中的特征点进行匹配。

该算法具有尺度不变性和旋转不变性,可以在不同的图像尺度和旋转角度下进行特征点的匹配。

SIFT特征提取算法总结

SIFT特征提取算法总结

SIFT特征提取算法总结SIFT(Scale-Invariant Feature Transform)特征提取算法是一种旋转不变性和尺度不变性较强的特征提取算法,被广泛应用于计算机视觉领域中的图像配准、目标识别、三维重建等任务中。

SIFT算法由David Lowe在1999年提出,并在2004年发表了他的论文,成为一种经典的特征提取算法。

本篇文章将对SIFT特征提取算法进行总结和分析。

1.SIFT特征提取算法原理(1)尺度空间极值检测:在不同的尺度空间中寻找关键点。

SIFT算法使用高斯金字塔对图像进行尺度空间的离散采样。

在每个尺度空间中,通过构建DoG(Difference of Gaussian)金字塔来检测图像中的局部极值点。

(2)关键点定位:对尺度空间极值点进行精确定位以得到关键点。

在尺度空间中使用Hessian矩阵来估计关键点的位置和尺度,并通过亚像素插值来获得更加精确的关键点位置。

(3)方向分配:为每个关键点分配主方向。

SIFT算法在关键点周围的邻域内计算梯度方向直方图,选择梯度方向最大的方向作为该关键点的主方向。

(4)描述子生成:对关键点周围的邻域进行描述子的生成。

SIFT算法将关键点周围的邻域划分为一个个小区域,并计算每个小区域内的梯度方向直方图,从而生成描述子。

2.SIFT特征提取算法优点(1)尺度不变性:SIFT算法在不同尺度空间中检测图像的关键点,使得检测到的关键点能够具有尺度不变性。

(2)旋转不变性:SIFT算法对每个关键点分配主方向,通过旋转关键点周围的邻域来实现旋转不变性。

(3)良好的特征描述性:SIFT特征由128维向量表示,能够克服一些小范围内的图像变换,如亮度变化等。

(4)鲁棒性:SIFT算法对噪声、模糊等干扰具有较强的鲁棒性,适用于复杂的图像条件下提取特征。

3.SIFT特征提取算法应用SIFT特征提取算法广泛应用于计算机视觉领域中的图像配准、目标识别、三维重建等任务中。

常见特征检测算法介绍

常见特征检测算法介绍

常见特征检测算法介绍特征检测算法是计算机视觉领域中常用的技术之一,用于从图像或视频中提取出具有一定重要性或者代表性的特征点或区域。

这些特征点或者区域可以帮助我们进行图像匹配、物体识别、边缘检测等任务。

下面将介绍几种常见的特征检测算法。

1.SIFT(尺度不变特征变换)SIFT是一种基于局部特征的算法,最初由Lowe 在1999 年提出。

它通过寻找图像中的尺度和旋转不变性的关键点,来提取特征点。

SIFT 算法先对图像进行多尺度的高斯滤波,然后计算出尺度空间极值点。

随后,选取关键点并计算其主方向。

最后,通过在关键点周围的窗口里计算梯度直方图,生成特征描述子。

2.SURF(加速稳健特征)SURF是一种快速且具有不变性的特征检测算法,由Bay等人于2024年提出。

它采用了一种叫做积分图像的计算方法来加速特征的提取过程。

SURF 的关键点提取过程与SIFT 类似,但是采用了一种叫作Haar小波响应的方法来计算特征描述子。

3.FAST(特征快速)FAST 是一种具有高速性能的角点检测算法,由Rosten 和Drummond 在2024年提出。

它通过比较像素点灰阶值和邻域像素点的灰阶值来判断是否为关键点。

FAST 算法具有简单、快速和鲁棒的特点,被广泛应用于图像和视频中特征点的检测。

4. Harris 角点检测算法Harris 角点检测算法是一种基于图像灰度变化的特征检测算法,由Harris和Stephens 在1988 年提出。

它通过计算图像灰度在不同方向上的变化率,来判断一些像素点是否为角点。

Harris 角点检测算法简单、快速,且对光照变化和图像旋转具有一定的不变性。

5. ORB(Oriented FAST and Rotated BRIEF)ORB 是一种特征点检测和描述子生成算法,由Rublee等人于2024年提出。

ORB 算法结合了FAST 点检测和BRIEF 描述子生成算法,同时引入了旋转不变性和仿射不变性,提高了算法的鲁棒性和性能。

SIFT算法原理SIFT算法详细介绍

SIFT算法原理SIFT算法详细介绍

SIFT算法原理SIFT算法详细介绍SIFT(Scale-Invariant Feature Transform)是一种用于计算机视觉领域的算法,用于检测和描述图像中的局部特征。

它被广泛应用于目标识别、图像匹配和三维重建等任务中。

SIFT算法通过提取图像的稳定特征点来实现图像的尺度和旋转不变性。

下面详细介绍SIFT算法的原理和步骤。

1.尺度空间极值检测:SIFT算法首先在不同的尺度空间中通过高斯差分金字塔(Difference of Gaussian,DoG)寻找稳定的特征点。

通过对输入图像进行高斯滤波,得到一系列不同尺度的图像。

然后,通过对相邻的两个不同尺度的图像进行差分操作,得到高斯差分图像,即DoG金字塔。

接着,在DoG金字塔中寻找局部极值点,即该点的像素值在其周围的3×3×3邻域内最大或最小。

2.生成关键点:在尺度空间极值点检测后,通过插值计算亚像素精度的关键点位置,以获得更精确的特征点位置。

对比邻域像素的梯度幅值和方向,重新定位关键点位置。

3.消除边缘响应:排除低对比度的稳定特征点和位于边缘的特征点,以提高匹配的准确性。

通过计算Hessian矩阵的迹和行列式来判断是否为边缘响应。

4.计算主方向:为了使SIFT算法对旋转具有不变性,对每个关键点计算该点的主方向。

在关键点周围的邻域内,计算梯度幅值和方向直方图,选取主方向作为该特征点的方向描述符。

5.生成特征描述子:在关键点检测和主方向计算后,利用关键点附近的图像区域创建描述子。

以关键点为中心,将图像区域分为若干个子区域,并在每个子区域内计算局部特征。

对每个子区域,计算梯度幅值和方向直方图,形成一个向量。

最后将这些向量串联形成一个特征向量,作为该特征点的描述子。

6.特征点匹配:使用描述子来匹配不同图像中的特征点。

通过计算两个特征点描述子之间的距离来判断它们的相似性。

通常使用欧氏距离或余弦相似度来度量特征点之间的差异。

然后,根据距离进行特征点匹配,通过选取最佳匹配对的阈值来过滤不准确的匹配。

尺度空间理论和SIFT算法小结

尺度空间理论和SIFT算法小结

尺度空间理论和SIFT算法小结一、尺度空间理论尺度空间理论是一种描述图像在不同尺度上的表示方法。

它源于人类视觉系统在感知物体时会通过改变焦距和观察距离来获得不同尺度的信息。

尺度空间理论在图像处理中模拟了这种方式,通过高斯滤波器的不同尺度参数来表示图像的不同尺度信息。

高斯滤波器具有平滑图像的作用,其尺度参数越大则平滑效果越明显,图像的细节信息也会被模糊化。

通过不同尺度的高斯滤波器对图像进行滤波操作,得到一系列尺度空间图像,即每张图像代表了特定尺度下的图像信息。

尺度空间理论的应用有两个主要目的:尺度不变性和尺度选择。

尺度不变性是指当图像在不同尺度上发生变化时,特征点的描述子应保持不变。

这一特性在物体检测和图像匹配中非常重要,因为物体的大小和形状在不同尺度下可能发生变化。

尺度选择是指如何选择合适的尺度参数来提取图像特征。

根据尺度空间理论,选择一个合适的尺度参数可以提取到物体的局部特征,并使得特征对尺度的变化不敏感。

二、SIFT算法SIFT(Scale Invariant Feature Transform)算法是一种用于检测和描述图像中的局部特征的算法。

它由David Lowe在1999年提出,是一种具有尺度不变性和鲁棒性的特征提取算法,并被广泛应用于物体检测、图像匹配和三维重建等领域。

SIFT算法的主要步骤包括尺度空间极值检测、关键点精确定位、方向分配和特征描述等。

首先,通过构建尺度空间图像和高斯差分金字塔,从图像中检测出尺度空间极值点,用于确定关键点的位置和尺度。

然后,对关键点进行迭代精确定位,通过求解关键点的仿射变换参数来提高关键点的准确性。

接下来,通过梯度方向直方图统计的方法为每个关键点分配主方向,用于为关键点的描述子进行旋转。

最后,使用关键点周围的梯度信息生成一个128维的特征向量作为关键点的描述子,该描述子具有尺度不变性和鲁棒性。

SIFT算法的优点是具有良好的尺度不变性和鲁棒性,在复杂的环境下仍能较好地提取和匹配特征。

SIFTSURF算法的深入剖析——谈SIFT的精妙与不足

SIFTSURF算法的深入剖析——谈SIFT的精妙与不足

SIFTSURF算法的深入剖析——谈SIFT的精妙与不足SIFTSURF (Scale-Invariant Feature Transform Speeded UpRobust Features) 算法是一种经典的计算机视觉算法,用于在图像中检测和描述特征点。

它由 David G. Lowe 在 1999 年提出,并被广泛应用于图像匹配、目标识别、图像拼接等领域。

SIFTSURF 算法具有很多优点,但同时也存在一些不足之处。

SIFTSURF算法的精妙之处在于它的关键步骤:尺度空间极值检测、关键点定位、关键点方向计算、关键点描述子生成和匹配。

首先,尺度空间极值检测通过应用尺度空间的高斯差分来寻找图像中的极值点,选择出尺度和位置具有显著变化的关键点。

这能够使得算法对尺度和旋转的变化具有很强的鲁棒性。

其次,关键点定位通过对极值点进行精细的位置确定和过滤,排除噪声和边缘响应。

然后,关键点方向计算通过计算关键点周围像素的梯度方向直方图,并选择主导方向作为关键点的方向。

关键点描述子生成则使用关键点周围的图像局部区域的梯度信息生成一个具有旋转和尺度不变性的特征描述子。

最后,特征点匹配通过比较描述子之间的相似度,找出图像中具有相似特征的点。

SIFTSURF算法的精妙之处在于它的多尺度和旋转不变性,这使得它能够在不同尺度和旋转变换下对图像特征进行有效匹配。

它也具有较好的鲁棒性,能够在一定程度上抵抗图像噪声和视角变化的影响。

此外,生成的关键点描述子具有很好的区分度,可以用来进行图像匹配和目标识别。

然而,SIFTSURF算法也存在一些不足之处。

首先,尽管该算法通过高斯差分来检测尺度空间极值点,但在特征点数量较大的情况下,会导致计算量过大,降低计算效率。

其次,关键点匹配过程中,由于描述子的维数较高,需要进行大量的比较计算,这同样会带来较大的计算开销。

而且,在存在大量外观相似但空间位置不同的特征点的情况下,匹配过程容易产生误匹配。

关于图像处理中特征点描述算子的一点总结

关于图像处理中特征点描述算子的一点总结

关于图像处理中特征点描述算子的一点总结1.SIFt算子SIFT算子是David G Lowe在2004提出的,即尺度不变特征变换(Scale Invariant Feature Transform)。

它是以尺度空间的构造为基础的局部特征描述算子,对于图像的缩放、旋转和放射变换等具有不变性。

SIFT算子在构建好的尺度空间的基础上搜索尺度空间中的极值点(特征点),然后确定极值点的尺度信息以及位置,再确定极值点的方向(其邻域梯度的主方向),最终可以得到具有鲁棒性的128维(4*4*8)的特征描述子。

2.surf特征SURF(Speed-Up Robust Features)算子选取图像在尺度空间上的极值点作为候选特征点。

与SIFT算子不同的是SURF算子采用Hessian矩阵行列式近似值来构造金字塔。

提取SURF特征点需要4个步骤:提取SURF特征,对于特征点进行定位,赋予主方向,生成特征点描述符。

3. BRIEF特征BRIEF特征(binary robust independent elementary features)是Calonder等在2010年提出来的,他采用二进制字符串作为特征点描述符,因而在速度和性能上都有着卓越的表现。

其主要思路是:在特征点附近随机的选取若干点对,将这些点对的灰度值大小组合成一个长为256的二进制字串,并将这个二进制字串作为该特征点的特征描述子。

由于其描述子利用二进制(“0”和“1”)编码,因此在特征匹配时只需计算2个特征点描述子的Hamming距离。

大量实验表明,不匹配特征点的描述子的Hamming距离在128左右,匹配点对描述子的Hamming距离则远小于128。

由于BRIEF的匹配速度远高于SURF和SIFT,因此应用较为广泛。

BRIEF特征描述符是一个bit串,有若干个二值测试组成,即影像块 (尺寸为 )经过平滑后再进行若干测试。

其中,影像块在x处的灰度值定义为,特征描述符为一个长度为的二进制串:这里有两点要注意:1)如何选取内核对图形进行平滑处理(预处理);2)如何选择测试点对。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

图1 Two octaves of a Gaussian scale-space image pyramid with s =2 intervals. The first image in the second octave is created by down sampling the second to last image in the previous
σ n = 0.5, σ 0 = 1.6 ⋅ 21/ S , omin = −1, S = 3
在组 o=-1,图像用双线性插值扩大一倍(对于扩大的图像 σ n = 1 ) 。 ▲ 精确确定极值点位置 通过拟和三维二次函数以精确确定关键点的位置和尺度(达到亚像素精度) , 同时去除低对比度的关键点和不稳定的边缘响应点(因为 DoG 算子会产生较强的 边缘响应),以增强匹配稳定性、提高抗噪声能力。 边缘响应的去除 一个定义不好的高斯差分算子的极值在横跨边缘的地方有较大的主曲率, 而在垂 直边缘的方向有较小的主曲率。主曲率通过一个 2x2 的 Hessian 矩阵 H 求出:
DOG 算子计算简单,是尺度归一化的 LoG 算子的近似。 图像金字塔的构建:图像金字塔共 O 组,每组有 S 层,下一组的图像由上一组 图像降采样得到。 图 1 由两组高斯尺度空间图像示例金字塔的构建, 第二组的第一副图像由第一 组的第一副到最后一副图像由一个因子 2 降采样得到。 图 2 DoG 算子的构建:
图4 由梯度方向直方图确定主梯度方向
在梯度方向直方图中,当存在另一个相当于主峰值80%能量的峰值时,则将 这个方向认为是该关键点的辅方向。一个关键点可能会被指定具有多个方向(一 个主方向,一个以上辅方向),这可以增强匹配的鲁棒性
[53]

至此, 图像的关键点已检测完毕, 每个关键点有三个信息: 位置、 所处尺度、 方向。由此可以确定一个SIFT特征区域(在实验章节用椭圆或箭头表示)。 ▲ 特征点描述子生成 首先将坐标轴旋转为关键点的方向,以确保旋转不变性。
图5 由关键点邻域梯度信息生成特征向量
接下来以关键点为中心取8×8的窗口。 图5-4左部分的中央黑点为当前关键点 的位置,每个小格代表关键点邻域所在尺度空间的一个像素,箭头方向代表该像 素的梯度方向,箭头长度代表梯度模值,图中蓝色的圈代表高斯加权的范围(越 靠近关键点的像素梯度方向信息贡献越大)。然后在每4×4的小块上计算8个方 向的梯度方向直方图,绘制每个梯度方向的累加值,即可形成一个种子点,如图 5右部分所示。此图中一个关键点由2×2共4个种子点组成,每个种子点有8个方 向向量信息。这种邻域方向性信息联合的思想增强了算法抗噪声的能力,同时对 于含有定位误差的特征匹配也提供了较好的容错性。 实际计算过程中, 为了增强匹配的稳健性,Lowe建议对每个关键点使用4×4 共16个种子点来描述,这样对于一个关键点就可以产生128个数据,即最终形成 128维的SIFT特征向量。此时SIFT特征向量已经去除了尺度变化、旋转等几何变 形因素的影响,再继续将特征向量的长度归一化,则可以进一步去除光照变化的 影响。 当两幅图像的SIFT特征向量生成后,下一步我们采用关键点特征向量的欧式 距离来作为两幅图像中关键点的相似性判定度量。取图像1中的某个关键点,并 找出其与图像2中欧式距离最近的前两个关键点,在这两个关键点中,如果最近 的距离除以次近的距离少于某个比例阈值,则接受这一对匹配点。降低这个比例 阈值,SIFT匹配点数目会减少,但更加稳定。
图2 The difference of two adjacent intervals in the Gaussian scale-space pyramid create an interval in the difference-of-Gaussian pyramid (shown in green).
Dxx H = Dxy
Dxy Dyy
(4)
导数由采样点相邻差估计得到。 D的主曲率和H的特征值成正比,令 α 为最大特征值, β 为最小的特征值,则
令 α = γβ ,则:
(r + 1) /r的值在两个特征值相等的时候最小,随着r的增大而增大,因此,为 了检测主曲率是否在某域值r下,只需检测
SIFT 算法小结
1 SIFT 发展历程 SIFT算法由D.G.Lowe 1999年提出,2004年完善总结。后来Y.Ke将其描述子部 分用PCA代替直方图的方式,对其进行改进。 2 SIFT 主要思想 SIFT算法是一种提取局部特征的算法,在尺度空间寻找极值点,提取位置,尺 度,旋转不变量。 3 SIFT算法的主要特点: a) SIFT特征是图像的局部特征,其对旋转、尺度缩放、亮度变化保持不变 性,对视角变化、仿射变换、噪声也保持一定程度的稳定性。 b) 独特性(Distinctiveness)好,信息量丰富,适用于在海量特征数据库中进 行快速、准确的匹配
[23]

c) 多量性,即使少数的几个物体也可以产生大量SIFT特征向量。 d) 高速性,经优化的SIFT匹配算法甚至可以达到实时的要求。 e) 可扩展性,可以很方便的与其他形式的特征向量进行联合。 SIFT 算法步骤: 1)检测尺度空间极值点 2)精确定位极值点 3)为每个关键点指定方向参数 4)关键点描述子的生成 5 SIFT 算法详细 ▲尺度空间的生成 尺度空间理论目的是模拟图像数据的多尺度特征。 高斯卷积核是实现尺度变换的唯一线性核[],于是一副二维图像的尺度空间定 义为: 4
▲空间极值点检测
为了寻找尺度空间的极值点,每一个采样点要和它所有的相邻点比较, 看其是否 比它的图像域和尺度域的相邻点大或者小。如图 3 所示,中间的检测点和它同尺 度的 8 个相邻点和上下相邻尺度对应的 9×2 个点共 26 个点比较, 以确保在尺度 空间和二维图像空间都检测到极值点。
图 3 DoG 尺度空间局部极值检测
▲ 构建尺度空间需确定的参数 σ -尺度空间坐标 O-octave 坐标 S- sub-level 坐标
σ 和 O、S 的关系 σ (o, s) = σ 0 2 o + s / S , o ∈ omin + [0,..., O − 1], s ∈ [0,..., S − 1]
其中 σ 0 是基准层尺度。o-octave 坐标,s- sub-level 坐标。注:octaves 的索 引可能是负的。第一组索引常常设为 0 或者-1,当设为-1 的时候,图像在计算高 斯尺度空间前先扩大一倍。 空间坐标 x 是组 octave 的函数,设 0。 ▲ 关键点方向分配 利用关键点邻域像素的梯度方向分布特性为每个关键点指定方向参数, 使算子具备旋转不变性。
(5) 式(5)为(x,y)处梯度的模值和方向公式。其中L所用的尺度为每个关键点各自 所在的尺度。 在实际计算时,我们在以关键点为中心的邻域窗口内采样,并用直方图统计 邻域像素的梯度方向。梯度直方图的范围是0~360度,其中每10度一个柱,总共 36个柱。直方图的峰值则代表了该关键点处邻域梯度的主方向,即作为该关键点 的方向。图4是采用7个柱时使用梯度直方图为关键点确定主方向的示例。
D( x, y, σ ) = (G ( x, y, kσ ) − G ( x, y, σ )) ∗ I ( x, y ) = L( x, y, kσ ) − L( x, y,σ )
(3)
Comment [S1]: 所谓降采样,就是在一系列 样点中,只取其中的奇数或偶数样点. Comment [S2]: 对于一个离散的信号序列, 如果采样因子 采样因子是 采样因子 N,下采样就是每隔 N-1 个点取一个点,这样组成一个新的序列。比 如序列 123456789,要下 2 采样,就成 13579 了 对于图像的话,就是 2 个方向的取样了。
x = 2 o x0 , o ∈ Ζ, x0 ∈ [0,..., N 0−1]× [0,..., M 0 − 1]
如果 ( M 0 , N 0 ) 是基础组 o=0 的分辨率,则其他组的分辨率由下式获得:
N M N 0 = o0 , M 0 = o0 2 2
注:在 Lowe 的文章中,Lowe 使用了如下的参数:
L( x, y, σ ) = G ( x, yσ ) ∗ I ( x, y )
其中 G ( x, y, σ ) 是尺度可变高斯函数, G ( x, y, σ ) = (1)
1 2πσ
2
e −( x
2
+ y2 )
/ 2σ 2
(2)
(x,y)是空间坐标, σ 是尺度坐标。 为了有效的在尺度空间检测到稳定的关键点,提出了高斯差分尺度空间( DOG scale-space) 。利用不同尺度的高斯差分核与图像卷积生成。
相关文档
最新文档