stereo calibration使用opencv获取图像rectification

    1. 使用opencv获取图像rectification

左右两张图像经过rectification后,会前向共面,也就是它们的主光轴平行,见“三角测量的前提的假设”。

该处理的源代码对应于opencv的sample的stereo_calib.cpp。

      1. 基本处理过程

基本处理过程分为两个部分,1)获取进行rectification所需要的map1和map2。 2)对每张图像基于是left camera还是right camera分别进行remap。

第二部分非常简单,类似于单目camera的UndistortRectify的remap操作,省略。

第一部分的处理如下:

  1. 从图片列表中读取图像。
  2. cvtColor,把图像转换成灰度图;
  3. 基于灰度图像,使用findChessboardCorners, 获取corners
  4. 基于灰度图,使用cornerSubPix,获取更精确的corners
  5. 基于左右camera,把每张图的Corner points 放入分别放入左右images points,二维向量,第一维对应于图像,第二维对应于图像内的corners points;
  6. 基于图像的数量构造obj points ;
  7. 调用initCameraMatrix2D函数,基于3D object的points和2D image points的对应关系,获取左右camera matrix。
  8. 调用stereoCalibrate函数,进行stereo 标定
  9. 遍历所有图像,调用undistortPoints函数和computeCorrespondEpilines函数和函数fabs来计算标定的epipolar的误差。
  10. 调用stereoRectify函数,获取左右image plane的和、投影矩阵和和用于3维重建的矩阵Q。后面会调用stereoRectifyUncalibrated函数更新左右image plane的和、投影矩阵和。
  11. 如果使用的是HARTLEY'S METHOD,调用findFundamentalMat函数,计算基本矩阵。
  12. 果使用的是HARTLEY'S METHOD,调用stereoRectifyUncalibrated函数,计算用于rectification的单应性矩阵,并基于单应性矩阵获取左右image plane的和,并更新投影矩阵和。
  13. 调用initUndistortRectifyMap函数,获取左右image plane对应的undistortion map。
  14. 结束。
      1. demo的输入参数

demo的输入参数:

  1. -w=6,board_width,棋盘的x-axis有6个Corner;
  2. -h=9,board_height,棋盘的y-axis有9个Corner;
  3. Inputdata=stereoFrames/path.yml,它的左右图像必须成对出现,因此,它的组织形式按seq方式组织如下:

%YAML:1.0

---

image:

   - "/data_1/songqing/opencv/example/image/stereoFrames/Color_0.bmp"

   - "/data_1/songqing/opencv/example/image/stereoFrames/IR_gain0x0_exp0x0_1.bmp"

   - "/data_1/songqing/opencv/example/image/stereoFrames/Color_10.bmp"

   - "/data_1/songqing/opencv/example/image/stereoFrames/IR_gain0x0_exp0x0_11.bmp"

  1. square size,默认为1;

我使用了HARTLEY'S METHOD,如果使用BOUGUET’S METHOD,出来的结果是错误的,应该是我右边的摄像头有光斑导致的。

用网上使用的棋盘图像,使用HARTLEY'S METHOD和BOUGUET’S METHOD都能得到正确的结果。

      1. 结果分析

原有的程序输出的结果有:

  1. extrinsics.yml:包含stereo 标定的旋转矩阵R,left camera的,right camera,平移矩阵T,leftcamera的投影矩阵,rightcamera的,重映射矩阵Q。
  2. intrinsics.yml:左右两个camera的camera 内参和畸变相关系数。

 

我进行图像验证的输入和输出如下:

输入的图像如下:

输出的图像如下:

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: OpenCV是一个开源的计算机视觉库,提供了很多图像处理和计算机视觉算法的功能。其中,stereocalibration 是其重要的功能之一。 Stereocalibration (立体标定)是指通过对立体摄像机进行标定,获取两个摄像机之间的相对位置和姿态关系的过程。通过立体标定,我们可以得到摄像机的内参(内部参数)和外参(外部参数),来实现立体视觉应用的效果。 在OpenCV中,实现立体标定的方法为cv::stereoCalibrate。该函数需要输入最少8组匹配的立体校准图像点对,并输出摄像机内参和外参矩阵。在进行立体标定之前,需要先进行单目摄像机的标定(通过cv::calibrateCamera函数),获取摄像机的内参矩阵。 进行立体标定时,需要确保两个摄像机存在一定的平行关系,即两个摄像机的视野相同,且图像中有一定数量的共视点。标定过程会计算两个摄像机之间的旋转矩阵和平移矩阵,通过这些参数可以实现对图像的三维重建以及深度信息的获取。 值得注意的是,立体标定的精度会受到多种因素的影响,如图像噪声、特征点提取的准确性等。因此,在进行立体标定的过程中,需要谨慎选择标定图像,优化特征点匹配算法,以及对标定结果进行评估和优化。 总结来说,OpenCV的立体标定功能为我们提供了实现立体视觉应用的基础,通过标定摄像机的内外参,我们可以获得摄像机的几何关系,从而实现深度信息的获取和三维重建等应用。但在使用过程中需要注意标定参数的选择和精度评估,以获得较好的标定效果。 ### 回答2: OpenCV是一个开源的计算机视觉库,它提供了许多用于图像处理和计算机视觉任务的函数和工具。其中一个重要的功能是立体摄像机标定(stereo calibration)。 立体摄像机标定是通过对立体摄像机进行一系列的计算和校准,使其能够准确地测量和重建三维物体的几何信息。 在标定过程中,需要收集一组立体图像对(即左右两个摄像机拍摄的同一场景),并对这些图像进行处理和分析。 首先,必须确定摄像机的内部参数,如焦距、主点位置和畸变系数。这可以通过摄像机的参数模型和一组已知的三维点与它们在图像中的对应点来完成。OpenCV提供了一些函数,可以自动检测并计算这些内部参数。 接下来,需要确定摄像机的相对位置和姿态(即外部参数)。这可以通过对图像中的特征点进行匹配,并使用三角测量技术计算两个摄像机的相对位置和姿态。 一旦摄像机的内部和外部参数都已确定,我们就可以使用立体摄像机进行深度感知和三维重建。通过将左右两个图像对应的像素点投影到三维空间中,并计算它们之间的距离,就可以得到三维物体的位置和形状信息。 OpenCV提供了一些函数和工具,可帮助我们执行所有这些步骤。它包括摄像机标定函数(calibrateCameraStereo)和立体匹配函数(stereoRectify,stereoMatch),这些函数可以方便地进行标定和三维重建。 总之,OpenCV的立体摄像机标定功能可以帮助我们准确地测量和重建三维物体的几何信息。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值