• 学习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

  • 相关阅读:
    学习 TList 类的实现[8]
    System.SetString 获取字符串
    System.Odd 判断一个整数是不是奇数
    问与答[2008331]
    System.Val 将字符串转换为数字
    事件自调用 回复 maxcool 的问题
    JS操作select相关方法:新增 修改 删除 选中 清空 判断存在 等
    自由人生 从容生活
    [引]智能设备开发演练:创建用于设备的 Windows 窗体应用程序
    gentle做的分页控件
  • 原文地址:https://www.cnblogs.com/GarfieldEr007/p/5401909.html
Copyright © 2020-2023  润新知