双目测距-原理及代码实现

时间:2019-05-14 21:30:31   收藏:0   阅读:857

需求:使用双目摄像头得出物体3D坐标,本质就是利用双目来得到深度信息。

github代码

0 知识扫盲

1 相机标定

使用MATLAB标定。左右照片各15张(共采集19张,MATLAB识别出有效16张,手动删除一张Mean Erro较大的图)。记下 内参参数及两相机间的RT矩阵。MATLAB 标定结果如下。设置棋盘格单位长度25mm。
技术分享图片
可以看出标定出的的结果相机及棋盘的摆放位置与实际摆放接近。
技术分享图片
图中标定显示棋盘与相机大概700~800mm的距离(棋盘格单位为25mm的前提下)。

2 计算3d坐标。

题主主要利用了opencv提供的
cv2.triangulatePoints()函数

'''
参数含义:
projMatr1   3x4 projection matrix of the first camera.
projMatr2   3x4 projection matrix of the second camera.
projPoints1 2xN array of feature points in the first image. In case of c++ version it can be also a vector of feature points or two-channel matrix of size 1xN or Nx1.
projPoints2 2xN array of corresponding points in the second image. In case of c++ version it can be also a vector of feature points or two-channel matrix of size 1xN or Nx1.
points4D    4xN array of reconstructed points in homogeneous coordinates.
'''
points4D = cv.triangulatePoints(projMatr1, projMatr2, projPoints1, projPoints2[, points4D])

可见关键步是计算出两个投影矩阵, 然后将待测物体在左右相机成像的像素坐标代入即可得到3d坐标。原理、方法都很简单。
投影矩阵的计算有两种方式:

3.验证.

将棋盘格左右像素坐标代入函数cv.triangulatePoints()得到棋盘格格点3d坐标.
MATLAB标定结果:
技术分享图片
opencv标定结果:
技术分享图片
可以看出在3维坐标的计算上,三个轴3d坐标与实际值相差都很小,并且opencv标注产生的均方误差在三个轴均略优于MATLAB。

继续验证:
左相机视图:
技术分享图片
实物图:
技术分享图片

matlab标定给出的3d结果:
技术分享图片

opencv标定给出的3d结果:
技术分享图片
(结果比较接近,相差6mm。结果负值是坐标系原因。)
github代码

原文:https://www.cnblogs.com/mengban/p/10864549.html

评论(0
© 2014 bubuko.com 版权所有 - 联系我们:wmxa8@hotmail.com
打开技术之扣,分享程序人生!