SURF(Speeded-Up Robust Features) 是对 SIFT 得改进,相对于 SIFT,SURF 利用积分图像与盒函数模拟 DoG,提升了计算速度;同时,使用了一种不用于 SIFT 的特征描述方案。

在 SIFT 中,检测尺度空间极值使用了 DoG 响应,SURF 做了如下改进:

1)首先求原图像的积分图像,使用积分图像可以求任意尺度盒函数(Box Filter)响应;

2)使用 Box Fitler 代替 DoG,下图给出了垂直方向与xy方向的 Box Filter,使用积分图像求任意尺寸响应时间都是固定的;

3)在 空间寻找极值作为候选特征点,定义 Hessian 矩阵 ,其中,G 为高斯函数,I 为图像函数;

剔除 Det(H) 小于某固定值的候选特征点,得到较好的极值点;

4)使用小波函数计算特征点附近响应,该响应仍然可在积分图像上计算;然后以 60 度为步长在圆形上滑动,求每个窗口响应和并将响应和最大方向作为主方向;

5)将特征点区域分为 4 * 4 小区域,在小区域内再次应用小波函数,并分别求出响应和,可构成向量 ,最终构成 4 * 4 * 4 = 64 维特征向量;

一种扩展方式是区分 dx,dy 方向,分别统计 dy > 0 时对应的 dx 求和,dy < 0 时对应的 dx 求和...,这样将 v 扩展为 8 维向量,最终形成 4 * 4 * 8 = 128 维特征向量;

opencv 提供了 SURF 实现,其构造函数如下:

SURF(double hessianThreshold, int nOctaves=4, int nOctaveLayers=2, bool extended=true, bool upright=false);

hessianThreshold:当候选特征点的 Hessian 矩阵行列式值小于该值时,忽略该候选特征点;

nOctaves:表示高斯金字塔层数,当层数越多时,可检测到更粗的特征点;

nOctaveLayers:检测尺度空间上极值使用层数为 nOctaveLayers + 3;

extended:是否使用扩展特征描述,默认特征点描述向量为64维,扩展特征点描述向量为128维;

upright:当特征点方向不改变时,在描述特征点时可不计算特征点主方向;

SURF 特征匹配代码与 SIFT 基本一致,如下:

 1 cv::Mat img1 = cv::imread("a.jpg", cv::IMREAD_GRAYSCALE);
2 cv::Mat img2 = cv::imread("b.jpg", cv::IMREAD_GRAYSCALE);
3
4 cv::SurfFeatureDetector detector(2000);
5 std::vector<cv::KeyPoint> keypoints1, keypoints2;
6 cv::Mat descriptors1, descriptors2;
7 detector.operator()(img1, cv::noArray(), keypoints1, descriptors1);
8 detector.operator()(img2, cv::noArray(), keypoints2, descriptors2);
9
10 cv::BFMatcher matcher(cv::NORM_L2);
11 std::vector<DMatch> matches;
12 matcher.match(descriptors1, descriptors2, matches);
13
14 cv::Mat img_matches;
15 cv::drawMatches(img1, keypoints1, img2, keypoints2, matches, img_matches);
16 cv::imwrite("c.jpg", img_matches);
17
18 double min_dist = 100;
19
20 for (int i = 0; i < matches.size(); i++)
21 {
22 double dist = matches[i].distance;
23 if (dist < min_dist) min_dist = dist;
24 }
25
26
27 // Draw only "good" matches (i.e. whose distance is less than 2*min_dist,
28 // or a small arbitary value ( 0.02 )
29 std::vector< DMatch > good_matches;
30 for (int i = 0; i < matches.size(); i++)
31 {
32 if (matches[i].distance <= max(2 * min_dist, 0.02))
33 {
34 good_matches.push_back(matches[i]);
35 }
36 }
37
38 cv::drawMatches(img1, keypoints1, img2, keypoints2, good_matches, img_matches);
39 cv::imwrite("d.jpg", img_matches);

参考资料 SURF: Speeded Up Robust Features Herbert Bay & Tinne Tuylelaars & Luc Van Gool

Learning OpenCV 3   Adrian Kaehler & Gary Bradski

opencv笔记--SURF的更多相关文章

  1. opencv笔记6:角点检测

    time:2015年10月09日 星期五 23时11分58秒 # opencv笔记6:角点检测 update:从角点检测,学习图像的特征,这是后续图像跟踪.图像匹配的基础. 角点检测是什么鬼?前面一篇 ...

  2. OpenCV笔记大集锦(转载)

    整理了我所了解的有关OpenCV的学习笔记.原理分析.使用例程等相关的博文.排序不分先后,随机整理的.如果有好的资源,也欢迎介绍和分享. 1:OpenCV学习笔记 作者:CSDN数量:55篇博文网址: ...

  3. opencv笔记5:频域和空域的一点理解

    time:2015年10月06日 星期二 12时14分51秒 # opencv笔记5:频域和空域的一点理解 空间域和频率域 傅立叶变换是f(t)乘以正弦项的展开,正弦项的频率由u(其实是miu)的值决 ...

  4. opencv笔记4:模板运算和常见滤波操作

    time:2015年10月04日 星期日 00时00分27秒 # opencv笔记4:模板运算和常见滤波操作 这一篇主要是学习模板运算,了解各种模板运算的运算过程和分类,理论方面主要参考<图像工 ...

  5. opencv笔记3:trackbar简单使用

    time:2015年 10月 03日 星期六 13:54:17 CST # opencv笔记3:trackbar简单使用 当需要测试某变量的一系列取值取值会产生什么结果时,适合用trackbar.看起 ...

  6. opencv笔记2:图像ROI

    time:2015年 10月 03日 星期六 12:03:45 CST # opencv笔记2:图像ROI ROI ROI意思是Region Of Interests,感兴趣区域,是一个图中的一个子区 ...

  7. opencv笔记1:opencv的基本模块,以及环境搭建

    opencv笔记1:opencv的基本模块,以及环境搭建 安装系统 使用fedora22-workstation-x86_64 安装opencv sudo dnf install opencv-dev ...

  8. opencv提取surf特征点出现的错误

    opencv实现surf特征的提取.本来是一个非常easy的代码,结果我执行时却出现了各种错误,以下来谈谈我出现的错误及问题的解决过程. 首先,我把提取surf特征的过程整合成了一个函数,我单独建立一 ...

  9. OpenCV图像Surf与flann特征点(转载)

    Surf(Speed Up Robust Feature) Surf算法的原理                                                             ...

随机推荐

  1. java 使用 ArrayList 排序【包括数字和字符串】

    1.数字排序 /** * 数字排序 */ @Test public void t2() { List<Integer> list = new ArrayList<>(); li ...

  2. Java实现163邮箱发送邮件到QQ邮箱

    注:图片如果损坏,点击文章链接:https://www.toutiao.com/i6812973124141711876/ 先创建一个maven的普通项目 添加依赖,附在文档末尾 其中几个注意的地方 ...

  3. vue 因为使用scope后选择器和标签出现[data-v

    使用scope的以后出现datd-v,例如: <div data-v-2311c06a class="button-warp"> <button data-v-2 ...

  4. 基于windows环境VsCode的ESP32开发环境搭建

    1. 基于windows环境VsCode的ESP32开发环境搭建,网上有各类教程,但是我实测却不行. 例如我在vscode内安装的乐鑫插件,扩展配置项是下图这样: 而百度的各类博文却都是这样: 经过网 ...

  5. Kube-OVN 0.6.0 发布,支持 IPv6、流量镜像及更多功能

    Kube-OVN 是一个基于 OVN 的 Kubernetes 开源网络系统. 本次更新主要包含了以下内容: 1. 支持流量镜像 在安装 Kube-OVN 时可以开启 mirror 选项,会自动在每个 ...

  6. antd的table组件设置Column的width列宽度不生效问题

    超长连续字段(长数字和长单词) 破坏表格布局的问题(即使你指定了列的宽度也会被挤开),之前组件内默认加过 word-break: break-word; 去纠正此类布局,又会引起其他的问题. 所以最好 ...

  7. linux服务器之间传输文件的四种方式

    linux文件传输在内网渗透中至关重要,所以我在此总结一下几种Linux服务器之间传输文件的四种方式 1. scp [优点]简单方便,安全可靠:支持限速参数[缺点]不支持排除目录[用法]scp就是se ...

  8. STC8H开发(六): SPI驱动ADXL345三轴加速度检测模块

    目录 STC8H开发(一): 在Keil5中配置和使用FwLib_STC8封装库(图文详解) STC8H开发(二): 在Linux VSCode中配置和使用FwLib_STC8封装库(图文详解) ST ...

  9. 实习之bii--源码安装bind9

    刚学习linux时安装过fctix小企鹅输入法,那个比这个安装还要复杂,不过在这里也写一写,还是用的./configure make makeinstall这套命令.不像fctix有些高版本开始用cm ...

  10. 绑定方法和隐藏属性之property装饰器

    目录 一:绑定方法 1.绑定给对象的方法 2.绑定给类的方法 3.非绑定方法之静态方法 二,隐藏属性 1.如何隐藏属性 三,property 装饰器 一:绑定方法 1.绑定给对象的方法 class P ...