在 Opencv 2.4.6 ubuntu 中筛选实现
Sift implementation in Opencv 2.4.6 ubuntu
我正在尝试计算 2 张图像之间的对应关系,并且实际上对对应点的数量感兴趣,而不是对应点本身,以便我可以起诉它以获得最佳匹配图像。这是我的以下代码:
#include<iostream>
#include<vector>
#include<string>
#include "cv.h"
#include "highgui.h"
#include "opencv2/imgproc/imgproc.hpp"
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/legacy/legacy.hpp"
#include "opencv2/objdetect/objdetect.hpp"
#include "opencv2/nonfree/nonfree.hpp"
#include "opencv2/nonfree/features2d.hpp"
#include<stdio.h>
using namespace cv;
using namespace std;
int main(int argc, char **argv)
{
Mat A = imread("/home/itachi/iTaggproj/frame6.jpg",CV_LOAD_IMAGE_COLOR);
Mat src = imread("/home/itachi/iTaggproj/dataformatch/frame0.jpg",CV_LOAD_IMAGE_COLOR);
SiftFeatureDetector detector( 0.05, 5.0 );
SiftDescriptorExtractor extractor( 3.0 );
vector<KeyPoint>keypoints1,keypoints2;
detector.detect( A, keypoints1 );
detector.detect( src, keypoints2 );
int key1 = keypoints1.size();
int key2 = keypoints2.size();
printf("Keypoint1=%d nKeypoint2=%d", key1, key2);
// Feature descriptor computation
Mat descriptor1,descriptor2;
extractor.compute( A, keypoints1, descriptor1 );
extractor.compute( src, keypoints2, descriptor2 );
//match points to get correspondence
// BFMatcher matcher(NORM_L2);
FlannBasedMatcher matcher;
vector<DMatch>matches;
matcher.match( descriptor1, descriptor2, matches );
cout<<endl<<matches.size()<<endl;
return 0;
}
我从链接 1 和链接 2 中获取了我的代码。我所有的图像都是320X240。我拿了一个测试图像,并尝试在图像数据库上逐个运行它。但每次我这样做,我的比赛大小总是163。请注意,测试图像中的关键点也是 163。我正在尝试为测试图像找到最佳匹配项,但我不知道为什么会发生这种情况。与数据库的所有对应匹配都给出 163 的结果。
这些是我的问题和疑问,请帮助我。
- 如果上述方法使用错误,如何获得匹配数?
抱歉,如果问题非常简陋,但您的帮助非常感激。
FlannBasedMatcher.match()
方法不会执行您认为的操作;它将为每个关键点返回最佳匹配项。 因此,您将始终拥有 163 场比赛,因为总会有最佳匹配,即使它不是很好。
匹配特征时通常发生的情况是,然后将阈值应用于描述符距离;例如,如果任何匹配的距离大于阈值t
,则它们将被拒绝。 阈值化后的良好匹配数通常用于衡量图像之间的相似性。 我认为这是您期望获得的数字。
您的代码基本上构成了本教程的第一部分。 如果您阅读本教程,您将看到我所描述的内容,其中匹配项根据其距离设置阈值。
相关文章:
- 如果没有malloc,链表实现将失败
- 如何在c++中实现处理器调度模拟器
- 如何在c++中使用引用实现类似python的行为
- 实现无开销push_back的最佳方法是什么
- 使用简单类型列表实现的指数编译时间.为什么
- 如何在BST的这个简单递归实现中消除警告
- 实现一个在集合上迭代的模板函数
- 我应该实现右值推送功能吗?我应该使用std::move吗
- 如何正确实现和访问运算符的各种自定义枚举器
- C++Union/Struct位域的实现和可移植性
- 这个极客对极客的trie实现是否存在内存泄漏问题
- 在c++中实现LinkedList时,应出现未处理的错误
- 为左值和右值的包装器实现C++范围
- 使用模板进行堆栈实现; "name followed by :: must be a class or namespace"
- 使用GSoap实现ONVIF
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 在 Opencv 2.4.6 ubuntu 中筛选实现
- C++ SSE 筛选器实现
- Eratosthenes c++实现错误的筛选
- 筛选(标准)设计模式的正确实现