0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

检测三维物体?一篇文章认识《双目立体视觉》

新机器视觉 来源:CSDN 2023-06-01 14:54 次阅读

前言

双目立体视觉,由两个摄像头组成,像人的眼睛能看到三维的物体,获取物体长度、宽度信息,和深度的信息;单目视觉获取二维的物体信息,即长度、宽度。

1)双目摄像头

双目摄像头示意图(ORBBEC Gemini 3D传感摄像头是一款基于双目结构光3D成像技术的近距离高精度嵌入式模组):

e0e66e46-0016-11ee-90ce-dac502259ad0.png

2)双目相机基线

基线越大,测量范围越远;基线越小,测量范围越近。

e0fede9a-0016-11ee-90ce-dac502259ad0.png

建议:

(1)基线距离是工作距离的08-2.2倍时测量误差比较小;

(2)双目立体视觉的结构对称时,测量系统的误差比较小,精度也比较高。

(3)两台相机的有效焦距∫越大,视场越小,视觉测量系统的测量精度越高(即采用长焦距镜头容易获得较高的测量精度)

3)打开双目摄像头

在OpenCV用使用双目摄像头,包括:打开单目摄像头、设置摄像头参数、拍照、录制视频

环境编程语言:Python3        主要依赖库:OpenCV3.x 或 OpenCV4.x

双目同步摄像头,两个镜头共用一个设备ID,左右摄像机同一频率。这款摄像头分辨率支持2560*960或以上。

思路流程:

1、由于两个镜头共用一个设备ID,打开摄像头时使用cv2.VideoCapture()函数,只需打开一次。区别有的双目摄像头是左右镜头各用一个设备ID,需要打开两次cv2.VideoCapture(0),cv2.VideoCapture(1)。

2、双目摄像头的总分辨率是由左右镜头组成的,比如:左右摄像机总分辨率1280x480;分割为左相机640x480、右相机640x480

e10e4baa-0016-11ee-90ce-dac502259ad0.png

为了方便理解画了张草图;图中的“原点”是图像像素坐标系的原点。

3、分割后,左相机的分辨率:高度 0:480、宽度 0:640

右相机的分辨率:高度 0:480、宽度 640:1280

4、转换为代码后

    #读取摄像头数据
    ret, frame = camera.read()
    #裁剪坐标为[y0:y1, x0:x1]  HEIGHT * WIDTH
    left_frame = frame[0:480, 0:640]
    right_frame = frame[0:480, 640:1280]


    cv2.imshow("left", left_frame)
    cv2.imshow("right", right_frame)

源代码:

举个栗子:打开分辨率1280x480的双目摄像头

#-*-coding:utf-8-*-
import cv2
import time




AUTO = False  # 自动拍照,或手动按s键拍照
INTERVAL = 2 # 自动拍照间隔


cv2.namedWindow("left")
cv2.namedWindow("right")
camera = cv2.VideoCapture(0)


# 设置分辨率 左右摄像机同一频率,同一设备ID;左右摄像机总分辨率1280x480;分割为两个640x480、640x480
camera.set(cv2.CAP_PROP_FRAME_WIDTH,1280)
camera.set(cv2.CAP_PROP_FRAME_HEIGHT,480)


counter = 0
utc = time.time()
folder = "./SaveImage/" # 拍照文件目录


def shot(pos, frame):
    global counter
    path = folder + pos + "_" + str(counter) + ".jpg"


    cv2.imwrite(path, frame)
    print("snapshot saved into: " + path)


while True:
    ret, frame = camera.read()
    # 裁剪坐标为[y0:y1, x0:x1] HEIGHT*WIDTH
    left_frame = frame[0:480, 0:640]
    right_frame = frame[0:480, 640:1280]


    cv2.imshow("left", left_frame)
    cv2.imshow("right", right_frame)


    now = time.time()
    if AUTO and now - utc >= INTERVAL:
        shot("left", left_frame)
        shot("right", right_frame)
        counter += 1
        utc = now


    key = cv2.waitKey(1)
    if key == ord("q"):
        break
    elif key == ord("s"):
        shot("left", left_frame)
        shot("right", right_frame)
        counter += 1
camera.release()
cv2.destroyWindow("left")
cv2.destroyWindow("right")

补充理解:

OpenCV有VideoCapture()函数,能用来定义“摄像头”对象,0表示第一个摄像头(一般是电脑内置的摄像头);如果有两个摄像头,第二个摄像头则对应VideoCapture(1)。

在while循环中使用“摄像头对象”的read()函数一帧一帧地读取摄像头画面数据。

imshow函数是显示摄像头的某帧画面;cv2.waitKey(1)是等待1ms,如果期间检测到了键盘输入q,则退出while循环。

效果:

e142af1c-0016-11ee-90ce-dac502259ad0.png

4)双目测距

原理:

通过对两幅图像视差的计算,直接对图像所拍摄到的范围进行距离测量,无需判断前方出现的是什么类型的障碍物。

e162347c-0016-11ee-90ce-dac502259ad0.png

视差disparity:

首先看一组视觉图:左相机图和右相机图不是完全一致的,通过计算两者的差值,形成视差,生成视差图(也叫:深度图)

e1761154-0016-11ee-90ce-dac502259ad0.png

视差是同一个空间点在两个相机成像中对应的x坐标的差值;

它可以通过编码成灰度图来反映出距离的远近,离镜头越近的灰度越亮;

e1810370-0016-11ee-90ce-dac502259ad0.png

我们观察一下,看到台灯在前面,离双目相机比较近,在灰度图呈现比较亮;摄影机及支架在后方,离双目相机比较远,在灰度图呈现比较暗。

补充理解:

由立体视觉系统测量的深度被离散成平行平面 (每个视差值一个对应一个平面)

e198bc86-0016-11ee-90ce-dac502259ad0.png

给定具有基线 b 和焦距 f 的立体装备, 系统的距离场受视差范围[dmin ,dmax]的约束。

极线约束:

极线约束(Epipolar Constraint)是指当空间点在两幅图像上分别成像时,已知左图投影点p1,那么对应右图投影点p2一定在相对于p1的极线上,这样可以极大的缩小匹配范围。

e1afa1ee-0016-11ee-90ce-dac502259ad0.png

标准形式的双目摄像头,左右相机对齐,焦距相同。

e1c41f20-0016-11ee-90ce-dac502259ad0.png

如果不是标准形式的双目摄像头呢?哦,它是是这样的:(需要极线校正/立体校正)

e1daa22c-0016-11ee-90ce-dac502259ad0.png

极线校正/立体校正

e1ff23f4-0016-11ee-90ce-dac502259ad0.png

双目测距流程:

a.双目标定

主要是获取内参(左摄像头内参+右摄像头内参)、外参(左右摄像头之间平移向量+旋转矩阵)

标定过程:

e21bbf46-0016-11ee-90ce-dac502259ad0.png

b.双目矫正

消除镜头变形,将立体相机对转换为标准形式

e29330f8-0016-11ee-90ce-dac502259ad0.png

c.立体匹配

寻找左右相机对应的点(同源点)

e2b73e58-0016-11ee-90ce-dac502259ad0.png

d.双目测距(三角测量)

给定视差图、基线和焦距,通过三角计算在3D中对应的位置

e2cdd668-0016-11ee-90ce-dac502259ad0.png

双目测距原理

e2e4a5e6-0016-11ee-90ce-dac502259ad0.png

e.测距效果

e2fd8502-0016-11ee-90ce-dac502259ad0.png

彩蛋:双目立体匹配(重点)

立体匹配是双目立体视觉中比较重要的一环,往往这里做研究和优化。

e314ed32-0016-11ee-90ce-dac502259ad0.png

a.立体匹配流程

e33dc388-0016-11ee-90ce-dac502259ad0.png

b.匹配代价计算

代价函数用于计算左、右图中两个像素之间的匹配代价(cost)。cost越大,表示这两个像素为对应点的可能性越低。

e345b070-0016-11ee-90ce-dac502259ad0.png

常用代价函数

AD/BT

AD+Gradient

Census transform

SAD/SSD

NCC

AD+Census

CNN

c.立体匹配

e370a122-0016-11ee-90ce-dac502259ad0.png

端到端视差计算网络

 Disp-Net (2016)

 GC-Net (2017)

 iRestNet (2018)

 PSM-Net (2018)

 Stereo-Net (2018)

 GA-Net (2019)

 EdgeStereo (2020)

e382dc66-0016-11ee-90ce-dac502259ad0.png

立体视觉方法评测网站

ETH3Dhttps://www.eth3d.net/

Kitti Stereohttp://www.cvlibs.net/datasets/kitti/eval_scene_flow.php?benchmark=stereo

Middlebury Stereo 3.0https://vision.middlebury.edu/stereo/eval3/

e3a132a6-0016-11ee-90ce-dac502259ad0.png

双目测距总结

优势:

(1)成本比单目系统要高,但尚处于可接受范围内,并且与激光雷达等方案相比成本较低;

(2)没有识别率的限制,因为从原理上无需先进行识别再进行测算,而是对所有障碍物直接进行测量;

(3)直接利用视差计算距离,精度比单目高;

(4)无需维护样本数据库,因为对于双目没有样本的概念。

难点:

(1)计算量大,对计算单元的性能要求高,这使得双目系统的产品化、小型化的难度较;(芯片FPGA

(2)双目的配准效果,直接影响到测距的准确性;

(3)对环境光照非常敏感;(光照角度、光照强度)

(4)不适用于单调缺乏纹理的场景;(天空、白墙、沙漠)

(5)相机基线限制了测量范围。(基线越大,测量范围越远;基线越小,测量范围越近)

审核编辑 :李倩

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 成像技术
    +关注

    关注

    4

    文章

    265

    浏览量

    31288
  • 摄像头
    +关注

    关注

    59

    文章

    4612

    浏览量

    92909
  • 结构光
    +关注

    关注

    0

    文章

    74

    浏览量

    13082

原文标题:检测三维物体?一篇文章认识《双目立体视觉》

文章出处:【微信号:vision263com,微信公众号:新机器视觉】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    双目立体视觉原理大揭秘(

    双目视觉的应用来说,主要分为四大部分: 双目视觉导航、定位;二 三维重构; 双目
    发表于 11-21 16:20

    双目立体视觉原理大揭秘(二)

    `双目立体视觉原理大揭秘(二)——三维重构双目立体视觉门有着广阔应用前景的学科,根据
    发表于 11-21 16:22

    基于立体视觉的变形测量

    ,快速、精确的获得被测对象的全场位移应变信息,在各个研究领域得到了广泛应用。 立体视觉是由多幅图像获取物体三维几何信息的方法。双目立体视觉
    发表于 09-21 10:11

    双目产品在高校科研应用中的实例及优点分析

    中,应用双目立体视觉来进行的热点方向很多,采用视图像专门针对双目立体视觉优化定制的系列双目工业
    发表于 01-19 16:59

    双目立体视觉的运用

    四种:1、双目视觉导航、定位;2、三维重构;3、双目立体测量;4、空间三维立体跟踪。这些运用需求
    发表于 03-03 09:36

    LABVIEW能做双目立体视觉

    最近在做双目立体视觉项目,LABVIEW有模块吗,有哪位大神用LABVIEW做过
    发表于 01-13 19:44

    3D视觉的测量原理

    ,然后通过角测量原理计算图像像素间的位置偏差(视差)来获取景物的三维信息。这过程与人类视觉感知过程是类似的。    双目
    发表于 12-01 15:08

    双目立体视觉在嵌入式中有何应用

    双目立体视觉(BinocularStereoVision)是机器视觉种重要形式,因其可简单地利用左右摄像机中的图像信息计算得到相机视野中物体
    发表于 12-23 07:19

    双目立体视觉中靶标的设计与识别

    0 引言    双目立体视觉测量是基于视差原理,由多幅图像获取物体三维几何信息的方法。在计算机视觉系统中,
    发表于 09-26 17:07 1098次阅读
    <b class='flag-5'>双目</b><b class='flag-5'>立体视觉</b>中靶标的设计与识别

    基于HALCON的双目立体视觉系统实现

    双目立体视觉的研究一直是机器视觉中的热点和难点。使用双目立体视觉系统可以确定任意物体
    发表于 04-08 17:51 130次下载
    基于HALCON的<b class='flag-5'>双目</b><b class='flag-5'>立体视觉</b>系统实现

    双目立体视觉三维测量原理

    双目立体视觉是基于视差,由三角法原理进行三维信息的获取,即由两个摄像机的图像平面和北侧物体之间构成一个三角形。一直两个摄像机之间的位置关系,便可以获得两摄像机公共视场内
    的头像 发表于 04-11 14:32 2.3w次阅读
    <b class='flag-5'>双目</b><b class='flag-5'>立体视觉</b><b class='flag-5'>三维</b>测量原理

    双目主动立体视觉监测平台靶标编码标志点的设计与识别分析

    双目立体视觉测量是基于视差原理,由多幅图像获取物体三维几何信息的方法。在计算机视觉系统中,双目
    的头像 发表于 12-29 08:50 4194次阅读

    重庆钜芯视觉科技发布国内首款智能双目立体视觉芯片

    智能双目立体视觉芯片模拟人的“双眼”,给车辆加上一双“眼睛”,将二维成像变为三维成像。
    的头像 发表于 10-08 15:31 7109次阅读

    使用双目立体视觉实现CCD测距系统设计的资料说明

    双目立体视觉测量是人类利用双眼获取环境三维信息的主要途径。随着计算机视觉理论的发展,双目立体视觉
    发表于 11-26 12:05 6次下载
    使用<b class='flag-5'>双目</b><b class='flag-5'>立体视觉</b>实现CCD测距系统设计的资料说明

    一篇文章带你认识双目立体视觉

    前言 双目立体视觉,由两个摄像头组成,像人的眼睛能看到三维物体,获取物体长度、宽度信息,和深度的信息;单目
    的头像 发表于 04-26 14:19 9088次阅读
    一篇文章带你<b class='flag-5'>认识</b>《<b class='flag-5'>双目</b><b class='flag-5'>立体视觉</b>》