OpenCV图像匹配算法之freak

OpenCV图像匹配算法之freak,第1张

概述OpenCV图像匹配算法之freak

下面是内存溢出 jb51.cc 通过网络收集整理的代码片段。

内存溢出小编现在分享给大家,也给大家做个参考。

    //freak.cpp      #include "stdafx.h"      #include <cv.hpp>      #include <highgui.h>      #include "utils.h"      #include <iostream>      using namespace std;            voID freak(char* path1,char* path2,INFO& info,bool show)      {          double t1,t2;          t1=cvGetTickCount();                initModule_nonfree();                Mat img1,img2;          img1=imread(path1,0);          img2=imread(path2,0);          if(img1.data==NulL)          {              cout<<"The image can not been loaded: "<<path1<<endl;              system("pause");              exit(-1);          }          if(img2.data==NulL)          {              cout<<"The image can not been loaded: "<<path2<<endl;              system("pause");              exit(-1);          }                vector<KeyPoint> kpts1_freak,kpts2_freak;          Mat desc1_freak,desc2_freak;          Ptr<cv::DescriptorMatcher> matcher_l1 = DescriptorMatcher::create("BruteForce-Hamming");      //二进制汉明距离匹配          vector<vector<DMatch> > dmatches_freak;          vector<Point2f> matches_freak,inlIErs_freak;                              SurfFeatureDetector dfreak(200,4);                    dfreak.detect(img1,kpts1_freak);          dfreak.detect(img2,kpts2_freak);          info.n1 = kpts1_freak.size();          info.n2 = kpts2_freak.size();                    FREAK freak;          freak.compute(img1,kpts1_freak,desc1_freak);          freak.compute(img2,kpts2_freak,desc2_freak);          matcher_l1->knnMatch(desc1_freak,desc2_freak,dmatches_freak,2);          matches2points_nndr(kpts1_freak,matches_freak,dratIO);          info.m=matches_freak.size()/2;          compute_inlIErs_ransac(matches_freak,inlIErs_freak,MIN_H_ERROR,false);          info.rm=inlIErs_freak.size()/2;                t2=cvGetTickCount();          info.t=(t2-t1)/1000000.0/cvGetTickFrequency();                Mat img1_rgb_freak = imread(path1,1);          Mat img2_rgb_freak = imread(path2,1);          Mat img_com_freak = Mat(Size(img1.cols*2,img1.rows),CV_8UC3);                if(show == true)          {              draw_inlIErs(img1_rgb_freak,img2_rgb_freak,img_com_freak,2);              imshow("freak",img_com_freak);              waitKey(0);          }                return;      }  

使用
    INFO freak_info;      freak(path1,path2,freak_info,true);      showInfo(freak_info);  

以上是内存溢出(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

总结

以上是内存溢出为你收集整理的OpenCV图像匹配算法之freak全部内容,希望文章能够帮你解决OpenCV图像匹配算法之freak所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1232273.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存