SIFT在OpenCV中的调用和具体实现(HELU版)

时间:2021-09-20 15:59:31

前面我们对sift算法的流程进行简要研究,那么在OpenCV中,sift是如何被调用的?又是如何被实现出来的了?

特别是到了3.0以后,OpenCV对特征点提取这个方面进行了系统重构,那么整个代码结构变成了什么模样?
在代码中
SIFT在OpenCV中的调用和具体实现(HELU版)
可以看出目前的结构是基于hess的算法进行的重构。那么首先需要解决的是整体的调用和实现结构问题,然后是hess算法的结构问题,再然后才是具体的算法。需要做的事情很多,一起来研究。
一、OpenCV中sift调用接口和例子
    首先是一定要编译使用contrib版本的OpenCV代码,同时最后设置的时候需要注意,头文件和命名空间要选择正确。
SIFT在OpenCV中的调用和具体实现(HELU版)
     在最新版本的OpenCV中,已经对特征提取这块的函数进行了统一接口:        
    Mat matSrc = imread("e:/template/lena.jpg");
    Mat gray;  
    Mat draw;
    cvtColor( matSrc, gray, CV_RGB2GRAY );  
    Mat descriptors;  
    std,,),DrawMatchesFlags::DEFAULT);
结果:
SIFT在OpenCV中的调用和具体实现(HELU版)
    这里也只是简单地把特征点给画了出来,并没有将方向等信息进行表示。下面我们具体看一看sift在OpenCV中是如何实现的。
    OpenCV是开发源代码的,所以这里的代码都是可以自己看到的。那么联调的方式为
SIFT在OpenCV中的调用和具体实现(HELU版)
SIFT在OpenCV中的调用和具体实现(HELU版)
SIFT在OpenCV中的调用和具体实现(HELU版)
二、sift的代码结构解析
注意,sift的原始地址在
SIFT在OpenCV中的调用和具体实现(HELU版)
 
它的类结构为:
SIFT在OpenCV中的调用和具体实现(HELU版)SIFT在OpenCV中的调用和具体实现(HELU版)
它的构建函数为:
SIFT在OpenCV中的调用和具体实现(HELU版)
直接返回的是本类的指针
SIFT在OpenCV中的调用和具体实现(HELU版)
我们去看代码,基本了解结构以后,就直接从我们想要用的那个函数开始“顺藤摸瓜”。我们想要的是detectAndCompute  函数。
SIFT在OpenCV中的调用和具体实现(HELU版)    
三、sift的代码具体实现
step0: createInitialImage 将图片转换成为合适的大小
    Mat base = createInitialImage(image, firstOctave < 0, (float)sigma);
    最为简单的一步,据说将输入的图片变化为规整的大小和格式:
SIFT在OpenCV中的调用和具体实现(HELU版)
//step1: buildGaussianPyramid 构建高斯金字塔

buildGaussianPyramid(base, gpyr, nOctaves);

SIFT在OpenCV中的调用和具体实现(HELU版)
//step2: buildDoGPyramid 构建高斯差分金字塔

buildDoGPyramid(gpyr, dogpyr);

SIFT在OpenCV中的调用和具体实现(HELU版)
//step3: findScaleSpaceExtrema removeDuplicated 寻找并筛选尺度空间特征值

findScaleSpaceExtrema(gpyr, dogpyr, keypoints);

注意这里将特征值的初略寻找和细化寻找放在了一起(一个循环)
SIFT在OpenCV中的调用和具体实现(HELU版)
其中
SIFT在OpenCV中的调用和具体实现(HELU版)
其中二
SIFT在OpenCV中的调用和具体实现(HELU版)
注意:
SIFT在OpenCV中的调用和具体实现(HELU版)
 
//step4: calcDescriptors 计算特征值

        calcDescriptors(gpyr, keypoints, descriptors, nOctaveLayers, firstOctave);

SIFT在OpenCV中的调用和具体实现(HELU版)
三、简单小结
       这里也只是将sift的代码挑了出来,简单进行了分析。应该说OpenCV的代码本身才是其最为精髓的地方,无论是代码背后的理论,还是代码实现的技术,以及各种提升速度的方法,都对于我们写出出色的图像处理算法和运用很有帮助。
       而学习的最好方法就是去实现创造。OpenCV本身就是开源的项目,基于现有的这么多的资源,在图像处理广阔的领域去进行创新,不断巩固提升自己的能力。与大家共勉!

SIFT在OpenCV中的调用和具体实现(HELU版)的更多相关文章

  1. opencv中的SIFT&comma;SURF&comma;ORB&comma;FAST 特征描叙算子比较

    opencv中的SIFT,SURF,ORB,FAST 特征描叙算子比较 参考: http://wenku.baidu.com/link?url=1aDYAJBCrrK-uk2w3sSNai7h52x_ ...

  2. (原&plus;转)Eclipse中Android调用OpenCv

    大部分都是参考下面的网址,如果感觉看起来不舒服,可以直接查看原网址.最后遇到了一点问题: Description      Resource Path Location   Type E:/~\cod ...

  3. OpenCV中IplImage图像格式与BYTE图像数据的转换

    最近在将Karlsruhe Institute of Technology的Andreas Geiger发表在ACCV2010上的Efficent Large-Scale Stereo Matchin ...

  4. 混合高斯模型:opencv中MOG2的代码结构梳理

    /* 头文件:OurGaussmix2.h */ #include "opencv2/core/core.hpp" #include <list> #include&q ...

  5. 【OpenCV】OpenCV中GPU模块使用

    CUDA基本使用方法 在介绍OpenCV中GPU模块使用之前,先回顾下CUDA的一般使用方法,其基本步骤如下: 1.主机代码执行:2.传输数据到GPU:3.确定grid,block大小: 4.调用内核 ...

  6. opencv通过dll调用matlab函数,图片作为参数

    [blog 项目实战派]opencv通过dll调用matlab函数,图片作为参数                   前文介绍了如何“csharp通过dll调用opencv函数,图片作为参数”.而在实 ...

  7. opencv中的Bayes分类器应用实例

    转载:http://blog.csdn.net/yang_xian521/article/details/6967515 PS:很多时候,我们并不需要特别精通某个理论,而且有的时候即便你非常精通,但是 ...

  8. OpenCV中的SVM參数优化

    SVM(支持向量机)是机器学习算法里用得最多的一种算法.SVM最经常使用的是用于分类,只是SVM也能够用于回归,我的实验中就是用SVM来实现SVR(支持向量回归). 对于功能这么强的算法,opencv ...

  9. opencv-python与c&plus;&plus; opencv中的一些区别和基础的知识

    使用opencv-python一段时间了,因为之前没有大量接触过c++下的opencv,在网上看c++的一些程序想改成python遇到了不少坑,正好在这里总结一下. 1.opencv 中x,y,hei ...

随机推荐

  1. webform 页面传值的方法总结

    ASP.NET页面之间传递值的几种方式   页面传值是学习asp.net初期都会面临的一个问题,总的来说有页面传值.存储对象传值.ajax.类.model.表单等.但是一般来说,常用的较简单有Quer ...

  2. 【并发编程】Executor类的继承结构

    来自为知笔记(Wiz)

  3. KVO机制

    KVO,全称为Key-Value Observing,是iOS中的一种设计模式,用来监测对象的某些属性的实时变化情况并作出响应 首先,假设我们的目标是在一个UITableViewController内 ...

  4. c&num; 类;一维数组;二维数组

    1. 输入邮箱帐号,判断格式是否正确  (1)有且只有一个@          Contains IndexOf ==LastIndexOf  (2)不能以@开头           StartsWi ...

  5. BZOJ 2423 (求LCS的长度和种类数)

    Description 字符序列的子序列是指从给定字符序列中随意地(不一定连续)去掉若干个字符(可能一个也不去掉)后所形成的字符序列.令给定的字符序列X=“x0,x1,…,xm-1”,序列Y=“y0, ...

  6. Mongodb条件查询Query的用法

    Query.All("name", "a", "b");//通过多个元素来匹配数组Query.And(Query.EQ("name ...

  7. Handling Event

    [Handling Event] 1.React events are named using camelCase 2.You must call preventDefault explicitly ...

  8. &period;Net单元测试业务实践

    使用次数和允许取消次数单元测试实践 /** * prism.js Github theme based on GitHub's theme. * @author Sam Clarke */ code[ ...

  9. Jmeter不同线程组之间的变量引用

    用过LoadRunner的小伙伴应该知道,它的脚本主要分为三个部分,即Login,Action,End三个模块.Login中一般是“初始化”环境所用,而Action模块主要做一些诸如压测的动作.举个例 ...

  10. css之导航菜单的制作

    通过设置<a>的背景改变样式,通过a:hover改变交互效果,改变文字颜色color 纵向 <!DOCTYPE html> <html> <head lang ...