opencv实现surf特征的提取。本来是一个非常easy的代码,结果我执行时却出现了各种错误,以下来谈谈我出现的错误及问题的解决过程。

首先,我把提取surf特征的过程整合成了一个函数,我单独建立一个project读取两张图片,然后调用这个surf提取的函数时时不管是debug还是release模式下都是没有问题的。当我把这个函数加入到我如今已有的project代码里面的时候出现了各种奇葩错误。以下是我surf特征提取的函数

void surfdetect(IplImage *image1,IplImage *image2)
{
using namespace std;
//IplImage *image1,*image2;
//image1 = cvLoadImage("lena1.jpg");
//image2= cvLoadImage("lena2.jpg"); cv::SurfFeatureDetector detector;
cv::SurfDescriptorExtractor descriptor_extractor;
cv::BruteForceMatcher<cv::L2<float> > descriptor_matcher; //提取特征点
std::vector<cv::KeyPoint> keypoints1,keypoints2;
detector.detect( image1, keypoints1 );//检測img1中的Surf特征点。存储到keypoints1中
detector.detect( image2, keypoints2 );
cout<<"图像1特征点个数:"<<keypoints1.size()<<endl;
cout<<"图像2特征点个数:"<<keypoints2.size()<<endl; //依据特征点计算特征描写叙述子矩阵。即特征向量矩阵
cv::Mat descriptors1,descriptors2;
descriptor_extractor.compute( image1, keypoints1, descriptors1 );
descriptor_extractor.compute( image2, keypoints2, descriptors2 ); cv::Mat img_keypoints1,img_keypoints2;
drawKeypoints(image1,keypoints1,img_keypoints1);
drawKeypoints(image2,keypoints2,img_keypoints2);
//imshow("Src1",img_keypoints1);
//cv::waitKey(6000);
//imshow("Src2",img_keypoints2);
//cv::waitKey(6000); std::vector<cv::DMatch> matches;//匹配结果
descriptor_matcher.match( descriptors1, descriptors2, matches );//匹配两个图像的特征矩阵
cout<<"Match个数:"<<matches.size()<<endl;
cv::Mat img_matches1,img_matches2;
cv::drawMatches(image1,keypoints1,image2,keypoints2,matches,img_matches1);
imshow("粗匹配",img_matches1);
cv::waitKey(0); double max_dist = 0;
double min_dist = 100;
for(int i=0; i<matches.size(); i++)
{
double dist = matches[i].distance;
if(dist < min_dist) min_dist = dist;
if(dist > max_dist) max_dist = dist;
}
cout<<"最大距离:"<<max_dist<<endl;
cout<<"最小距离:"<<min_dist<<endl; //筛选出较好的匹配点
std::vector<cv::DMatch> goodMatches;
for(int i=0; i<matches.size(); i++)
{
if(matches[i].distance < 0.05 * max_dist)
{
goodMatches.push_back(matches[i]);
}
}
cout<<"goodMatch个数:"<<goodMatches.size()<<endl;
cv::drawMatches(image1,keypoints1,image2,keypoints2,goodMatches,img_matches2);
imshow("精匹配",img_matches2);
cv::waitKey(00); }

SURF特征提取的整个代码都在上面了。可当我把这个函数在我已有的project中调用的时候,出现了一下错误

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvY2dmXzkwOQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

经百度说出现这样的错误是内存问题,要么就是内存木有释放,要么就是两个指针指向同一个内存。一个指针把它释放掉了等等,于是我在代码里面找了非常久,改了很多遍 也没有解决,最后我发现我把代码中的vector

  std::vector<cv::KeyPoint> keypoints1,keypoints2;
cv::Mat descriptors1,descriptors2;
std::vector<cv::DMatch> matches;//匹配结果
std::vector<cv::DMatch> goodMatches;

从函数中拿出来,作为全局变量,问题尽然攻克了,事实上我都没想明确这是什么原因。

vector里面的内存不是不须要手动释放的吗,话说当其在函数里面作为局部变量的时候我也尝试过释放它,先是clear。后来发现clear不能释放其内存。于是我依照网上说的用swap来手动释放,但是终于还是没用。最后误打误撞的,把它作为全局变量,问题才得以解决,只是攻克了就好。

在debug底下程序已经能够执行了,全都通过了。可接下来,我在release底下又遇到错误了。错误类型例如以下:

网上说这样的我是加入opencv库的时候加入错了,我细致看了我的additional dependencies的加入。在release底下我确实没带d啊。可怎么就是出现了这样的错误呢,要是是程序有问题,那怎么debug底下能够执行呢。我非常纳闷,尝试了非常多方法。最后抱着试试的态度,干脆把release和debug底下都加入了带d的库文件,奇葩的是问题尽然结局了。对于这我仅仅能表示相当无语啊。

opencv提取surf特征点出现的错误的更多相关文章

  1. 【OpenCV新手教程之十八】OpenCV仿射变换 &amp; SURF特征点描写叙述合辑

    本系列文章由@浅墨_毛星云 出品,转载请注明出处. 文章链接:http://blog.csdn.net/poem_qianmo/article/details/33320997 作者:毛星云(浅墨)  ...

  2. OpenCV图像Surf与flann特征点(转载)

    Surf(Speed Up Robust Feature) Surf算法的原理                                                             ...

  3. OpenCV特征点提取----Fast特征

    1.FAST(featuresfrom accelerated segment test)算法 http://blog.csdn.net/yang_xian521/article/details/74 ...

  4. 【OpenCV新手教程之十七】OpenCV重映射 &amp; SURF特征点检測合辑

    本系列文章由@浅墨_毛星云 出品.转载请注明出处. 文章链接:http://blog.csdn.net/poem_qianmo/article/details/30974513 作者:毛星云(浅墨)  ...

  5. Opencv中使用Surf特征实现图像配准及对透视变换矩阵H的平移修正

    图像配准需要将一张测试图片按照第二张基准图片的尺寸.角度等形态信息进行透视(仿射)变换匹配,本例通过Surf特征的定位和匹配实现图像配准. 配准流程: 1. 提取两幅图像的Surf特征 2. 对Sur ...

  6. OpenCV开发笔记(六十四):红胖子8分钟带你深入了解SURF特征点(图文并茂+浅显易懂+程序源码)

    若该文为原创文章,未经允许不得转载原博主博客地址:https://blog.csdn.net/qq21497936原博主博客导航:https://blog.csdn.net/qq21497936/ar ...

  7. opencv::SURF特征

    SURF特征基本介绍 SURF(Speeded Up Robust Features)特征关键特性: -特征检测 -尺度空间 -选择不变性 -特征向量 工作原理 . 选择图像中POI(Points o ...

  8. 基于SURF特征的图像与视频拼接技术的研究和实现(一)

    基于SURF特征的图像与视频拼接技术的研究和实现(一)      一直有计划研究实时图像拼接,但是直到最近拜读西电2013年张亚娟的<基于SURF特征的图像与视频拼接技术的研究和实现>,条 ...

  9. SURF特征

    了解了SIFT特征后,来学习SURF特征. 虽说是SIFT的一个变种,可是跟SIFT还是有差别的 差别有例如以下: 1.尺度空间的构建(近似)不同. 2.同意尺度空间多层图像同一时候被处理 3.特征点 ...

随机推荐

  1. android studio 设置

    1.设置启动不打开最近项目 2.设置字体 3.安装逍游模拟器,并与android studio 进行链接 adb connect 127.0.0.1:21503 4.添加第三方包 文件jar.Modu ...

  2. 最小生成树的Prim算法

       构造最小生成树的Prim算法    假设G=(V,E)为一连通网,其中V为网中所有顶点的集合,E为网中所有带权边的集合.设置两个新的集合U和T,其中集合U用于存放G的最小生成树的顶点,集合T用于 ...

  3. HDU 多校1.4

    Division Game Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) ...

  4. hdu5558

    hdu5558 题意 给出一个字符串,按照特殊规则进行加密. 假设已经加密了前 \(i\) 个字符,从第 \(i+1\) 个字符开始找到 \(S[i..N]\) 的长度为 \(K\) 的最长前缀等于 ...

  5. RPD Volume 168 Issue 4 March 2016 评论7-end

    Shielding activation of petawatt laser facilities in Romania: a FLUKA preliminary evaluation   Abstr ...

  6. [BZOJ2655]calc(拉格朗日插值法+DP)

    2655: calc Time Limit: 30 Sec  Memory Limit: 512 MBSubmit: 428  Solved: 246[Submit][Status][Discuss] ...

  7. [CF911D]Inversion Counting

    题目大意: 给你一个数列,翻转其中一个区间,问每次翻转过后逆序对个数的奇偶性. 思路: 首先树状数组求出一开始的奇偶性,然后考虑每次翻转对答案的贡献. 对于整个区间,我们可以把翻转转化成若干次交换. ...

  8. NPOI读取Excel2003,2007

    using System; using System.Collections.Generic; using System.Data; using System.IO; using System.Lin ...

  9. 关于char类型的说明

    #include<iostream> using namespace std; int main() {  char ch=128;//VC编译器默认是有符号的.但c并未明确给出.由编译器 ...

  10. NDK之打印调试信息Log

    第一步:gradle配置ndk ndk { moduleName "Iso8583Lib" ldLibs "log", "z", " ...