技术标签: OpenCV OpenCV学习教程 Fast ORB
一般特征说的意思是关键点+描述子;
原理: FAST是一种角点, 主要检测局部像素灰度变换明显
的地方。
核心思想: 如果一个像素与邻域的像素差别较大,那么它更可能是角点。
优势: 由于只需要比较像素的亮度大小,所以速度十分快捷。
检测过程
1.在图像中选取一点像素p,假设它的亮度为Ip;
2.设置一个亮度阈值T;
3.以像素p为中心,选取半径为3的圆上的上16个像素点;
4.假如选取的圆上有连续的N个点的亮度大于 (Ip+T) 或 (Ip-T), 那么像素p就被人误是特征点;
5.循环以上四步, 对每一个像素都进行相同的操作;
ps: 在这里,N一般取12, 即算法叫做Fast-12, 同理有Fast-9. Fast-11;
在Fast-12中有一项预测试操作,以快速排除绝大多数不是角点的像素。该操作为: 对于每一个像素,直接检测邻域上的第1,5,9,13个像素点的亮度,只有当这四个像素中有3个满足上述步骤4的条件时,才将当前像素点作为候选点进行之后的操作,否则,直接排除
非极大值抑制
需要对特征点计算FAST得分值s,计算方式如下:
1.计算以某个特征点p为中心的邻域内(3x3或5x5等), 有多少个特征点;
2.计算每个特征点的得分值s = 所有特征点与中心像素点的差值的绝对值总和,若q是邻域内所有特征点中响应值最大的,则保留; 否则,抑制。
3.若邻域内只有一个特征点,则该特征点保留;
假设P,Q两个点相邻,分别计算两个点与其周围的16个像素点之间的差分和为V,去除V值较小的点,即把非最大的角点抑制掉。
Fast角点的缺陷
1.它提取角点的数量大,且数目不确定;
2.Fast角点不具有方向和尺度信息(取固定半径为3的圆)
OpenCV使用Fast检测
#include <opencv2/opencv.hpp>
cv::FAST(img, kpts, 75);
cv::Mat imgKpts;
cv::drawKeypoints(img, kpts, imgKpts, cv::Scalar::all(-1), cv::DrawMatchesFlags::DEFAULT);
cv::imshow("kerpoints", imgKpts);
cv::waitKey(2);
ORB算法效率比sift高两个数量级, 在计算速度上
, ORB是sift的100倍, ORB是surf的10倍。就目前来说,ORB算法是综合性能在各种测评离相较于其他特征提取算法是最好的!
ORB特征实质是一种改进的Fast角点, 改进的地方主要有以下两点,分别对关键点和描述子进行了改进:
特征描述子应该具有特性:对光照不敏感(亮度), 具有尺度一致性(大小), 旋转一致性(角度)等
ps:ORB算法本身没有解决ORB的尺度一致性问题,而是我们在实现过程中,借助某些技术手段(如构建图像金字塔),来改善这方面的性能。
在ORB中的尺度不变性可由构建图像金字塔解决,旋转不变型可由灰度质心法来实现
关键点: Fast角点改进
ORB在原来的Fast角点的基础上改进,第一指定提取一定数量的角点, 第二分别对Fast角点计算Harris响应值
, 然后选取前N个具有最大响应值的角点作为最终的角点集合。
灰度质心法
所谓的质心是指; 以图像块灰度值作为权重的中心,在这里每个像素的像素值就代表其质量的大小。
1.定义一个小的图像块, 并定义图像块的矩为m;
m p q = ∑ x , y x p y q I ( x , y ) m_{p q}=\sum_{x, y} x^{p} y^{q} I(x, y) mpq=∑x,yxpyqI(x,y)
2.通过图像矩就可以计算图像的质心C;
C = ( m 10 m 00 , m 01 m 00 ) C=\left(\frac{m_{10}}{m_{00}}, \frac{m_{01}}{m_{00}}\right) C=(m00m10,m00m01)
3.可以得到特征点的方向: 质心与几何中心O的向量OC;
θ = atan 2 ( m 01 , m 10 ) \theta=\operatorname{atan} 2\left(m_{01}, m_{10}\right) θ=atan2(m01,m10)
在这里稍微拓展一下,这个地方很多人都简单的略过去了,里面的原理可能还是懵懵懂懂,什么是图像的矩? 什么是质心?图像的质心为什么是这么算?
实质:就是以中心点为核心与其他所有点的差值的k次方, 再求平均值;
质心相对于质点系中各质点的相对位置与坐标系的选择无关。质点系的质心仅与各质点的质量大小和分布的相对位置有关。
描述子:BRIEF描述子改进
原始的BRIEF描述子 :在一个特征点的邻域选择n对像素点(p,q),比较其灰度值大小,如果I§>I(q),则令其对应的值为1,否则为0,这样对n对像素比较之后,就形成一个长度为n的二进制向量。一般一般n取128、256或512。
选择n对像素点的方法:随机选取或均匀采样等多种方式;
**改进的BRIEF描述子—steered BRIEF:**加入了旋转不变性。在关键点的改进中,使得关键点有了方向,根据此方向,可以获取旋转后的描述子信息,即描述子具有了旋转不变性。
OpenCV使用ORB
#include <opencv2/opencv.hpp>
cv::Ptr<cv::ORB> orb = cv::ORB::create();
orb->detect ( img_1,keypoints_1 );
orb->compute ( img_1, keypoints_1, descriptors_1 );
到目前为止,OpenCV的基础学习已经更新到了十四讲, 这算是最后一讲了(机器学习部分不算在这里),后面的内容主要从以下几个方面开始:
前面所讲内容中需要深入补充的
项目使用过程中所涉及到的图像处理算法
机器学习算法(可能不放在这里,也有可能放在这里)
LaTeX复杂表格制作常用LaTeX表格主要有三个:tabular最基础的表格制作方式,是table的组件,缺点是无法对表格进行排序,如:“表1”。table内含tabular,可以对表格进行计算机自动排序。longtable需要导入longtable宏包,解决表格太大,显示不全的问题。用法与table一致。tabular 1. 内容:列与列之间用“&”隔开,行与行之间用“\\”表示,位于每一行的最后; 2. 对齐方式:左对齐“l”,居中对齐“c”,右对齐“r”,
访问属性名字属性获取:地址属性获取: 访问方法调用值栈中对象的普通方法: 访问静态属性和方法调用Action中的静态方法:调用JDK中的类的静态方法:调用JDK中的类的静态方法(同上):调用JDK中的类的静态方法:调用普通类中的静态属性: 访问构造方法调用普通类的构造方法:
纸张 2D 组件用于添加(或修改)2D Sprites 或 Flipbooks 以作为 Actor 的子对象。Paper Sprite Component (Paper Sprite 组件)PaperSpriteComponent 用于处理 UPaperSprite 资产的单个实例的渲染和碰撞。 当您将精灵资产从 Content Browser 拖放到 Blueprint 时,将创建该
首先 监听的信息Listening Endpoints Summary... (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=LISTENER))) (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=10.100.21.205)(PORT=1521))) (DESCRIPTION=(ADDRESS=(PROTOCOL=t
idea报错Module Project1 must not contain source root “…\Project1\src”. The root already belongs to m选择你的根模块选择modules,选择根模块,删除add content root 下面不直接属于根模块的目录即可。...
IntelliJ Idea 常用快捷键列表:Ctrl+Shift + Enter,语句完成“!”,否定完成,输入表达式时按 “!”键Ctrl+E,最近的文件Ctrl+Shift+E,最近更改的文件Shift+Click,可以关闭文件Ctrl+[ OR ],可以跑到大括号的开头与结尾Ctrl+F12,可以显示当前文件的结构Ctrl+F7,可以查询当前元素在当前文件中的引用,然后按 ...
tb的启动 -- 如这篇文章看完之后,还是不能解答你心中的疑惑;关注我 后续文章肯定会为你解答
CSS1.基本介绍1.基本介绍* 1.概念: Cascading Style Sheets 层叠样式表 * 层叠:多个样式可以作用在同一个html的元素上,同时生效2. 好处: 1. 功能强大 2. 将内容展示和样式控制分离 * 降低耦合度。解耦 * 让分工协作更容易 * 提高开发效率...
1、注册广播有哪几种方式,有什么区别1-1.常驻型广播 注册方式就是在应用程序的AndroidManifast.xml中进行注册,这注册方式通常又被称作静态注册action android:name="android.provider.Telephony.SMS_RECEIVED"/>1-2、非常驻形广播··非常驻型广播,当应用程序结束了,广播自然就没有了, 比如在 Activ...
#include<stdio.h>#define M 100//递归法int Fibo1(int n){ if(n==1||n==2){ return 1;//递归终止条件} else { return Fibo1(n-1)+Fibo1(n-2);//递归 }}//非递归法in...
一、IOC基本注入和集合注入实体类Bean--配置文件(applicationContext)--测试类(Test)1.1 实体Bean:属性+getter()方法+setter()方法public class MyBean {private String url;private String name;private String pwd;private int
InnoDB存储引擎是多线程的模型,因此其后台有多个不同的后台线程,负责处理不同的任务。主要分为:Master Thread、IO Thread、Purge Thread和Page Cleaner Thread。Master Thread通过名字就可以看出,Master Thread是非常重要的线程,维护着InnoDB存储引擎中的大多数的操作,因为此线程的效率也直接影响着InnoDB的整体性能。所以,不同InnoDB版本的改进也主要针对此线程的功能进行的。InnoDB1.0.x版本之前 Master T