博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
OpenCV的ORB特征提取算法
阅读量:5760 次
发布时间:2019-06-18

本文共 3929 字,大约阅读时间需要 13 分钟。

hot3.png

经过查找发现:

描述符数据类型有是float的,比如说SIFT,SURF描述符,还有是uchar的,比如说有ORB,BRIEF

对于float 匹配方式有:

FlannBased

BruteForce<L2<float> >

BruteForce<SL2<float> >

BruteForce<L1<float> >

对于uchar有:

BruteForce<Hammin>

BruteForce<HammingLUT>

BruteForceMatcher< L2<float> > matcher;//改动的地方

BruteForceMatcher< L2<float> > matcher;//改动的地方

完整代码如下:

#include 
   #include "opencv2/core/core.hpp"   #include "opencv2/features2d/features2d.hpp"   #include "opencv2/highgui/highgui.hpp"   #include 
   #include 
   using namespace cv;  using namespace std;  int main()  {      Mat img_1 = imread("D:\\image\\img1.jpg");      Mat img_2 = imread("D:\\image\\img2.jpg");      if (!img_1.data || !img_2.data)      {          cout << "error reading images " << endl;          return -1;      }        ORB orb;      vector
 keyPoints_1, keyPoints_2;      Mat descriptors_1, descriptors_2;        orb(img_1, Mat(), keyPoints_1, descriptors_1);      orb(img_2, Mat(), keyPoints_2, descriptors_2);            BruteForceMatcher
 matcher;      vector
 matches;      matcher.match(descriptors_1, descriptors_2, matches);        double max_dist = 0; double min_dist = 100;      //-- Quick calculation of max and min distances between keypoints       for( int i = 0; i < descriptors_1.rows; i++ )      {           double dist = matches[i].distance;          if( dist < min_dist ) min_dist = dist;          if( dist > max_dist ) max_dist = dist;      }      printf("-- Max dist : %f \n", max_dist );      printf("-- Min dist : %f \n", min_dist );      //-- Draw only "good" matches (i.e. whose distance is less than 0.6*max_dist )       //-- PS.- radiusMatch can also be used here.       std::vector< DMatch > good_matches;      for( int i = 0; i < descriptors_1.rows; i++ )      {           if( matches[i].distance < 0.6*max_dist )          {               good_matches.push_back( matches[i]);           }      }        Mat img_matches;      drawMatches(img_1, keyPoints_1, img_2, keyPoints_2,          good_matches, img_matches, Scalar::all(-1), Scalar::all(-1),          vector
(), DrawMatchesFlags::NOT_DRAW_SINGLE_POINTS);      imshow( "Match", img_matches);      cvWaitKey();      return 0;  }

另外: SURF SIFT 

/*SIFT sift;sift(img_1, Mat(), keyPoints_1, descriptors_1);sift(img_2, Mat(), keyPoints_2, descriptors_2);BruteForceMatcher
 >  matcher;*//*SURF surf;surf(img_1, Mat(), keyPoints_1);surf(img_2, Mat(), keyPoints_2);SurfDescriptorExtractor extrator;extrator.compute(img_1, keyPoints_1, descriptors_1);extrator.compute(img_2, keyPoints_2, descriptors_2);BruteForceMatcher
 >  matcher;*/

需要在之前的那个imshow之前加上如下代码即可完成一个简单的功能展示:

// localize the object   std::vector
 obj;  std::vector
 scene;    for (size_t i = 0; i < good_matches.size(); ++i)  {      // get the keypoints from the good matches       obj.push_back(keyPoints_1[ good_matches[i].queryIdx ].pt);      scene.push_back(keyPoints_2[ good_matches[i].trainIdx ].pt);  }  Mat H = findHomography( obj, scene, CV_RANSAC );    // get the corners from the image_1   std::vector
 obj_corners(4);  obj_corners[0] = cvPoint(0,0);  obj_corners[1] = cvPoint( img_1.cols, 0);  obj_corners[2] = cvPoint( img_1.cols, img_1.rows);  obj_corners[3] = cvPoint( 0, img_1.rows);  std::vector
 scene_corners(4);    perspectiveTransform( obj_corners, scene_corners, H);    // draw lines between the corners (the mapped object in the scene - image_2)   line( img_matches, scene_corners[0] + Point2f( img_1.cols, 0), scene_corners[1] + Point2f( img_1.cols, 0),Scalar(0,255,0));  line( img_matches, scene_corners[1] + Point2f( img_1.cols, 0), scene_corners[2] + Point2f( img_1.cols, 0),Scalar(0,255,0));  line( img_matches, scene_corners[2] + Point2f( img_1.cols, 0), scene_corners[3] + Point2f( img_1.cols, 0),Scalar(0,255,0));  line( img_matches, scene_corners[3] + Point2f( img_1.cols, 0), scene_corners[0] + Point2f( img_1.cols, 0),Scalar(0,255,0));

转载于:https://my.oschina.net/u/1426828/blog/655485

你可能感兴趣的文章
纯DIV+CSS简单实现Tab选项卡左右切换效果
查看>>
栈(一)
查看>>
ios 自定义delegate(一)
查看>>
创建美国地区的appleId
查看>>
例题10-2 UVa12169 Disgruntled Judge(拓展欧几里德)
查看>>
JS 原生ajax写法
查看>>
Composer管理PHP依赖关系
查看>>
React.js学习笔记之JSX解读
查看>>
Socket编程问题小记
查看>>
基于Flask-Angular的项目组网架构与部署
查看>>
一张图道尽程序员的出路
查看>>
redis 常用命令
查看>>
LVS+Keepalived高可用负载均衡集群架构
查看>>
烂泥:kvm安装windows系统蓝屏
查看>>
iPhone开发面试题--葵花宝典
查看>>
EdbMails Convert EDB to PST
查看>>
POJ 2184
查看>>
大话 程序猿 眼里的 接口
查看>>
struts2用了哪几种模式
查看>>
replace函数结合正则表达式实现转化成驼峰与转化成连接字符串的方法
查看>>