- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我是 opencv 新手,正在尝试实现两个图像之间的图像匹配。为此,我试图了解特征描述符、描述符提取器和描述符匹配器之间的区别。我遇到了很多术语,并试图在 opencv 文档网站上阅读它们,但我似乎无法理解这些概念。我理解了这里的基本区别。 Difference between Feature Detection and Descriptor Extraction
但我在研究该主题时遇到了以下术语:
FAST, GFTT, SIFT, SURF, MSER, STAR, ORB, BRISK, FREAK, BRIEF
我了解 FAST、SIFT、SURF 的工作原理,但似乎无法弄清楚以上哪些只是检测器,哪些是提取器。
然后是匹配器。
FlannBased, BruteForce, knnMatch and probably some others.
经过阅读,我认为某些匹配器只能与某些提取器一起使用,如此处所述。 How Does OpenCV ORB Feature Detector Work?给出的分类很清楚,但仅适用于少数提取器,我不明白 float 和 uchar 之间的区别。
所以基本上,有人可以请吗
我知道它要求很多,但我将不胜感激。谢谢。
最佳答案
I understand how FAST, SIFT, SURF work but can't seem to figure out which ones of the above are only detectors and which are extractors.
Basically, from that list of feature detectors/extractors (link to articles: FAST , GFTT , SIFT , SURF , MSER , STAR , ORB , BRISK , FREAK , BRIEF ), some of them are only feature detectors ( FAST、GFTT)其他都是特征检测器和描述符提取器(SIFT、SURF、ORB、FREAK)。
如果我没记错的话,BRIEF 只是一个描述符提取器,所以它需要通过 FAST 或 ORB 等其他算法检测到的特征。
要确定哪个是哪个,您必须浏览与算法相关的文章或浏览 opencv 文档以查看哪个是为 FeatureDetector
类实现的,或者哪个是为 DescriptorExtractor 实现的
类。
Q1: classify the types of detectors, extractors and matchers based on float and uchar, as mentioned, or some other type of classification?
Q2: explain the difference between the float and uchar classification or whichever classification is being used?
关于问题1和2,将它们分类为float和uchar,link you already posted是我所知道的最好的引用,也许有人可以完成它。
Q3: mention how to initialize (code) various types of detectors, extractors and matchers?
回答问题3,OpenCV 使代码使用的各种类型完全相同——主要是你必须选择一个特征检测器。大部分区别在于选择匹配器的类型,您已经提到了 OpenCV 拥有的 3 个匹配器。最好的办法是阅读文档 code samples 和相关的 Stack Overflow 问题。此外,一些博客文章是很好的信息来源,例如 series of feature detector benchmarks by Ievgen Khvedchenia(该博客不再可用,因此我不得不从其 google 缓存创建原始文本拷贝)。
Matchers 用于查找一个描述符是否与列表中的另一个描述符相似。您可以将您的查询描述符与列表中的所有其他描述符(BruteForce)进行比较,也可以使用更好的启发式方法(FlannBased, knnMatch)。问题是启发式方法不适用于所有类型的描述符。例如,FlannBased 实现仅适用于 float
描述符,但不适用于 uchar
(但从 2.4.0 开始,带有 LSH 索引的 FlannBased 可以应用于 uchar 描述符) .
引用 this App-Solut blog post 关于 DescriptorMatcher
类型:
The DescriptorMatcher comes in the varieties “FlannBased”, “BruteForceMatcher”, “BruteForce-L1” and “BruteForce-HammingLUT”. The “FlannBased” matcher uses the flann (fast library for approximate nearest neighbors) library under the hood to perform faster but approximate matching. The “BruteForce-*” versions exhaustively searche the dictionary to find the closest match for an image feature to a word in the dictionary.
一些比较流行的组合是:
特征检测器/描述符提取器/匹配器类型
(FAST, SURF)/SURF/FlannBased
(FAST, SIFT)/SIFT/FlannBased
(FAST, ORB)/ORB/Bruteforce
(FAST, ORB)/Brief/Bruteforce
(FAST, SURF)/FREAK/Bruteforce
您可能还注意到,特征检测器有一些适配器(动态、金字塔、网格)。 The App-Solut blog post 很好地总结了它们的用途:
(...) and there are also a couple of adapters one can use to change the behavior of the key point detectors. For example the
Dynamic
adapter which adjusts a detector type specific detection threshold until enough key-points are found in an image or thePyramid
adapter which constructs a Gaussian pyramid to detect points on multiple scales. ThePyramid
adapter is useful for feature descriptors which are not scale invariant.
进一步阅读:
This blog post by Yu Lu 对 SIFT、FAST、SURF、BRIEF、ORB、BRISK 和 FREAK 做了非常好的总结描述。
这些 series of posts by Gil Levi 还对其中几种算法(BRIEF、ORB、BRISK 和 FREAK)做了详细的总结。
关于c++ - 检测器、提取器和匹配器的分类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14808429/
我正在做一个业余爱好项目,使用 Ruby、PHP 或 Java 来抓取 ASP.net 网站的内容。例如,如果网站 url“www.myaspnet.com/home.aspx”。我想从 home.a
如果我有这些字符串: mystrings <- c("X2/D2/F4", "X10/D9/F4", "X3/D22/F4",
我有以下数据集 > head(names$SAMPLE_ID) [1] "Bacteria|Proteobacteria|Gammaproteobacteria|Pseudomonadales|Mor
设置: 3个域类A,B和C。A和B在插件中。 C在依赖于此插件的应用程序中。 class A{ B b static mapping = { b fetch: 'joi
我不知道如何提取 XML 文件中的开始标记元素名称。我很接近〜意味着没有错误,我正在获取标签名称,但我正在获取标签名称加上信息。我得到的是: {http://www.publishing.org}au
我有一个字符串 x <- "Name of the Student? Michael Sneider" 我想从中提取“Michael Sneider”。 我用过: str_extract_all(x,
我有一个如下所示的文本文件: [* content I want *] [ more content ] 我想读取该文件并能够提取我想要的内容。我能做的最好的事情如下,但它会返回 [更多内容] 请注意
假设我有一个项目集合 $collection = array( 'item1' => array( 'post' => $post, 'ca
我正在寻找一种过滤文本文件的方法。我有许多文件夹名称,其中包含许多文本文件,文本文件有几个没有人员,每个人员有 10 个群集/组(我在这里只显示了 3 个)。但是每个组/簇可能包含几个原语(我在这里展
我已经编写了一个从某个网页中提取网址的代码,我面临的问题是它不会以网页上相同的方式提取网址,我的意思是如果该网址位于某些网页中法语,它不会按原样提取它。我该如何解决这个问题? import reque
如何在 C# 中提取 ZipFile?(ZipFile 是包含文件和目录) 最佳答案 为此使用工具。类似于 SharpZip .据我所知 - .NET 不支持开箱即用的 ZIP 文件。 来自 here
我有一个表达: [training_width]:lofmimics 我要提取[]之间的内容,在上面的例子中我要 training_width 我试过以下方法: QRegularExpression
我正在尝试创建一个 Bash 脚本,该脚本将从命令行给出的最后一个参数提取到一个变量中以供其他地方使用。这是我正在处理的脚本: #!/bin/bash # compact - archive and
我正在寻找一个 JavaScript 函数/正则表达式来从 URI 中提取 *.com...(在客户端完成) 它应该适用于以下情况: siphone.com = siphone.com qwr.sip
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 8 年前。 Improve this qu
编辑:添加了实际的 JSON 对象和代码以供审查 我有这种格式的 JSON(只是这种层次结构,假设 JSON 正常工作) {u'kind': u'calendar#events', u'default
我已经编写了代码来使用 BeautifulSoup 提取一本书的 url 和标题来自页面。 但它并没有在 > 之间提取惊人的 super 科学故事 1930 年 4 月这本书的名字。和 标签。 如何提
使用 Java,我想提取美元符号 $ 之间的单词。 例如: String = " this is first attribute $color$. this is the second attribu
您好,我正在尝试找到一种方法来确定字符串中的常量,然后提取该常量左侧的一定数量的字符。 例如-我有一个 .txt 文件,在那个文件的某处有数字 00nnn 数字的例子是 00234 00765 ...
php读取zip文件(删除文件,提取文件,增加文件)实例 从zip压缩文件中提取文件 复制代码 代码如下: <?php /* php 从zip压缩文件
我是一名优秀的程序员,十分优秀!