在过去的一段时间内,我也实现了几篇关于立体匹配的学术论文,程序最终的显示效果却远不如论文中呈现的效果,可是自己编写的程序是严格按照论文中的步骤和参数设置的,为什么?经过上网查找资料和阅读论文,发现了其中一个原因。如果程序真没问题,可能是论文中没有介绍额外的处理步骤,即一些后续处理步骤(post-processing),比如左右一致性检测(left-right consistency,LRC)。
遮挡介绍:顾名思义是指一些点只出现在一幅图像中,而在另一幅图像中看不到。在立体匹配算法中如果不针对遮挡区域做一些特殊处理是不可能通过单幅图像提供的有限信息得到遮挡点的正确视差的。遮挡点通常是一块连续的区域。
LRC:作用是实现遮挡检测,得到左图对应的遮挡图像。具体做法:根据左右两幅输入图像,分别得到左右两幅视差图。对于左图中的一个点p,求得的视差值是d1,那么p在右图中的对应点应该是(p-d1),其视差值记作d2.若|d1-d2|>threshold,p标记为遮挡点。