【特征检測】BRIEF特征点描写叙述算法
简单介绍
BRIEF是2010年的一篇名为《BRIEF:Binary Robust Independent Elementary Features》的文章中提出,BRIEF是对已检測到的特征点进行描写叙述,它是一种二进制编码的描写叙述子,摈弃了利用区域灰度直方图描写叙述特征点的传统方法,大大的加快了特征描写叙述符建立的速度,同一时候也极大的减少了特征匹配的时间,是一种非常高速,非常有潜力的算法。
BRIEF详细算法
因为BRIEF不过特征描写叙述子。所以事先要得到特征点的位置,能够利用FAST特征点检測算法或Harris角点检測算法或SIFT、SURF等算法检測特征点的位置。
接下来在特征点邻域利用BRIEF算法建立特征描写叙述符。
算法过程例如以下:
1、为降低噪声干扰,先对图像进行高斯滤波(方差为2。高斯窗体为9x9)。
2、以特征点为中心,取SxS的邻域窗体。在窗体内随机选取一对(两个)点,比較二者像素的大小,进行例如以下二进制赋值。
当中,p(x),p(y)各自是随机点x=(u1,v1),y=(u2,v2)的像素值。
3、在窗体中随机选取N对随机点,反复步骤2的二进制赋值,形成一个二进制编码,这个编码就是对特征点的描写叙述,即特征描写叙述子。(一般N=256)
以上便是BRIEF特征描写叙述算法的步骤。
关于一对随机点的选择方法。原作者測试了下面5种方法,当中方法(2)比較好。
这5种方法生成的256对随机点例如以下(一条线段的两个端点是一对):
利用BRIEF特征进行配准
经过上面的特征提取算法,对于一幅图中的每个特征点,都得到了一个256bit的二进制编码。接下来对有相似或重叠部分的两幅图像进行配准。
特征配对是利用的汉明距离进行判决:
1、两个特征编码相应bit位上同样元素的个数小于128的,一定不是配对的。
2、一幅图上特征点与还有一幅图上特征编码相应bit位上同样元素的个数最多的特征点配成一对。
实验
opencv代码
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/features2d/features2d.hpp> using namespace cv; int main(int argc, char** argv)
{
Mat img_1 = imread("img1.png");
Mat img_2 = imread("img2.png"); // -- Step 1: Detect the keypoints using STAR Detector
std::vector<KeyPoint> keypoints_1,keypoints_2;
StarDetector detector;
detector.detect(img_1, keypoints_1);
detector.detect(img_2, keypoints_2); // -- Stpe 2: Calculate descriptors (feature vectors)
BriefDescriptorExtractor brief;
Mat descriptors_1, descriptors_2;
brief.compute(img_1, keypoints_1, descriptors_1);
brief.compute(img_2, keypoints_2, descriptors_2); //-- Step 3: Matching descriptor vectors with a brute force matcher
BFMatcher matcher(NORM_HAMMING);
std::vector<DMatch> mathces;
matcher.match(descriptors_1, descriptors_2, mathces);
// -- dwaw matches
Mat img_mathes;
drawMatches(img_1, keypoints_1, img_2, keypoints_2, mathces, img_mathes);
// -- show
imshow("Mathces", img_mathes); waitKey(0);
return 0;
}
实验结果
代码分析
在头文件features2d.hpp中定义了BRIEF算法的函数及參数:
class CV_EXPORTS BriefDescriptorExtractor : public DescriptorExtractor
{
public:
static const int PATCH_SIZE = 48; //S为48即窗体为48x48
static const int KERNEL_SIZE = 9; //高斯滤波器窗体为9x9 // bytes is a length of descriptor in bytes. It can be equal 16, 32 or 64 bytes.
BriefDescriptorExtractor( int bytes = 32 );//保存特征的空间为32字节,即32x8=256bit
...
...
...
}
对于參数的解释,写在參数定义后面。
在执行调试时,在观察窗体能够看到,在img1中检測到14个特征点,img2中检測到76个:
以img1为例,14个特征点,每一个特征点用一个32字节(256bit)的二进制编码描写叙述,则有:
进一步查看上图中第二个红框的信息,这表明特征描写叙述子存放的位置,起始地址是:0x01c08030。结束地址为:0x01c081f0。
能够看到,这就是终于提取到的特征点描写叙述编码了。一行32个字节。共14行,刚好相应img1的14个特征点。同理可知img2中得到了76个特征编码。假如以img1中的特征为准。在img2中寻找与其匹配的特征点,结果例如以下:
能够看到,img1中的14个特征点依次与img2中的第74、47、... 、29特征点配成一对,终于匹配效果见上面的实验结果图。
BRIEF算法优劣
长处
1、计算速度快
缺点
1、对噪声敏感(由于二进制编码是通过比較详细像素值来判定的)
2、不具备旋转不变性
3、不具备尺度不变性
參考资料
1、BRIEF:Binary Robust Independent Elementary Features[J].2010 ECCV.
2、基于ORB特征的检測检測与跟踪的研究[硕士论文],谢成明,2013.
3、基于ORB特征和粒子滤波的目标跟踪算法研究[硕士论文],章杰,2014.
4、基于ORB和改进RANSAC算法的图像拼接技术[J],2015.
【特征检測】BRIEF特征点描写叙述算法的更多相关文章
- Chromium网页输入事件捕捉和手势检測过程分析
连续的输入事件可能会产生一定的手势操作.比如滑动手势和捏合手势. 在Chromium中,网页的输入事件是在Browser进程中捕捉的.Browser进程捕获输入事件之后,会进行手势操作检測.检測出来的 ...
- 目标检測的图像特征提取之(一)HOG特征
1.HOG特征: 方向梯度直方图(Histogram of Oriented Gradient, HOG)特征是一种在计算机视觉和图像处理中用来进行物体检測的特征描写叙述子.它通过计算和统计图像局部区 ...
- 【OpenCV新手教程之十八】OpenCV仿射变换 & SURF特征点描写叙述合辑
本系列文章由@浅墨_毛星云 出品,转载请注明出处. 文章链接:http://blog.csdn.net/poem_qianmo/article/details/33320997 作者:毛星云(浅墨) ...
- 【OpenCV新手教程之十七】OpenCV重映射 & SURF特征点检測合辑
本系列文章由@浅墨_毛星云 出品.转载请注明出处. 文章链接:http://blog.csdn.net/poem_qianmo/article/details/30974513 作者:毛星云(浅墨) ...
- OpenCV特征点检測------Surf(特征点篇)
Surf(Speed Up Robust Feature) Surf算法的原理 ...
- OpenCV2马拉松第15圈——边缘检測(Laplace算子,LOG算子)
收入囊中 拉普拉斯算子 LOG算子(高斯拉普拉斯算子) OpenCV Laplacian函数 构建自己的拉普拉斯算子 利用拉普拉斯算子进行图像的锐化 葵花宝典 在OpenCV2马拉松第14圈--边缘检 ...
- 操作系统栈溢出检測之ucosII篇
操作系统栈溢出检測之uc/osII篇 Author : David Lin (林鹏) E-mail : linpeng1 ...
- 行人检測之HOG特征(Histograms of Oriented Gradients)
之前的文章行人计数.计次提到HOG特征这个概念,这两天看了一下原版的论文,了解了一下HOG特征的原理,并依据自己的理解将这种方法的流程写了下来,假设有不正确的地方欢迎指正. HOG(Histogram ...
- 【从零学习openCV】IOS7下的人脸检測
前言: 人脸检測与识别一直是计算机视觉领域一大热门研究方向,并且也从安全监控等工业级的应用扩展到了手机移动端的app,总之随着人脸识别技术获得突破,其应用前景和市场价值都是不可估量的,眼下在学习ope ...
随机推荐
- “玲珑杯”ACM比赛 Round #19
A -- A simple math problem Time Limit:2s Memory Limit:128MByte Submissions:1599Solved:270 DESCRIPTIO ...
- .NET重构(七):VS报表的制作
导读:机房做到最后阶段,就是报表的制作了.想到第一次,是借助外部控件进行实现的,这次采用VS进行编写,在这个软件中,有自带的报表编辑工具,更加的方便和简洁,现在就对这一块的学习,进行总结. 一.报表制 ...
- BZOJ 4033 [HAOI2015]树上染色 ——树形DP
可以去UOJ看出题人的题解. 这样的合并,每一个点对只在lca处被考虑到,复杂度$O(n^2)$ #include <map> #include <ctime> #includ ...
- HDU 1724 Ellipse ——Simpson积分
[题目分析] 一看题目,直接把椭圆积分起来就可以了嘛. 然后发现椭圆比较难积分,还是算了吧. 用Simpson积分硬上. 大概就是用二次函数去拟合面积. [代码] #include <cstdi ...
- 算法总结——主席树(poj2104)
题目: Description You are working for Macrohard company in data structures department. After failing y ...
- Swift3.0 函数闭包与 Block
刚接触Swift,如有不对,欢迎指正 Swift中定义一个基本函数 //定义一个函数,接收一个字符串,返回一个String类型的值 func test(name:String) -> Strin ...
- 标准C程序设计七---00
以下内容为阅读: <21天学通C语言>(第7版) 作者:Bradley Jones Peter Aitken Dean Miller(美), 姜佑译 人民邮电出版社 2014.11 ...
- java连oracle
下载连接驱动 安装完oracle之后 D:\app\Administrator\product\11.2.0\dbhome_1\jdbc\lib 目录下拷贝 支持jdk1.6以上 From.java ...
- DBA总结
HA MHA(1)从宕机崩溃的master保存二进制日志事件(binlog events);(2)识别含有最新更新的slave:(3)应用差异的中继日志(relay log)到其他的slave:(4) ...
- 一步步走向国际乱码大赛-- 恶搞C语言
大家都一直强调规范编码.可是这个世界上有个大师们娱乐的竞赛--国际乱码大赛. 能写出来的都是对语言深入了解的master.我从没想自己也能"恶搞"C,一直都是老老实实编码.就在前几 ...