OpenCV中SGBM中BT代价计算

2023-10-07 04:10
文章标签 计算 opencv 代价 sgbm bt

本文主要是介绍OpenCV中SGBM中BT代价计算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

OpenCV中SGBM中BT代价计算

  • AD算法
  • BT算法

AD算法

在对BT算法说明前,先对AD(Absolute differences)算法进行简单说明。
在这里插入图片描述
如上图所示, I R ( x , y ) I_R(x,y) IR(x,y) I T ( x , y ) I_T(x,y) IT(x,y)分别表示左图和右图中的像素 ( x , y ) (x,y) (x,y)处的值,那么左图中像素 I R ( x , y ) I_R(x,y) IR(x,y)与右图中视差为 d d d的像素的AD代价值如下式所示:
c ( x , y , d ) = ∣ I R ( x , y ) − I T ( x + d , y ) ∣ c(x,y,d)=|I_R(x,y)-I_T(x+d,y)| c(x,y,d)=IR(x,y)IT(x+d,y)

BT算法

BT的代价也是像素灰度值差值的绝对值,不同之处在于BT利用了亚像素的灰度信息。
在这里插入图片描述
如图所示,首先计算左图中像素 ( x R − 0.5 , y ) (x_R -0.5,y) (xR0.5,y) ( x R + 0.5 , y ) (x_R+0.5 ,y) (xR+0.5,y)之间亚像素位置 ( x R + x , y ) (x_R+x,y) (xR+x,y)的灰度值 I R ~ ( x R , y ) \widetilde{I_R}(x_R,y) IR (xR,y),然后计算右图中像素 ( x R + d − 0.5 , y ) (x_R +d-0.5,y) (xR+d0.5,y) ( x R + d + 0.5 , y ) (x_R +d+0.5,y) (xR+d+0.5,y)之间亚像素位置 ( x R + d + x , y ) (x_R+d+x,y) (xR+d+x,y)的灰度值 I T ~ ( x R + d , y ) \widetilde{I_T}(x_R+d,y) IT (xR+d,y)
分别计算两个代价:
c o s 1 = min ⁡ x R − 1 2 ≤ x R + 1 2 ∣ I R ( x R , y ) − I T ~ ( x R + d , y ) ∣ cos_1=\min_{x_R-\frac{1}{2}\le x_R+\frac{1}{2} }|I_R(x_R,y)-\widetilde{I_T}(x_R+d,y)| cos1=xR21xR+21minIR(xR,y)IT (xR+d,y) c o s 2 = min ⁡ x R − 1 2 ≤ x R + 1 2 ∣ I T ( x R + d , y ) − I R ~ ( x R , y ) ∣ cos_2=\min_{x_R-\frac{1}{2}\le x_R+\frac{1}{2} }|I_T(x_R+d,y)-\widetilde{I_R}(x_R,y)| cos2=xR21xR+21minIT(xR+d,y)IR (xR,y)最终的代价为两个代价的最小值:
c o s = m i n ( c o s 1 , c o s 2 ) cos = min(cos_1,cos_2) cos=min(cos1,cos2)
注意:Opencv源码中,并没有计算太多亚像素的灰度值,只是取了两个像素中间点的亚像素的灰度值。

 for( int d = minD; d < maxD; d++ ){int v = prow2[width-x-1 + d];// 之前右图是逆序存储,现在需要逆序取出,并加上视差值int v0 = buffer[width-x-1 + d];// 最小值int v1 = buffer[width-x-1 + d + width2];// 最大值int c0 = std::max(0, u - v1); c0 = std::max(c0, v0 - u);int c1 = std::max(0, v - u1); c1 = std::max(c1, u0 - v);// cost计算。与原论文不同的是,opencv的B.T. metrics包含了两个部分,// 一部分为prow1和prow2第一行所存储的左右图的sobel滤波结果的B.T. metrics,// 一部分为prow1和prow2第二行所存储的左右图的灰度值的B.T. metricscost[x*D + d] = (CostType)(cost[x*D+d] + (std::min(c0, c1) >> diff_scale));}

这篇关于OpenCV中SGBM中BT代价计算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/155947

相关文章

在PyCharm中安装PyTorch、torchvision和OpenCV详解

《在PyCharm中安装PyTorch、torchvision和OpenCV详解》:本文主要介绍在PyCharm中安装PyTorch、torchvision和OpenCV方式,具有很好的参考价值,... 目录PyCharm安装PyTorch、torchvision和OpenCV安装python安装PyTor

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

OpenCV图像形态学的实现

《OpenCV图像形态学的实现》本文主要介绍了OpenCV图像形态学的实现,包括腐蚀、膨胀、开运算、闭运算、梯度运算、顶帽运算和黑帽运算,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起... 目录一、图像形态学简介二、腐蚀(Erosion)1. 原理2. OpenCV 实现三、膨胀China编程(

opencv图像处理之指纹验证的实现

《opencv图像处理之指纹验证的实现》本文主要介绍了opencv图像处理之指纹验证的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录一、简介二、具体案例实现1. 图像显示函数2. 指纹验证函数3. 主函数4、运行结果三、总结一、

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

Java中的Opencv简介与开发环境部署方法

《Java中的Opencv简介与开发环境部署方法》OpenCV是一个开源的计算机视觉和图像处理库,提供了丰富的图像处理算法和工具,它支持多种图像处理和计算机视觉算法,可以用于物体识别与跟踪、图像分割与... 目录1.Opencv简介Opencv的应用2.Java使用OpenCV进行图像操作opencv安装j

opencv实现像素统计的示例代码

《opencv实现像素统计的示例代码》本文介绍了OpenCV中统计图像像素信息的常用方法和函数,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 统计像素值的基本信息2. 统计像素值的直方图3. 统计像素值的总和4. 统计非零像素的数量

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2