点特征检测

参考http://www.cnblogs.com/AndyJee/p/3734805.htmlhttp://www.cnblogs.com/cfantaisie/archive/2011/06/14/2080917.html

一、点特征检测

1、点特征的优势:

点特征属于局部特征,对遮挡有一定鲁棒性;

通常图像中可以检测到成百上千的点特征,以量取胜;

点特征有较好的辨识性,不同物体上的点容易区分;

点特征提取通常速度很快;

2、什么是好的点特征?

image30_thumb1

考虑图像上的一个小窗口,当窗口位置发生微小变化时,窗口图像如何变化?

很明显,从下图可以看出,角点是一个好的点特征,因为它沿任意方向移动,窗口的灰度变化明显,所以它可以作为一个特征来进行区分和辨别

image331_thumb

3、点特征的数学表达

      image391_thumb

  • 假设窗口W发生位置偏移(u,v);
  • 比较偏移前后窗口中每一个像素点的灰度变化值;
  • 使用误差平方和定义误差函数E(u,v)

          image36_thumb

       不同位置点计算得到的E(u,v)如下图所示,E(u,v)值随着u、v变化的效果图,可以看出,平坦区域(如天空)的灰度变化不大(下图3),边缘区域沿着边缘方向的灰度变化.

也很小(下图2),只有角点处的灰度变化稍微剧烈一点(下图1)

image42_thumb

  误差函数E(u,v):

image45_thumb1

将I(u,v)进行Taylor展开:

image48_thumb1

进一步展开,写成:

image511_thumb

image64_thumb1

H称为自相关矩阵,image57_thumbimage60_thumb是H的2个特征值,E(u,v)的变化如下图所示:

image67_thumb1

根据H的2个特征值大小对图像点进行分类:

image70_thumb

角点应该满足的基本性质:最小特征值尽量大

角点响应:image77_thumb

image81_thumb更有效的角点响应函数:

image841_thumb1

image871_thumb1

image90_thumb2

二、点特征检测:Harris角点

  • 算法步骤:

  1. 将原图像I使用w(x,y)进行卷积,并计算图像梯度Ix与Iy;
  2. 计算每个图像点的自相关矩阵H;
  3. 计算角点响应image93_thumb
  4. 选择R大于阈值且为局部极大值的点作为角点。

image96_thumbimage991_thumb

image102_thumbimage1051_thumbimage1081_thumbimage111_thumb

  • Harris角点改进:

Harris检测子获得的角点可能在图像上分布不均匀(对比度高的区域角点多)

改进方法:Adaptive non-maximal suppression(ANMS),只保留半径r内角点响应比其他点大10%的点作为角点。(Brown,Szeliski and Winder,2005)

image1_thumb

  • Harris角点的性质:

1.   旋转不变:

image411_thumb

椭圆转过一定角度但是其形状保持不变(特征值保持不变)

2.   光照变化不变:

image7_thumb

image1011_thumb只使用了图像导数,对于光照线性变化不变

3.   对比度变化部分不变:

image13_thumb

4.   对于图像尺度变化不具有不变性:

image16_thumb

三、点特征检测:MOPS

MOPS:Multi-scale oriented patches

尺度不变:在多层图像金字塔上检测角点,在同一层进行匹配

MOPS局限:待匹配的图像需要尺度近似

image26_thumb

四、sift特征

 主要步骤 
1)尺度空间的生成
2)、检测尺度空间极值点;
3)、精确定位极值点;
4)、为每个关键点指定方向参数;
5)、关键点描述子的生成。
              L(x,y,σ), σ= 1.6 a good tradeoff
  
               D(x,y,σ), σ= 1.6 a good tradeoff
      
 
  关于尺度空间的理解说明:图中的2是必须的,尺度空间是连续的。在  Lowe的论文中 ,
   将第0层的初始尺度定为1.6,图片的初始尺度定为0.5. 在检测极值点前对原始图像的高斯
  平滑以致图像丢失高频信息,所以 Lowe 建议在建立尺度空间前首先对原始图像长宽扩展
  一倍,以保留原始图像信息,增加特征点数量。尺度越大图像越模糊。 
 
    
                          next octave 是由 first octave 降采样得到(如2
          
            尺度空间的所有取值,s为每组层数,一般为3~5
 
      同一组中的 相邻尺度(由于k的取值关系,肯定是上下层)之间进行寻找
           
     在极值比较的过程中,每一组图像的首末两层是无法进行极值比较的, 为了满足尺度
     变化的连续性,我们在每一组图像的顶层继续用高斯模糊生成了 3 幅图像,高斯金字
     塔有每组S+3层图像。DOG金字塔每组有S+2层图像.
 
                                 
       If ratio > (r+1)2/(r), throw it out (SIFT uses r=10)
                  表示DOG金字塔中某一尺度的图像x方向求导两次
        通过拟和三维二次函数以精确确定关键点的位置和尺度(达到亚像素精度)?
 
   直方图中的峰值就是主方向,其他的达到最大值80%的方向可作为辅助方向
      
 Identify peak and assign orientation and sum of magnitude to key point
  The user may choose a threshold to exclude key points based on their
                             assigned sum of magnitudes.
 
      利用关键点邻域像素的梯度方向分布特性为每个关键点指定方向参数,使算子具备
      旋转不变性。以关键点为中心的邻域窗口内采样,并用直方图统计邻域像素的梯度
      方向。梯度直方图的范围是0~360度,其中每10度一个柱,总共36个柱。随着距
      中心点越远的领域其对直方图的贡献也响应减小.Lowe论文中还提到要使用高斯函
      数对直方图进行平滑,减少突变的影响。
 
 
                
                                       关键点描述子的生成步骤
              
      通过对关键点周围图像区域分块,计算块内梯度直方图,生成具有独特性
          的向量,这个向量是该区域图像信息的一种抽象,具有唯一性。
      每一个小格都代表了特征点邻域所在的尺度空间的一个像素 ,箭头方向代表了像素梯
      度方向,箭头长度代表该像素的幅值。然后在4×4的窗口内计算8个方向的梯度方向直
      方图。 绘制每个梯度方向的累加可形成一个种子点。
                
      每个直方图有8方向的梯度方向,每一个描述符包含一个位于关键点附近的四个直方图
      数组. 这就导致了SIFT的特征向量有128维.(先是一个4×4的来计算出一个直方图,
      每个直方图有8个方向。所以是4×4×8=128维)将这个 向量归一化之后,就进一步
      去除了光照的影响。
 
                
                   旋转为主方向
       
    
     
      
               

SIFT点的特点:

  • 视角和旋转变化不变性:

image105_thumb2image108_thumb2

  • 光照不变性:

image1111_thumb3

  • 尺度不变性:

image114_thumb3

五、点特征检测:小结


  • 根据自相关矩阵特征值检测角点(Harris); Harris角点具有旋转、光照不变性,但不具有尺度不变性。
  • 高斯差分尺度空间中检测尺度不变特征点(SIFT); SIFT具有尺度不变性。
  • Harris与SIFT的机理不同,因此可以联合使用,互为补充。


  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值