OpenCV中feature2D学习——BFMatcher和FlannBasedMatcher
2014-11-08 21:44
405 查看
C++: BFMatcher::BFMatcher(int normType=NORM_L2,
bool crossCheck=false )
Parameters: | normType – One of NORM_L1, NORM_L2, NORM_HAMMING, NORM_HAMMING2. L1 and L2 norms are preferable choices for SIFT and SURF descriptors, NORM_HAMMING should be used with ORB, BRISK and BRIEF, NORM_HAMMING2 should be used with ORB when WTA_K==3 or 4 (see ORB::ORB constructor description). crossCheck – If it is false, this is will be default BFMatcher behaviour when it finds the k nearest neighbors for each query descriptor. If crossCheck==true, then the knnMatch() method with k=1 will only return pairs (i,j) such that for i-th query descriptor the j-th descriptor in the matcher’s collection is the nearest and vice versa, i.e. the BFMatcher will only return consistent pairs. Such technique usually produces best results with minimal number of outliers when there are enough matches. This is alternative to the ratio test, used by D. Lowe in SIFT paper. |
---|
class FlannBasedMatcher : public DescriptorMatcher { public: FlannBasedMatcher( const Ptr<flann::IndexParams>& indexParams=new flann::KDTreeIndexParams(), const Ptr<flann::SearchParams>& searchParams=new flann::SearchParams() ); virtual void add( const vector<Mat>& descriptors ); virtual void clear(); virtual void train(); virtual bool isMaskSupported() const; virtual Ptr<DescriptorMatcher> clone( bool emptyTrainData=false ) const; protected: ... };
二者的区别在于BFMatcher总是尝试所有可能的匹配,从而使得它总能够找到最佳匹配,这也是Brute Force(暴力法)的原始含义。而FlannBasedMatcher中FLANN的含义是Fast Library forApproximate Nearest Neighbors,从字面意思可知它是一种近似法,算法更快但是找到的是最近邻近似匹配,所以当我们需要找到一个相对好的匹配但是不需要最佳匹配的时候往往使用FlannBasedMatcher。当然也可以通过调整FlannBasedMatcher的参数来提高匹配的精度或者提高算法速度,但是相应地算法速度或者算法精度会受到影响。
此外,使用特征提取过程得到的特征描述符(descriptor)数据类型有的是float类型的,比如说SurfDescriptorExtractor,
SiftDescriptorExtractor,有的是uchar类型的,比如说有ORB,BriefDescriptorExtractor。对应float类型的匹配方式有:FlannBasedMatcher,BruteForce<L2<float>>,BruteForce<SL2<float>>,BruteForce<L1<float>>。对应uchar类型的匹配方式有:BruteForce<Hammin>,BruteForce<HammingLUT>。所以ORB和BRIEF特征描述子只能使用BruteForce匹配法。
相关文章推荐
- opencv中的BFMatcher和FlannBasedMatcher的区别
- OpenCV中feature2D学习——ORB和BruteForceMatcher
- OpenCV中feature2D学习——ORB和BruteForceMatcher
- OpenCV中feature2D学习——ORB和BruteForceMatcher
- BFMatcher和FlannBasedMatcher
- opencv图像特征检测及匹配(harris,sift,surf,fast,breif,orb,BFmatch,FlannBasedMatcher)
- OpenCV中feature2D学习——亚像素级角点检测(cornerSubPix)
- 学习OpenCV——Surf(特征点篇)&flann
- OpenCV中feature2D学习——SIFT和SURF算法实现目标检测
- OPENCV中BFMatcher(BruteForceMatcher)和FlannBasedMatcher区别
- OpenCV中feature2D学习——SIFT和SURF算法实现目标检测
- OpenCV入门 - 关键点描述子匹配Flann-based
- 学习OpenCV——Surf(特征点篇)&flann(二)
- 【错误处理】error C2065: “SurfFeatureDetector”: 未声明的标识符;error C2065: “FlannBasedMatcher”: 未声明的标识符
- 学习opencv有感(二)-2维特征Feature2D
- OpenCV学习笔记[5]FLANN特征匹配
- 学习OpenCV——Surf(特征点篇)&flann
- OpenCV学习笔记__使用FLANN进行特征点匹配
- 学习OpenCV——Surf(特征点篇)&flann(一)
- 学习OpenCV——Surf(特征点篇)&flann