最初的目的是想做全景图像拼接,一开始找了OpenCV中自带的全景拼接的样例,用的是Stitcher类,可以很方便的实现全景拼接,而且效果很好,但是不利于做深入研究。

使用OpenCV中自带的Stitcher类的全景图像拼接样例下载http://download.csdn.net/detail/masikkk/5661075

后来想用OpenCV中自带的SIFT特征检测器进行特征检测和拼接,但还是有隔靴搔痒的感觉,接触不到SIFT算法的本质,

看到网上大多数都是使用RobHess的SIFT源码,自己也下载了一份进行了分析。

RobHess的SIFT源码下载地址http://robwhess.github.io/opensift/

一开始也是感觉比较乱,不知道怎么用,接触了一段时间后比较清晰了,下面说一下RobHess的SIFT源码中的几个文件都是做什么用的,方便刚接触的同学学习。

(1) imgfeatures.h和imgfeatures.c文件

imgfeatures.h中有SIFT特征点结构struct feature的定义,这个结构很重要,后面都要用到,除此之外还有一些特征点的导入导出以及特征点绘制函数的声明。

对应的imgfeatures.c文件中是特征点的导入导出以及特征点绘制函数的实现。

(2) utils.h和utils.c文件

这两个文件中是一些图像基本操作的函数,包括:
1、获取某位置的像素点
2、设置某位置的像素点(8位,32位和64位),
3、计算两点之间的距离的平方
4、在图片某一点画一个“X”
5、将两张图片合成为一个(在特征匹配中用到),高是二者之和,宽是二者的较大者。

(3) sift.h和sift.c文件

这两个是最重要的,里面的内容说白了很简单,就是两个特征点检测函数sift_features()和 _sift_features(),

sift_features()是用默认参数进行特征点检测, _sift_features()允许用户输入各种检测参数,其实sift_features()中也是再次调用_sift_features()函数。

所以,你只需提供原图像和存储特征点的数组以及其他一些检测参数,然后调用sift_features()或 _sift_features()就可完成SIFT特征点检测。

但是这两个文件分析起来也是最复杂的。

sift.h中有默认的各种特征检测中用到的参数的宏定义,sift.c中是检测函数的实现,是最核心的一个文件,里面的一些未暴露接口的本地函数就有31个之多。

仔细分析完后发现大神就是大神,程序写的条理非常清楚,尤其是函数_sift_features()的函数体,从头到尾的几部分正好对应SIFT算法的几个步骤,

把一些细节全部放在子函数中,非常清楚明了。

关于SIFT算法的原理,可以参加下面几篇文章,写的都不错:

小魏的SIFT原理与源码分析系列文章http://blog.csdn.net/xiaowei_cqu/article/details/8069548

Rachel-Zhang的SIFT算法分析http://blog.csdn.net/abcjennifer/article/details/7639681

July的经典算法研究系列中的SIFT算法分析http://blog.csdn.net/v_july_v/article/details/6186942

以及July的教你一步一步实现SIFT算法http://blog.csdn.net/v_july_v/article/details/6245939

tornadomeet的SIFT算法分析http://www.cnblogs.com/tornadomeet/archive/2012/08/16/2643168.html

以及这篇博客中的SIFT算法分析http://www.cnblogs.com/cfantaisie/archive/2011/06/14/2080917.html

还有这篇结合RobHess源码的SIFT算法分析http://underthehood.blog.51cto.com/2531780/658350

还有我觉得讲的挺详细的一篇文章http://download.csdn.net/detail/masikkk/5661453

或者你也可以直接读David.Lowe发表的英文原版论文:

David.Lowe1999年发表在ICCV的SIFT论文http://download.csdn.net/detail/masikkk/5661441

David.Lowe2004年发表在IJCV的SIFT改进论文http://download.csdn.net/detail/masikkk/5661447

(4) minpq.h和minpq.c文件

这两个文件中实现了最小优先级队列(Minimizing Priority Queue),也就是小顶堆,在k-d树的建立和搜索过程中要用到。

(5) kdtree.h和kdtree.c文件

这两个文件中实现了k-d树的建立以及用BBF(Best Bin First)算法搜索匹配点的函数。

如果你需要对两个图片中的特征点进行匹配,就要用到这两个文件。

关于k-d树算法的讲解,可参考这篇文章http://blog.csdn.net/masikkk/article/details/9088997

以及这篇http://underthehood.blog.51cto.com/2531780/687160

还有这篇,里面讲解了k-d树,BBF和RANSAChttp://blog.csdn.net/ijuliet/article/details/4471311

(6) xform.h和xform.c文件

这两个文件中实现了RANSAC算法(RANdom SAmple Consensus 随机抽样一致)。

RANSAC算法可用来筛选两个图像间的SIFT特征匹配并计算变换矩阵。

你可以单纯利用RANSAC算法筛选两个图像间的SIFT特征匹配,以得到更好的匹配结果,

见此文:利用RANSAC算法筛选SIFT特征匹配http://blog.csdn.net/masikkk/article/details/9145441

或者想要进行全景拼接时,利用RANSAC算法计算两个图像间的变换矩阵。

关于RANSAC算法的讲解,可参考这篇文章http://www.cnblogs.com/cfantaisie/archive/2011/06/09/2076864.html

以及这篇,里面有用RANSAC算法解决线性回归问题的例子http://grunt1223.iteye.com/blog/961063

以及这篇,里面讲解了k-d树,BBF和RANSAChttp://blog.csdn.net/ijuliet/article/details/4471311

(7) 其他文件:dspfeat.c,match.c,siftfeat.c

这几个文件中是一些使用SIFT算法的小例子:

dspfeat.c文件可以从预先保存的特征点文件中读取特征点并显示在图片上。

match.c文件可以检测两个图像中的特征点并进行匹配。

siftfeat.c文件利用SIFT算法检测特征点,有一些控制台操作提示。

最新文章

  1. R 单变量重命名与删除
  2. C#设置IE代理及遇到问题的解决方案
  3. Maven 学习-入门
  4. libgcc_s.so.1 must be installed for pthread_cancel to work
  5. 【原创】android内存管理-hprof文件
  6. JS util
  7. 使用Jsoup 爬取网易首页所有的图片
  8. 初探Team Foundation Server (TFS) 2015 REST API
  9. Python 删除列表中的重复数据
  10. POJ 2411 Mondriaan's Dream
  11. mysql忘记root密码 + 授权登录
  12. Oracle_系统和对象权限管理
  13. typedef 总结
  14. C语言之switch
  15. 使用git将本地代码传到github
  16. ## 本篇文章对linux常用的一些命令做一下总结,如有需要补充以及不懂得地方,请在下方留言 适合于linux初学者,以及对命令掌握不牢的用来备忘
  17. html总结:文本框填满表格
  18. sql之Replace
  19. json.stringify和json.parse,序列化和反序列化
  20. 让jQuery的contains方法不区分大小写

热门文章

  1. Android超炫日期日历控件:TimesSquare
  2. 浅谈移动Web开发(上):深入概念
  3. C#正则学习
  4. 硬盘安装Archlinux「2013-12-26」
  5. 显示linux开机时间的脚本
  6. 慧都十年大促起幕,Dev、BCG等明星控件6.8折起!
  7. 安装SQL Server 2005 - 初学者系列 - 学习者系列文章
  8. jQuery Easy UI LinkButton(button)包
  9. 【SSRS】入门篇(七) -- 报表发布
  10. MVC程序中实体框架的连接恢复和命令拦截