[VLFeat]Dense Sift的C源码学习

VLFeat是一个很好用的开源库,其中实现了计算机视觉常用的算法,使用的语言是C和matlab。
官网:http://www.vlfeat.org/index.html
在官网下载最新版本后,在matlab中添加路径即可。
1,Dense Sift
在文章《sift特征提取算法》中提到,提取图像的sift特征分4步:构建DOG尺度空间;关键点定位;关键点方向赋值;生成描述子。
这里产生的sift特征点是sparse sift,而在实际实验中,使用较多的则是dense sift。
dense sift省去了前3步,即直接指定关键点位置和描述子采样区域,计算sift特征。
主要过程是:
1,用一个patch在图像上以一定步长step滑动,代码中step=1,这个patch就是描述子采样区域,patch size是4bins*4bins,bin size可以自己指定,代码中是3pixels*3pixels。这里说的bin对应到《sift特征提取》中的第4步就是指子区域area。图中的bounding box是sift特征点的范围。
这里写图片描述
2,计算每个像素点的梯度(同sparse sift),统计每个bin内的像素点在8个方向上的梯度直方图,这样就生成了4*4*8维的sift特征。
这里写图片描述
在matlab中直接调用vl_dsift:

% 读入图像
I = vl_impattern('roofs1') ;
I = single(vl_imdown(rgb2gray(I))) ;
binSize = 8 ;
magnif = 3 ;
% 得到指定尺度的高斯图像
Is = vl_imsmooth(I, sqrt((binSize/magnif)^2 - .25)) ;
% 计算dense sift
[frame, descr] = vl_dsift(Is, 'size', binSize) ;
% frame中存储每个sift点的坐标,descr存储每个sift点的128维特征向量

主要实现代码在vl_dsift.c, dsift.c中
参数说明:
size: 是每个bin的大小,代码中是3pixels*3pixels
step: patch移动步长
bounds: sift点的区域,含minX, minY, maxX,maxY四个值
norm: 本来是存在frame中的一列,存储descriptor的值的和,用于normalization
geometry: [4 4 8],在4bins*4bins的范围内,对每个bin统计8个方向的梯度直方图
verbose: 一般bin大小和patch大小都取正方形,也就是长和宽一致,如果打开这个verbose开关,则要对sizeX和sizeY分别赋值。
自定义数据结构在文件dsift.h中:

typedef struct VlDsiftKeypoint_
{
  double x ; /**< x coordinate */
  double y ; /**< y coordinate */
  double s ; /**< scale */
  double norm ; /**< SIFT descriptor norm */
} VlDsiftKeypoint ;

/** @brief Dense SIFT descriptor geometry */
typedef struct VlDsiftDescriptorGeometry_
{
  int numBinT ;  /**< number of orientation bins */
  int numBinX ;  /**< number of bins along X */
  int numBinY ;  /**< number of bins along Y */
  int 
  • 5
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用OpenCV生成.sift文件,您需要安装OpenCV库和sift模块。请按以下步骤进行操作: 1. 安装OpenCV库:根据您的操作系统和开发环境,选择适合的OpenCV版本并进行安装。您可以从OpenCV官方网站(https://opencv.org/)上下载适合您系统的版本,并按照安装说明进行安装。 2. 导入OpenCV库:在您的代码中导入OpenCV库,以便可以使用其中的函数和模块。使用以下代码导入OpenCV: ```python import cv2 ``` 3. 加载图像:使用`cv2.imread()`函数加载要进行SIFT特征提取的图像。例如: ```python image = cv2.imread('image.jpg', 0) # 加载灰度图像 ``` 4. 创建SIFT对象:使用`cv2.xfeatures2d.SIFT_create()`函数创建一个SIFT对象。 ```python sift = cv2.xfeatures2d.SIFT_create() ``` 5. 检测关键点和计算描述符:使用SIFT对象的`detectAndCompute()`函数检测图像中的关键点,并计算每个关键点的特征描述符。 ```python keypoints, descriptors = sift.detectAndCompute(image, None) ``` 6. 保存特征描述符到文件:使用Python的文件操作将特征描述符保存到.sift文件中。 ```python with open('output.sift', 'w') as f: for descriptor in descriptors: f.write(' '.join(str(value) for value in descriptor) + '\n') ``` 这样,您就可以使用OpenCV生成.sift文件了。确保您已正确安装OpenCV并按照上述步骤编写代码。请注意,SIFT算法已经在OpenCV 4.4.0及更高版本中被移除,但您仍然可以使用OpenCV 3.x版本进行SIFT特征提取。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值