OpenCV相机标定与3D重建(66)对立体匹配生成的视差图(disparity map)进行验证的函数validateDisparity()的使用

server/2025/1/24 12:36:15/
  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

使用左右检查来验证视差。矩阵 “cost” 应该由立体对应算法计算。
cv::validateDisparity 函数是 OpenCV 库中用于对立体匹配生成的视差图(disparity map)进行后处理的一个工具。其主要功能是对计算出的视差值进行验证,确保相邻像素间的视差值是合理的,并且符合左右图像的一致性检查。这有助于减少错误匹配和噪声,从而提高深度估计的准确性。

使用场景

  • 立体视觉应用:在需要高精度深度信息的应用中,如自动驾驶、机器人导航、增强现实等,使用 cv::validateDisparity 可以显著提高视差图的质量,进而提升系统的性能。
  • 3D重建:在基于立体图像的3D重建任务中,准确的视差图对于生成正确的三维模型至关重要。
  • 障碍物检测:在需要实时检测和避障的应用中,如无人机或自动机器人,高质量的视差图可以帮助更可靠地识别和避开障碍物。

函数原型

void cv::validateDisparity	
(InputOutputArray 	disparity,InputArray 	cost,int 	minDisparity,int 	numberOfDisparities,int 	disp12MaxDisp = 1 
)	

参数

  • InputOutputArray disparity:
    类型: 输入/输出参数
    说明: 这是待验证的视差图。它应该是一个单通道的矩阵,通常为 CV_16S 或 CV_32F 类型,表示每个像素点的视差值。经过 validateDisparity 处理后,不合理的视差值将被标记为无效(默认使用 CV_DISPARITY_INVALID_VALUE 或者用户定义的无效值)。
  • InputArray cost:
    类型: 输入参数
    说明: 代价体积(cost volume),由立体对应算法(如块匹配或半全局块匹配)计算得到。这个矩阵包含了每个可能的视差值的成本信息,帮助 validateDisparity 判断哪些视差值是可靠的。代价体积的尺寸应与 disparity 和 numberOfDisparities 对应。
  • int minDisparity:
    类型: 输入参数
    说明: 允许的最小视差值。所有低于这个值的视差都会被认为是无效的。这个参数定义了视差范围的下限。
  • int numberOfDisparities:
    类型: 输入参数
    说明: 在搜索范围内尝试的最大视差数量。视差的有效范围是从 minDisparity 到 minDisparity + numberOfDisparities - 1。这个参数定义了视差范围的上限,并且决定了代价体积的深度(即第三个维度的大小)。
  • int disp12MaxDisp = 1:
    类型: 输入参数(可选,默认值为 1)
    说明: 左右一致性检查中允许的最大差异。如果两个方向上的视差值差异超过了这个阈值,则认为该点的视差是不可靠的,并将其标记为无效。较大的值可能会容忍更多的误差,但也会导致更多的噪声通过验证。

代码示例

#include <iostream>
#include <opencv2/calib3d.hpp>  // 包含 validateDisparity 函数的头文件
#include <opencv2/opencv.hpp>
#include <opencv2/ximgproc/disparity_filter.hpp>  // 包含 WLS滤波器using namespace cv;
using namespace std;int main()
{// 读取左右图像 (假设为灰度图像)Mat imgL = imread( "/media/dingxin/data/study/OpenCV/sources/images/left.jpg", IMREAD_GRAYSCALE );Mat imgR = imread( "/media/dingxin/data/study/OpenCV/sources/images/right.jpg", IMREAD_GRAYSCALE );if ( imgL.empty() || imgR.empty() ){std::cout << "Could not open or find the images!" << std::endl;return -1;}// 创建 StereoSGBM 对象int minDisparity      = 0;int numDisparities    = 64;  // 必须是16的倍数int blockSize         = 5;int disp12MaxDiff     = 1;int uniquenessRatio   = 10;int speckleWindowSize = 100;int speckleRange      = 32;cv::Ptr< cv::StereoSGBM > sgbm = cv::StereoSGBM::create( minDisparity, numDisparities, blockSize, 8 * blockSize * blockSize, 32 * blockSize * blockSize, disp12MaxDiff, uniquenessRatio,speckleWindowSize, speckleRange, cv::StereoSGBM::MODE_SGBM_3WAY );// 计算视差图cv::Mat disparity;sgbm->compute( imgL, imgR, disparity );// 规范化视差图以进行显示cv::Mat disp;disparity.convertTo( disp, CV_8U, 255 / ( numDisparities * 16. ) );cv::imshow( "disparity", disp );cv::waitKey( 0 );return 0;
}

http://www.ppmy.cn/server/161017.html

相关文章

2025发文新方向:AI+量化 人工智能与金融完美融合!

2025深度学习发论文&模型涨点之——AI量化 人工智能的融入&#xff0c;使量化交易实现了质的突破。借助机器学习、深度学习等先进技术&#xff0c;人工智能可高效处理并剖析海量市场数据&#xff0c;挖掘出数据背后错综复杂的模式与趋势&#xff0c;从而不仅提升了数据分析…

汇编实验·循环程序设计

一、实验目的: 1.掌握汇编语言循环程序编写的基本方法。 2.理解高级语言中的循环的实现方式。 3.理解循环程序对性能的一些影响因素。 二、实验内容 1.C语言函数void*memset(void*s,intch,size_tn);是将s中当前位置后面的n个字节用ch替换,通常用于在一段内存块中填充某个…

nuxt3项目打包部署到服务器后配置端口号和开启https

nuxt3打包后的项目部署相对于一般vite打包的静态文件部署要稍微麻烦一些&#xff0c;还有一个主要的问题是开发环境配置的.env环境变量在打包后部署时获取不到&#xff0c;具体的解决方案可以参考我之前文章 nuxt3项目打包后获取.env设置的环境变量无效的解决办法。 这里使用的…

智能化加速标准和协议的更新并推动验证IP(VIP)在芯片设计中的更广泛应用

作者&#xff1a;Karthik Gopal, SmartDV Technologies亚洲区总经理 智权半导体科技&#xff08;厦门&#xff09;有限公司总经理 随着AI技术向边缘和端侧设备广泛渗透&#xff0c;芯片设计师不仅需要考虑在其设计中引入加速器&#xff0c;也在考虑采用速度更快和带宽更高的总…

99.10 金融难点通俗解释:投资资本回报率(ROIC)

目录 0. 承前1. 简述2. 比喻&#xff1a;养鸡赚钱2.1 第一步&#xff1a;分清投入2.2 第二步&#xff1a;开始经营2.3 第三步&#xff1a;计算收益2.4 第四步&#xff1a;计算ROIC 3. 生活中的例子3.1 高效率经营3.2 普通经营3.3 低效率经营 4. 小朋友要注意4.1 ROIC看什么4.2 …

Java数据结构 (从0构建链表(LinkedList))

在本文中&#xff0c;我们将基于 MySingleLinkedList 类&#xff0c;深入探讨单链表的实现&#xff0c;包括创建、插入、删除等核心操作&#xff0c;同时分享完整的代码示例。单链表是一种灵活的数据结构&#xff0c;适用于处理需要频繁插入和删除操作的场景&#xff0c;例如实…

【mybatis】一对多查询

书接上文&#xff0c;当多表查询&#xff0c;为了一个查询出全部&#xff0c;使用了GROUP_CONCAT和json_object函数&#xff0c;但是当数据量过大时&#xff0c;需要更改mysql的数据库配置&#xff0c;调大group_concat_max_len配置参数。 但是项目中可能存在线上数据库不让重…

高质量编程 性能优化学习笔记

高质量编程 & 性能优化学习笔记 目录 高质量编程 编程原则编码规范 性能优化 性能优化建议实战pprof性能调优案例 自动内存管理 常见内存管理方式 Go内存管理及优化 Go内存分配Go内存管理优化 编译器和静态分析 编译器静态分析 Go编译器优化 函数内联逃逸分析…