zoukankan      html  css  js  c++  java
  • 学习OpenCV——Surf简化版

    之前写过一遍关于学习surf算法的blog:http://blog.csdn.net/sangni007/article/details/7482960

    但是代码比较麻烦,而且其中还涉及到flann算法(其中的Random KDTree+KNN),虽然能看明白,但是比较费劲,今天在文档中找到一个简化版本:

    1.SurfFeatureDetector detector( minHessian );构造surf检测器;

       detector.detect( img_1, keypoints_1 ); detector.detect( img_2, keypoints_2 );检测

    2.SurfDescriptorExtractor extractor;提取描述结构

       Mat descriptors_1, descriptors_2;

       extractor.compute( img_1, keypoints_1, descriptors_1 ); extractor.compute( img_2, keypoints_2, descriptors_2 );

    3.BruteForceMatcher< L2<float> > matcher;牛逼的匹配结构啊!!!!可以直接暴力测量距离

       std::vector< DMatch > matches; 

       matcher.match( descriptors_1, descriptors_2, matches );

     文档:http://opencv.itseez.com/modules/gpu/doc/feature_detection_and_description.html?highlight=bruteforce#gpu::BruteForceMatcher_GPU

    PS:OpenCV 你是在太强悍了!!!只有我想不到,木有你办不到的啊! 我真心跪了!

    [cpp] view plain copy
     
     print?
    1. /** 
    2.  * @file SURF_descriptor 
    3.  * @brief SURF detector + descritpor + BruteForce Matcher + drawing matches with OpenCV functions 
    4.  * @author A. Huaman 
    5.  */  
    6.   
    7. #include <stdio.h>  
    8. #include <iostream>  
    9. #include "opencv2/core/core.hpp"  
    10. #include "opencv2/features2d/features2d.hpp"  
    11. #include "opencv2/highgui/highgui.hpp"  
    12.   
    13. using namespace cv;  
    14. using namespace std;  
    15.   
    16. void readme();  
    17.   
    18. /** 
    19.  * @function main 
    20.  * @brief Main function 
    21.  */  
    22. int main( int argc, char** argv )  
    23. {  
    24.   //if( argc != 3 )  
    25.   //{ return -1; }  
    26.   
    27.   Mat img_1 = imread( "D:/src.jpg", CV_LOAD_IMAGE_GRAYSCALE );  
    28.   Mat img_2 = imread( "D:/Demo.jpg", CV_LOAD_IMAGE_GRAYSCALE );  
    29.     
    30.   if( !img_1.data || !img_2.data )  
    31.   { return -1; }  
    32.   
    33.   //-- Step 1: Detect the keypoints using SURF Detector  
    34.   int minHessian = 400;  
    35.     
    36.   double t=getTickCount();  
    37.   
    38.   SurfFeatureDetector detector( minHessian );  
    39.   
    40.   std::vector<KeyPoint> keypoints_1, keypoints_2;  
    41.   
    42.   detector.detect( img_1, keypoints_1 );  
    43.   detector.detect( img_2, keypoints_2 );  
    44.   
    45.   //-- Step 2: Calculate descriptors (feature vectors)  
    46.   SurfDescriptorExtractor extractor;  
    47.   
    48.   Mat descriptors_1, descriptors_2;  
    49.   
    50.   extractor.compute( img_1, keypoints_1, descriptors_1 );  
    51.   extractor.compute( img_2, keypoints_2, descriptors_2 );  
    52.   
    53.   //-- Step 3: Matching descriptor vectors with a brute force matcher  
    54.   BruteForceMatcher< L2<float> > matcher;  
    55.   std::vector< DMatch > matches;  
    56.   matcher.match( descriptors_1, descriptors_2, matches );  
    57.   t=getTickCount()-t;  
    58.   t=t*1000/getTickFrequency();  
    59.   //-- Draw matches  
    60.   Mat img_matches;  
    61.   drawMatches( img_1, keypoints_1, img_2, keypoints_2, matches, img_matches );   
    62.   cout<<"Cost Time:"<<t<<endl;  
    63.   //-- Show detected matches  
    64.   imshow("Matches", img_matches );  
    65.   
    66.   waitKey(0);  
    67.   
    68.   return 0;  
    69. }  
    70.   
    71. /** 
    72.  * @function readme 
    73.  */  
    74. void readme()  
    75. { std::cout << " Usage: ./SURF_descriptor <img1> <img2>" << std::endl; }  

    图像中match的keypoints没有经过过滤。导致匹配点过多

    文档地址:http://opencv.itseez.com/doc/tutorials/features2d/feature_description/feature_description.html?highlight=description

    文档中还有一个版本带定位的和过滤Match的,

    http://opencv.itseez.com/doc/tutorials/features2d/feature_homography/feature_homography.html?highlight=drawmatchesflags

    from: http://blog.csdn.net/yangtrees/article/details/7544133

  • 相关阅读:
    zookeeper的ACL权限控制
    Zookeeper客户端Curator基本API
    get和post的区别
    Html基本操作实例代码
    poj3322 Bloxorz I
    Delphi 调用SQL Server 2008存储过程
    架构设计师—你在哪层楼?
    LINUX常用命令
    分层自动化测试与传统自动化测试的差别
    商业智能漫谈
  • 原文地址:https://www.cnblogs.com/GarfieldEr007/p/5401909.html
Copyright © 2011-2022 走看看