中文字幕在线观看,亚洲а∨天堂久久精品9966,亚洲成a人片在线观看你懂的,亚洲av成人片无码网站,亚洲国产精品无码久久久五月天

OpenCV圖像匹配算法之brisk

2018-07-20    來源:open-open

容器云強(qiáng)勢(shì)上線!快速搭建集群,上萬Linux鏡像隨意使用
    //brisk.cpp  
    #include "stdafx.h"  
    #include <cv.hpp>  
    #include <highgui.h>  
    #include "utils.h"  
    #include <iostream>  
    using namespace std;  
      
    void brisk(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);  
        }  
      
        BRISK dbrisk(BRISK_HTHRES,BRISK_NOCTAVES);  
        vector<KeyPoint> kpts1_brisk, kpts2_brisk;  
        Mat desc1_brisk, desc2_brisk;  
        Ptr<cv::DescriptorMatcher> matcher_l1 = DescriptorMatcher::create("BruteForce-Hamming");      //二進(jìn)制漢明距離匹配  
        vector<vector<DMatch> > dmatches_brisk;  
        vector<Point2f> matches_brisk, inliers_brisk;  
          
        dbrisk(img1,noArray(),kpts1_brisk,desc1_brisk,false);  
        dbrisk(img2,noArray(),kpts2_brisk,desc2_brisk,false);  
        info.n1=kpts1_brisk.size();  
        info.n2=kpts2_brisk.size();  
      
        matcher_l1->knnMatch(desc1_brisk,desc2_brisk,dmatches_brisk,2);  
        matches2points_nndr(kpts1_brisk,kpts2_brisk,dmatches_brisk,matches_brisk,DRATIO);  
        info.m=matches_brisk.size()/2;  
        compute_inliers_ransac(matches_brisk,inliers_brisk,MIN_H_ERROR,false);  
        info.rm=inliers_brisk.size()/2;  
      
        t2=cvGetTickCount();  
        info.t=(t2-t1)/1000000.0/cvGetTickFrequency();  
      
        Mat img1_rgb_brisk = imread(path1,1);  
        Mat img2_rgb_brisk = imread(path2,1);  
        Mat img_com_brisk = Mat(Size(img1.cols*2,img1.rows),CV_8UC3);  
      
        if(show == true)  
        {  
            draw_inliers(img1_rgb_brisk,img2_rgb_brisk,img_com_brisk,inliers_brisk,2);  
            imshow("brisk",img_com_brisk);  
            waitKey(0);  
        }  
      
        return;  
    }  

使用
    INFO brisk_info;  
    brisk(path1,path2,brisk_info,false);  
    showInfo(brisk_info);  

標(biāo)簽:

版權(quán)申明:本站文章部分自網(wǎng)絡(luò),如有侵權(quán),請(qǐng)聯(lián)系:west999com@outlook.com
特別注意:本站所有轉(zhuǎn)載文章言論不代表本站觀點(diǎn)!
本站所提供的圖片等素材,版權(quán)歸原作者所有,如需使用,請(qǐng)與原作者聯(lián)系。

上一篇: 將時(shí)間顯示為“剛剛”“n分鐘/小時(shí)前”等的PHP代碼

下一篇:php生成驗(yàn)證碼 支持中文 字母 數(shù)字混合