Harris corner detector
参考博客:https://blog.csdn.net/u011534057/article/details/77775974
学习笔记以及源码、图片下载:
一.引入
图像特征的类型
提一下:
- 边缘
- 角落(也称为兴趣点)
- Blob(也称为感兴趣的区域)
在本教程中,我们将特别研究角落特征。
角落为何如此特别?
- 因为它是两条边的交点,所以它代表这两条边的方向发生变化的点。因此,图像的梯度(在两个方向上)具有高变化,可用于检测它。
二.算法原理分析(需要有高等数学和线性代数基础)
角点检测基本原理:
人们通常通过在一个小的窗口区域内观察点的灰度值大小来识别角点,如果往任何方向移动窗口都会引起比较大的灰度变换那么往往这就是我们要找的角点。
下面我们看一下Harris的数学公式,对于[x,y]平移[u,v]个单位后强度的变换有下式,I(x+u,y+v)是平移后的强度,I(x,y)是原图像像素。对于括号里面的值,如果是强度恒定的区域,那么它就接近于零,反之如果强度变化剧烈那么其值将非常大,所以我们期望E(u,v)很大。
其中w是窗函数,它可以是加权函数,也可以是高斯函数
利用二维泰勒展开式我们有
所以其中一阶可以近似为
于是我们可以给出Harris Corner的如下推导,其中Ix,Iy是x,y方向的Gradient模,乘以位移得到位移后的量
对于小的位移,我们可以用双线性插值方法近似:
其中M为2*2矩阵如下
在本质上我们可以把二次项看成一个椭圆函数,我们对M进行特征值分析有λ1,λ2
根据λ1,λ2的值我们可以把其分为三类:
1.λ1,λ2都很小且近似,E在所以方向接近于常数;
2.λ1>>λ2,或者λ2>>λ1, E将在某一方向上很大;
3.λ1,λ2都很大且近似,E将在所有方向上很大;
如图所示:
最后我们通过计算角点响应值R来判断其属于哪个区间
其中k一般为常数取在0.04-0.06间。
算法步骤:
1.计算图像x,y方向的梯度Ix,Iy
2.计算每个像素点的梯度平方
3.计算梯度在每个像素点的和
4