LBD算法 – Graph matching 图匹配算法分析

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

概述


原文:《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方向直方图,得到规范化直方图LBD算法 - Graph matching 图匹配算法分析,h代表直方图。我们改变LBD算法 - Graph matching 图匹配算法分析的角度,通过公式LBD算法 - Graph matching 图匹配算法分析寻找一个全局近似旋转角LBD算法 - Graph matching 图匹配算法分析

而全局旋转变换不一定总是好的,所以我们也需要去检查估计旋转角是不是真的。实际上如果透视变换可以通过旋转来近似,那么直方图之差LBD算法 - Graph matching 图匹配算法分析比较小。这代表了在进行了旋转之后,两个图像之间的相似程度。
这里写图片描述
上图就显示出了两张图之间的直方图差距,通过旋转我们可以得出两张图之间相似度很高。上图中的预估角度LBD算法 - Graph matching 图匹配算法分析是0.349,偏移是0.243

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

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

1.2. 局部外观相似性

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

2. 构建关系图

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

成对几何属性

LBD算法 - Graph matching 图匹配算法分析
我们选择两条线分别是LBD算法 - Graph matching 图匹配算法分析,他们代表了这两个LineVecs之间的最小描述子距离,并在原图中定位他们的端点位置。然后我们用他们的交点比率LBD算法 - Graph matching 图匹配算法分析,投影比率LBD算法 - Graph matching 图匹配算法分析和相对角度LBD算法 - Graph matching 图匹配算法分析来描述LBD算法 - Graph matching 图匹配算法分析的几何属性,就如上图所描述的那样。其中的两个值的计算方法如下:
LBD算法 - Graph matching 图匹配算法分析
Ij和Pj的值可以用相同的方法求解得到,LBD算法 - Graph matching 图匹配算法分析相对角度可以直接用线方向求得。这三个量对平移旋转缩放都是不变的。


外观相似度

计算一致性得分Aij:

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


3. 生成最终匹配结果

到这一步之后,匹配的问题最终就变成了,寻找匹配簇LM,该匹配簇可以最大化总的一致性分数LBD算法 - Graph matching 图匹配算法分析,以至于可以满足映射约束。我们使用一个指标向量来表示这个簇LBD算法 - Graph matching 图匹配算法分析,否则为0,因此这个问题被表示为:
LBD算法 - Graph matching 图匹配算法分析
其中x受制于映射约束。一般来说用二次规划来解决这个问题太耗费资源,我们采用谱图技术,对x放款映射约束和积分约束,使得他的元素可以采集实际值在[0,1]区间里。
通过Raleigh比率定理,可以最大化LBD算法 - Graph matching 图匹配算法分析的x*是A的主特征向量。它仍然是使用映射约束二值化特征向量和获得最优解的一个强大近似。


以下是算法细节:

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/228082.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月16日 下午7:51
下一篇 2026年3月16日 下午7:52


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号