概述


原文:《An efficient and robust line segment matching approach based on LBD descriptor and pairwise geometric consistency》

上一步我们进行了线特征的提取和描述,接下来我们进行线特征的匹配。在此之前我们先通过预处理将一些明显无法匹配的特征给消除,以降低图匹配问题的维度。
该部分图匹配算法分为三步:

  1. 查找候选匹配对
  2. 构建关系图
  3. 生成最终匹配结果

1. 查找候选匹配对


匹配的双方,我们分别称为参考图像和查询图像,检测出双方的LineVecs之后,我们要检测他们的一元几何属性局部外观相似度,若未通过测试,那么认为他们是不匹配的。这样做可以大大减小图优化匹配的问题维度,使得我们后期匹配的速度更快。

1.1.一元几何属性

线段的一元几何属性就是LineVecs的方向,在同一个LineVec中的线具有相同的方向,并且每一个LineVec拥有唯一的方向。但是两张图中的LineVecs的方向有可能是不可靠的,图像有可能会有任意角度的旋转,对于这点,我们利用图像对之间存在的近似全局旋转角,可以减少候选匹配对的数目。

构建旋转

和其他文章中使用对应匹配来进行图像旋转不同,LBD的Matching中通过计算两个图像的LineVecs方向直方图,得到规范化直方图,h代表直方图。我们改变的角度,通过公式寻找一个全局近似旋转角

而全局旋转变换不一定总是好的,所以我们也需要去检查估计旋转角是不是真的。实际上如果透视变换可以通过旋转来近似,那么直方图之差比较小。这代表了在进行了旋转之后,两个图像之间的相似程度。

上图就显示出了两张图之间的直方图差距,通过旋转我们可以得出两张图之间相似度很高。上图中的预估角度是0.349,偏移是0.243

但是如果图像中提取的线重复度很低的话,这种直方图方法就有可能提取出错误的旋转角度。为了解决这个问题,对于在方向直方图上落入相同区间bins的线段,将他们的长度累积起来。那么我们就可以得到一个长度向量,其第i个元素就是方向直方图中第i个bin中的线段累计长度。

我们设定最小偏移直方图小于阈值th,并且最小偏移长度向量距离小于阈值tl时,我们接受我们所估计的全局旋转角。一旦全局旋转角被接受,就会有一对LineVecs被匹配。但是如果这对LineVecs的方向角度和估计的全局旋转角之差超过阈值,那么我们认为他们是不能够匹配的。如果两个图片之间没有可以接受的旋转角度,那么我们只测试他们的外观相似性。

1.2. 局部外观相似性

我们用直线描述符之间的距离(lost)来度量局部外观相似度。
对于LineVec中的每个线段,我们都从提取出线的尺度层中生成一个LBD描述子向量V。当我们对一幅图像中提取出来的两组LineVec进行匹配,要去评估参考LineVec和测试LineVec中所有描述子之间的距离,并且用最小的描述子距离去测量LineVec外观相似度s。如果 s > ts s大于局部外观不相似容忍度,那么相应两个LineVecs将不会再进一步考虑。

在检查了LineVecs的一元几何属性和局部外观相似性之后,通过了这些测试的直线对被当做候选匹配。我们在上面的测试中,应当选取一组松散阈值,其中经验值是 tθ=π/4 ts=0.35。候选匹配的数量比实际匹配的数量要大很多,因为我们不能仅仅按照刚才两个属性来确定最终的匹配结果,当然我们上面的工作也是大大减小了图形匹配的问题维度的。

2. 构建关系图

对于上面得到一组候选匹配项,我们要构建一个关系图
其中关系图里的节点代表潜在的对应点
节点之间的连接的权重代表对应点之间的一致性

拿到了k对对应关系,我们用一个大小为k*k的邻接矩阵A来表示关系图,其中第i行第j列的元素值是候选LineVec匹配对的一致性得分。其中分别是引用图和查询图的LineVecs变量,上面的一致性得分是通过候选匹配对的成对几何属性外观相似度计算的来的。

成对几何属性


我们选择两条线分别是,他们代表了这两个LineVecs之间的最小描述子距离,并在原图中定位他们的端点位置。然后我们用他们的交点比率,投影比率和相对角度来描述的几何属性,就如上图所描述的那样。其中的两个值的计算方法如下:

Ij和Pj的值可以用相同的方法求解得到,相对角度可以直接用线方向求得。这三个量对平移旋转缩放都是不变的。

外观相似度

之前,我们使用LBD描述向量来表示线的局部外观。
假设描述子与r图(参考图)和q图(查询图)的LineVecs之间的最小距离是,同理对。我们可以得到两组成对几何属性和局部外观,分别是

计算一致性得分Aij:



其中是几何相似性;是局部外观相似性;是条件。最后一个代表所有在内的元素都不能大于1。
接下来我们设。计算完他们的一致性得分之后,我们便获得了邻接矩阵A。

3. 生成最终匹配结果

到这一步之后,匹配的问题最终就变成了,寻找匹配簇LM,该匹配簇可以最大化总的一致性分数,以至于可以满足映射约束。我们使用一个指标向量来表示这个簇,否则为0,因此这个问题被表示为:

其中x受制于映射约束。一般来说用二次规划来解决这个问题太耗费资源,我们采用谱图技术,对x放款映射约束和积分约束,使得他的元素可以采集实际值在[0,1]区间里。
通过Raleigh比率定理,可以最大化的x*是A的主特征向量。它仍然是使用映射约束二值化特征向量和获得最优解的一个强大近似。

以下是算法细节:

  1. 通过EDLine算法从参考图和查询图内提取LineVecs,以从两幅图中分别获得两组LineVecs
  2. 利用两组LineVecs的方向直方图估计图像对的全局旋转角
  3. 计算两组LineVecs的LBD描述子
  4. 通过检查描述子的一元几何属性和局部外观,生成一组候选匹配对
  5. 根据候选匹配对中一致性分数,构建k*k大小的邻接矩阵
  6. 通过使用ARPACK库,得到邻接矩阵A的主特征向量x*
  7. 初始化匹配结果
  8. 查找,如果x*(a)=0,那么停止查找返回匹配结果LM,否则设且x*(a)=0。
  9. 检查CM中所有的候选者,如果冲突,那么设
  10. 如果CM是空的,那么返回LM,否则返回到步骤8。

最后一行的线段匹配可以从LineVecs LM的匹配结果直接检索。注意,在LineVec的线位于图像的同一区域,并且具有同一方向,因此,每对linevec的匹配,线段匹配有一对就足够检索了。

参考文档:
http://www.cnblogs.com/Jessica-jie/p/7545554.html

代码:
https://github.com/chishuideyu/LBD_and_LineMatching

LBD算法 - Graph matching 图匹配算法分析相关推荐

  1. 多目标跟踪算法中之图匹配——匈牙利算法和KM算法详解

    目录 一.匈牙利算法 1.算法背景及思想 2.最大匹配 3.最优匹配/完美匹配 4.增广路径 5.代码实现 6.匈牙利算法总结 6.1.深度优先 6.2. 广度优先 二.KM算法思想及局限性 代码示例 ...

  2. 图像匹配算法 MAD、SAD、SSD、MSD、NCC、SSDA、SATD,LBD算法

    图像匹配算法分为3类:基于灰度的匹配算法.基于特征的匹配算法.基于关系的匹配算法 (1)基于灰度的模板匹配算法:模板匹配(Blocking Matching)是根据已知模板图像到另一幅图像中寻找与模板 ...

  3. 图匹配(Graph Matching)入门学习笔记——以《Factorized Graph Matching》为例(一)

    这篇文章本身是图匹配经典论文<Factorized Graph Matching>的阅读笔记,后来发现该文介绍并串联了许多图匹配相关的知识,甚至可以看作一个小小的综述性文章,因此就作为图匹 ...

  4. 讲座笔记:图匹配 Graph Matching 问题 | 机器学习组合优化

    讲座信息: 主讲人:严骏驰 上海交通大学 主办单位:运筹OR帷幄 讲座时间:2020年9月9日 讲座地点:线上 讲座链接:https://www.bilibili.com/video/BV1Zf4y1 ...

  5. 一个基于高阶图匹配的多目标跟踪器:Online Multi-Target Tracking with Tensor-Based High-Order Graph Matching

    论文地址:Online Multi-Target Tracking with Tensor-Based High-Order Graph Matching 基于高阶图匹配的多目标跟踪器 一. 摘要 二 ...

  6. 图匹配(Graph Matching)入门学习笔记——以《Factorized Graph Matching》为例(二)

    本文是"图匹配入门学习笔记--以<Factorized Graph Matching>为例"系列的第二篇文章,主要介绍了FGM算法的实现过程,包括图匹配的因式分解形式, ...

  7. 如何找到相似Graph?DeepMind提出超越GNN的图匹配网络

    选自arxiv 作者:Yujia Li.Chenjie Gu.Thomas Dullien等 机器之心编译 参与:李诗萌.路雪 近日,DeepMind 和谷歌联合进行了一项研究,该研究提出了一种执行相 ...

  8. 多目标跟踪数据关联的二部图解:CVPR18多目标跟踪开创性深度端到端二部图匹配佳作《Deep Learning of Graph Matching》读后有感

    多目标跟踪算法的核心以及瓶颈之处,即是在得到两个set的DR(detection response,其中一个前序set可能是tracklets,但也由DR来表征)之后如何实现二部图匹配.传统的Hung ...

  9. C++paranthesis matching括号匹配的算法(附完整源码)

    C++paranthesis matching括号匹配的算法 C++paranthesis matching括号匹配的算法完整源码(定义,实现,main函数测试) C++paranthesis mat ...

最新文章

  1. 【pytorch】pytorch-backward()的理解
  2. 大道至简第一章伪代码读后感
  3. ONAP — CCVPN 跨域 SDN 协同编排
  4. 总结过去10年的程序员生涯,给程序员小弟弟小妹妹们的一些总结性忠告
  5. 区分各浏览器的CSS hack(包括360、搜狗、opera)
  6. python中的所有功能_python – 是否可以列出模块中的所有功能?
  7. MVC中利用ActionFilterAttribute过滤关键字
  8. linux运行jps五行结果,Linux系统性能监控
  9. lock concurrence
  10. JESD204B时钟网络
  11. 常用的Sql命令之造数据
  12. 微信小程序 — 保存文件到本地的两种方式
  13. 3dsMax---椅子
  14. 浏览器访问127.0.0.1已拒绝连接
  15. React高级话题之Refs and the DOM
  16. 手机端搜狗输入法语音转文字的体验报告
  17. 自定义模块:根据光导的导光条件计算光栅周期
  18. 如何将域名地址转换成对应的IP地址?
  19. 如何让win10超时自动锁定屏幕?
  20. python的书哪个好知乎_python书籍推荐 知乎红色有哪些

热门文章

  1. 三首励志诗歌,你我共勉之!
  2. mysql数据库添加用户
  3. xp计算机出厂日期,xp电脑系统时间不对怎么办
  4. 信息学测python知识点(三)顺序结构
  5. WCF 跨域问题解决方案
  6. Nature Communications:主要精神和神经退行性疾病的共同机制
  7. Struts2项目实例
  8. 计算机考试笔试题库,计算机等级考试一级笔试题库及答案
  9. 完成以下程序,并进行调试某班期末考试科目为数学、英语和计算机,有最多不超过30人参加考试。
  10. Cannot insert explicit value for identity column in table xxx when IDENTITY_INSERT is set to OFF