opencv-之SIFT匹配算法

本文介绍了使用OpenCV库在C++中实现SIFT特征检测、关键点匹配及描述符提取的过程。通过读取两张图片,调整大小,利用SIFT算法检测特征并绘制,然后计算特征向量,最后使用BFMatch进行暴力匹配并筛选出高质量匹配。
摘要由CSDN通过智能技术生成

先上代码

#include "opencv2/opencv.hpp"
#include <opencv2/nonfree/nonfree.hpp>//SIFT
#include <opencv2/legacy/legacy.hpp>//BFMatch暴力匹配
#include <vector>
#include<iostream>
using namespace std;
using namespace cv;
void main()
{     
    Mat srcImg1 = imread("D:\\0.jpg");
    Mat srcImg2 = imread("D:\\1.jpg");
	resize(srcImg1,srcImg1,Size(srcImg1.cols*3,srcImg1.rows*3));
	resize(srcImg2,srcImg2,Size(srcImg2.cols/3,srcImg2.rows/3));
    //定义SIFT特征检测类对象
    SiftFeatureDetector siftDetector(1000);//先给SiftFeatureDetector 定义一个对象,这里与C++构造函数类似。这里1000是一个匹配精度,值越大匹配精度越大
    //定义KeyPoint变量,用来存放待会特征点匹配的结果
    vector<KeyPoint>keyPoints1;
    vector<KeyPoint>keyPoints2;
    //特征点检测
    siftDetector.detect(srcImg1, keyPoints1);//调用detect属性,这个属性其实是个函数
    siftDetector.detect(srcImg2, keyPoints2);//从图片中检查特征点存入keyPoints2中
    //绘制特征点(关键点)
    Mat feature_pic1, feature_pic2;
    drawKeypoints(srcImg1, keyPoints1, feature_pic1, Scalar::all(-1));
    drawKeypoints(srcImg2, keyPoints2, feature_pic2, Scalar::all(-1));
    //显示原图
    imshow("src1", srcImg1);
    imshow("src2", srcImg2);
    //显示结果
    imshow("feature1", feature_pic1);
    imshow("feature2", feature_pic2);
    //计算特征点描述符 / 特征向量提取
    SiftDescriptorExtractor descriptor;//定义一个对象
    Mat description1;
    descriptor.compute(srcImg1, keyPoints1, description1);//开始调用对象的compute属性计算
    Mat description2;
    descriptor.compute(srcImg2, keyPoints2, description2);
    //进行BFMatch暴力匹配
    BruteForceMatcher<L1<float>>matcher;    //实例化暴力匹配器
    vector<DMatch>matches;   //定义匹配结果变量。用来存放匹配到的点
    matcher.match(description1, description2, matches);  //实现描述符之间的匹配
    //匹配结果筛选
    nth_element(matches.begin(), matches.begin()+29, matches.end());   //提取出前30个最佳匹配结果     
    matches.erase(matches.begin()+30, matches.end());    //剔除掉其余的匹配结果
    Mat result;
    drawMatches(srcImg1, keyPoints1, srcImg2, keyPoints2, matches, result,  Scalar(0, 255, 0), Scalar::all(-1));//匹配特征点绿色,单一特征点颜色随机
    imshow("Match_Result", result);
    waitKey(0);
}
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值