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

相关文章

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

qtcreater配置opencv遇到的坑及实践记录

《qtcreater配置opencv遇到的坑及实践记录》我配置opencv不管是按照网上的教程还是deepseek发现都有些问题,下面是我的配置方法以及实践成功的心得,感兴趣的朋友跟随小编一起看看吧... 目录电脑环境下载环境变量配置qmake加入外部库测试配置我配置opencv不管是按照网上的教程还是de

Java计算经纬度距离的示例代码

《Java计算经纬度距离的示例代码》在Java中计算两个经纬度之间的距离,可以使用多种方法(代码示例均返回米为单位),文中整理了常用的5种方法,感兴趣的小伙伴可以了解一下... 目录1. Haversine公式(中等精度,推荐通用场景)2. 球面余弦定理(简单但精度较低)3. Vincenty公式(高精度,

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti