【OpenCV】OpenCV3中的SURF特征点的寻找和匹配
来源:互联网 发布:淘宝评价管理在哪 编辑:程序博客网 时间:2024/04/27 09:26
不多说什么了,直接上代码吧:
#include <iostream>#include <stdio.h>#include "opencv2/core.hpp"#include "opencv2/core/utility.hpp"#include "opencv2/core/ocl.hpp"#include "opencv2/imgcodecs.hpp"#include "opencv2/highgui.hpp"#include "opencv2/features2d.hpp"#include "opencv2/calib3d.hpp"#include "opencv2/imgproc.hpp"#include"opencv2/flann.hpp"#include"opencv2/xfeatures2d.hpp"#include"opencv2/ml.hpp"using namespace cv;using namespace std;using namespace cv::xfeatures2d;using namespace cv::ml;int main(){ Mat a = imread("box.png", IMREAD_GRAYSCALE); //读取灰度图像 Mat b = imread("box_in_scene.png", IMREAD_GRAYSCALE); Ptr<SURF> surf; //创建方式和2中的不一样 surf = SURF::create(800); BFMatcher matcher; Mat c, d; vector<KeyPoint>key1, key2; vector<DMatch> matches; surf->detectAndCompute(a, Mat(), key1, c); surf->detectAndCompute(b, Mat(), key2, d); matcher.match(c, d, matches); //匹配 sort(matches.begin(), matches.end()); //筛选匹配点 vector< DMatch > good_matches; int ptsPairs = std::min(50, (int)(matches.size() * 0.15)); cout << ptsPairs << endl; for (int i = 0; i < ptsPairs; i++) { good_matches.push_back(matches[i]); } Mat outimg; drawMatches(a, key1, b, key2, good_matches, outimg, Scalar::all(-1), Scalar::all(-1),vector<char>(), DrawMatchesFlags::NOT_DRAW_SINGLE_POINTS); //绘制匹配点 std::vector<Point2f> obj; std::vector<Point2f> scene; for (size_t i = 0; i < good_matches.size(); i++) { obj.push_back(key1[good_matches[i].queryIdx].pt); scene.push_back(key2[good_matches[i].trainIdx].pt); } std::vector<Point2f> obj_corners(4); obj_corners[0] = Point(0, 0); obj_corners[1] = Point(a.cols, 0); obj_corners[2] = Point(a.cols, a.rows); obj_corners[3] = Point(0, a.rows); std::vector<Point2f> scene_corners(4); Mat H = findHomography(obj, scene, RANSAC); //寻找匹配的图像 perspectiveTransform(obj_corners, scene_corners, H); line(outimg,scene_corners[0] + Point2f((float)a.cols, 0), scene_corners[1] + Point2f((float)a.cols, 0),Scalar(0, 255, 0), 2, LINE_AA); //绘制 line(outimg,scene_corners[1] + Point2f((float)a.cols, 0), scene_corners[2] + Point2f((float)a.cols, 0),Scalar(0, 255, 0), 2, LINE_AA); line(outimg,scene_corners[2] + Point2f((float)a.cols, 0), scene_corners[3] + Point2f((float)a.cols, 0),Scalar(0, 255, 0), 2, LINE_AA); line(outimg,scene_corners[3] + Point2f((float)a.cols, 0), scene_corners[0] + Point2f((float)a.cols, 0),Scalar(0, 255, 0), 2, LINE_AA); imshow("aaaa",outimg); cvWaitKey(0);}
运行图:
//-------------读取模板------------ cv::Mat img_object = imread("/storage/emulated/0/ApplePearFace/imgTemp.jpg"); //-------------图像处理--------- cv::Mat img_scene(yimage); /* // 检测surf特征点 int minHessian = 400; OrbDescriptorExtractor detector(minHessian); std::vector<KeyPoint> keypoints_1, keypoints_2; detector.detect(img_1, keypoints_1); detector.detect(img_2, keypoints_2); //-- Step 2: Calculate descriptors (feature vectors) OrbDescriptorExtractor extractor; Mat descriptors_1, descriptors_2; extractor.compute(img_1, keypoints_1, descriptors_1); extractor.compute(img_2, keypoints_2, descriptors_2); //-- Step 3: Matching descriptor vectors with a brute force matcher BFMatcher matcher(NORM_L2); std::vector< DMatch > matches; matcher.match(descriptors_1, descriptors_2, matches); //-- Draw matches Mat img_matches; drawMatches(img_1, keypoints_1, img_2, keypoints_2, matches, img_matches);*/ // 读取数据 //cv::Mat img_object = cv::imread("doll01.jpg"); //cv::Mat img_scene = cv::imread("doll012.jpg"); if (!img_object.data || !img_scene.data) { cout << "Error reading images." << endl; return 0; } // 构建特征检测器和描述子提取器 cv::Ptr<cv::FeatureDetector> detector = cv::FeatureDetector::create("ORB"); cv::Ptr<cv::DescriptorExtractor> descriptor = cv::DescriptorExtractor::create("ORB"); // 检测特征点 vector<cv::KeyPoint> kp_object, kp_scene; detector->detect(img_object, kp_object); detector->detect(img_scene, kp_scene); // 计算描述子 cv::Mat desp_object, desp_scene; descriptor->compute(img_object, kp_object, desp_object); descriptor->compute(img_scene, kp_scene, desp_scene); /* if (desp_object.type() != CV_32F) { desp_object.convertTo(desp_object, CV_32F); } if (desp_scene.type() != CV_32F) { desp_scene.convertTo(desp_scene, CV_32F); } */ // 匹配描述子 vector<cv::DMatch> matches; cv::FlannBasedMatcher matcher(new cv::flann::LshIndexParams(20, 10, 2)); matcher.match(desp_object, desp_scene, matches); //cout << "Find total " << matches.size() << " matches." << endl; // 筛选匹配 //double min_dist = 100000; //for (int i = 0; i < matches.size(); i++) { //float a = matches[i].distance; //if (a < min_dist) { //min_dist = matches[i].distance; //} //} //vector<cv::DMatch> good_matches; //for (int i = 0; i < matches.size(); i++) { // //if (matches[i].distance < 3 * min_dist) { //good_matches.push_back(matches[i]); //} //} // 显示匹配 //cout << "Good matches=" << matches.size() << endl; cv::Mat img_matches; cv::drawMatches(img_object, kp_object, img_scene, kp_scene, matches, img_matches); // 定位目标 cv::vector<cv::Point2f> obj_points; cv::vector<cv::Point2f> scene; for (int i = 0; i < matches.size(); i++) { obj_points.push_back(kp_object[matches[i].queryIdx].pt); scene.push_back(kp_scene[matches[i].trainIdx].pt); } cv::Mat H = cv::findHomography(obj_points, scene, CV_RANSAC); cv::vector<cv::Point2f> obj_corners(4); cv::vector<cv::Point2f> scene_corners(4); obj_corners[0] = cv::Point(0, 0); obj_corners[1] = cv::Point(img_object.cols, 0); obj_corners[2] = cv::Point(img_object.cols, img_object.rows); obj_corners[3] = cv::Point(0, img_object.rows); cv::perspectiveTransform(obj_corners, scene_corners, H); cv::line(img_matches, scene_corners[0] + cv::Point2f(img_object.cols, 0), scene_corners[1] + cv::Point2f(img_object.cols, 0), cv::Scalar(0, 255, 0), 4); cv::line(img_matches, scene_corners[1] + cv::Point2f(img_object.cols, 0), scene_corners[2] + cv::Point2f(img_object.cols, 0), cv::Scalar(0, 255, 0), 4); cv::line(img_matches, scene_corners[2] + cv::Point2f(img_object.cols, 0), scene_corners[3] + cv::Point2f(img_object.cols, 0), cv::Scalar(0, 255, 0), 4); cv::line(img_matches, scene_corners[3] + cv::Point2f(img_object.cols, 0), scene_corners[0] + cv::Point2f(img_object.cols, 0), cv::Scalar(0, 255, 0), 4); cv::Mat dstSize; cv::resize(img_matches, dstSize, Size(2 * h, w));
0 0
- 【OpenCV】OpenCV3中的SURF特征点的寻找和匹配
- OpenCV3中的SURF特征点的寻找和匹配
- Emgucv SURF特征点的寻找和匹配
- OpenCV实现摄像机标定和像素转换,surf寻找特征点,FLANN匹配算子进行匹配
- opencv3.2 SURF实现特征点匹配
- OpenCV中的SURF特征匹配
- opencv surf特征点匹配拼接源码
- opencv surf特征点匹配拼接源码
- opencv3.1 surf特征匹配
- OpenCV Surf特征匹配
- 【opencv】 特征点检测 sift和surf
- 使用RANSAC提纯SIFT和SURF特征点,达到鲁棒匹配的效果(OpenCV 2.4.13下,源码)
- OpenCV中feature2D学习——SIFT和SURF算子实现特征点提取与匹配
- OpenCV中feature2D学习——SIFT和SURF算子实现特征点提取与匹配
- opencv之SURF特征点提取及匹配
- 【OpenCV】SURF算法之视频图像实时特征点匹配
- Surf特征匹配点提纯
- opencv3中FLANN结合SURF进行关键点的描述和匹配
- 【第11周 项目1 - 二叉树算法验证(1)层次遍历算法的验证】
- shiro 小白学习过程(1)
- Cocoa深入学习:NSOperationQueue、NSRunLoop和线程安全
- 为什么Java中500==500为假而50==50为真?
- Boostrap 标准的远程弹出窗口页面样式
- 【OpenCV】OpenCV3中的SURF特征点的寻找和匹配
- if的格式
- hadoop学习之HIVE(3.2):hadoop2.7.2下配置hiveserver2启动远程连接
- 【JavaWeb】JSP学习笔记(一)环境|目录|JSP基础语法|内置对象
- LuaFramework数据传输Protobuf的解析repeated字段
- iPhone6无法开机
- 7. Reverse Integer
- sysbench压力测试工具使用方法
- centos7+maven安装