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

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

3天内不再提示

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

新机器视觉 来源:CSDN威廉希尔官方网站 社区 作者:一颗小树X 2021-04-26 14:19 次阅读

前言

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

1)双目摄像头

常见的双目摄像头有以下几款:

能看到不同类型的双目摄像头,左摄像头和右摄像头之间的距离不一样。

2)双目相机基线

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

建议:

(1)基线距B是工作距离的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

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

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循环。

效果

4)双目测距

原理

视差disparity

极线约束

极线校正/立体校正

双目测距流程:

a.双目标定

b.双目矫正

c.立体匹配

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

e.测距效果

原理

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

o4YBAGCGXHSAP9ctAAIB8Nbbiro048.png

视差disparity

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

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

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

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

补充理解:

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

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

极线约束

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

pIYBAGCGXLOAPKEXAAIK-8o5b9w626.png

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

pIYBAGCGXNSAThFQAAJsjQw00Gk841.png

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

极线校正/立体校正

双目测距流程:

相机标定(获取内参+外参)

双目矫正(矫正镜头变形图像)

双目立体匹配(生成视差图 Disparity map)

计算深度信息(生成深度图 Depth map)

计算距离

a.双目标定

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

标定过程:

详细过程请参考:双目视觉 标定+矫正 (基于MATLAB

b.双目矫正

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

c.立体匹配

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

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

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

o4YBAGCGXQ2AV88fAAJPgl5suuU260.png

双目测距原理

o4YBAGCGXTOAcrRjAAG5hFei-5w838.png

C++版代码请参考:双目 机器视觉-- 测距

Python版代码:看看大家情况,如果需要的,我抽时间完成分享给大家(BM、SGBM算法等)

e.测距效果

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

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

a.立体匹配流程

o4YBAGCGXVuAVF0OAABObZ8Tnyo191.png

b.匹配代价计算

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

常用代价函数

AD/BT

AD+Gradient

Census transform

SAD/SSD

NCC

AD+Census

CNN

c.立体匹配

端到端视差计算网络

 Disp-Net (2016)

 GC-Net (2017)

 iRestNet (2018)

 PSM-Net (2018)

 Stereo-Net (2018)

 GA-Net (2019)

 EdgeStereo (2020)

\

立体视觉方法评测网站

ETH3D https://www.eth3d.net/

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

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

如果大家对端到端视差计算网络感兴趣,需要开源代码跑通教程和介绍,也考虑分享大家,主要看大家意愿了。

双目测距总结

优势

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

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

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

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

难点

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

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

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

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

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

编辑:jq

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

    关注

    7

    文章

    3800

    浏览量

    64397
  • 代码
    +关注

    关注

    30

    文章

    4788

    浏览量

    68620
  • 测距
    +关注

    关注

    2

    文章

    105

    浏览量

    19647

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

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

收藏 人收藏

    评论

    相关推荐

    UVLED光固化机常用术语和单位简介,文章带你全面了解!

    在现代化的工业生产中,UVLED光固化机以其高效、环保的特点,成为了众多行业的得力助手。然而,对于初次接触UVLED光固化机的朋友来说,那些专业术语和单位可能会让人感到困惑。别担心,今天我们就来
    的头像 发表于 12-24 13:27 143次阅读
    UVLED光固化机常用术语和单位简介,<b class='flag-5'>一</b><b class='flag-5'>篇</b>文章<b class='flag-5'>带你</b>全面了解!

    杰和课堂|带你认识算力

    杰和课堂|带你认识算力人工智能浪潮汹涌的今天,算力词频繁出现在各类科技新闻、产业发展报告中。了解过杰和科技产品的读者们,也会在杰和各产品参数中发现算力这概念,比如AI
    的头像 发表于 12-06 10:24 293次阅读
    杰和课堂|<b class='flag-5'>带你</b><b class='flag-5'>认识</b>算力

    智慧公交是什么?带你详解智慧公交的解决方案!

    智慧公交是什么?带你详解智慧公交的解决方案!
    的头像 发表于 11-05 12:26 291次阅读
    智慧公交是什么?<b class='flag-5'>一</b>文<b class='flag-5'>带你</b>详解智慧公交的解决方案!

    德国进口蔡司体视显微镜的使用方法

    显微镜时是否需要手动对焦镜头,以及如何正确地进行对焦操作。、蔡司体视显微镜的对焦机制蔡司体视显微镜设计有灵活的对焦系统,旨在提供清晰、锐利的图像。尽管有些高级模型可
    的头像 发表于 09-26 15:19 386次阅读
    德国进口蔡司<b class='flag-5'>体视</b>显微镜的使用方法

    立体视觉新手必看:英特尔® 实感™ D421深度相机模组

    英特尔首款体化立体深度模组,旨在将先进的深度感应威廉希尔官方网站 带给更广泛的受众 2024年9月24日 —— 英特尔® 实感™ 威廉希尔官方网站 再次突破界限,推出全新的英特尔® 实感™ 深度相机模组D421。这是
    的头像 发表于 09-26 13:33 265次阅读
    <b class='flag-5'>立体视觉</b>新手必看:英特尔® 实感™ D421深度相机模组

    居然还有这样的10.1寸光场裸眼3D视觉训练平板电脑?

    在这个科技飞速发展的时代,我们为您带来了款革命性的产品——10.1寸光场裸眼3D视觉训练平板电脑。这款平板电脑不仅让您无需佩戴3D眼镜就能享受逼真的立体视觉效果,还通过先进的威廉希尔官方网站 帮助您缓解眼疲劳,提升
    的头像 发表于 07-25 14:09 278次阅读
    居然还有这样的10.1寸光场裸眼3D<b class='flag-5'>视觉</b>训练平板电脑?

    新品 | Bumblebee X系列用于高精度机器人应用的新型立体视觉产品

    TeledyneFLIRIIS推出款用于高精度机器人应用的新型立体视觉产品BumblebeeX系列。BumblebeeX产品图BumblebeeX系列,个基于
    的头像 发表于 05-07 08:34 454次阅读
    新品 | Bumblebee X系列用于高精度机器人应用的新型<b class='flag-5'>立体视觉</b>产品

    Teledyne FLIR IIS推出款用于高精度机器人的新型立体视觉产品

    Bumblebee X是最新的GigE驱动立体成像解决方案,为机器人引导和拾取应用带来高精度和低延迟
    的头像 发表于 05-06 09:23 564次阅读

    文读懂双眼立体显示威廉希尔官方网站 四种主流立体显示威廉希尔官方网站 介绍

    实现基于双眼视觉立体显示需要经过两大步骤,首先,要准备好两套分别供左眼和右眼观看的画面。
    发表于 04-24 11:48 1531次阅读
    <b class='flag-5'>一</b>文读懂双眼<b class='flag-5'>立体</b>显示威廉希尔官方网站
 四种主流<b class='flag-5'>立体</b>显示威廉希尔官方网站
介绍

    全新代哈弗H6官图曝光:外观焕然新,性能持续升级

     新款哈弗H6的前脸采用了大面积中网设计,呈现出独特的点阵式方块图案,营造出立体视觉效果。前大灯组与中网紧密连接,内置两个透镜,下方配以“7”字形日行灯,增强了科技感。
    的头像 发表于 04-16 15:17 522次阅读

    工业相机单目和双目的区别

    工业相机标定的方法根据工业相机的数目可分为单目标定、双目标定Q以及多目标定。
    的头像 发表于 03-26 16:26 1915次阅读
    工业相机单目和<b class='flag-5'>双目</b>的区别

    银牛微电子3D视觉感知方案赋能小米CyberDog系列仿生四足机器人

    2024年3月21日,合肥银牛微电子宣布小米CyberDog系列仿生四足机器人的AI多模态融合感知决策系统正式采用银牛的双目立体视觉产品解决方案。
    的头像 发表于 03-21 13:55 834次阅读

    总投资1.5亿!苏州清研微视立体视觉传感器项目落户安徽芜湖

    2月1日,清研年产3万台立体视觉传感器项目签约落户安徽芜湖三山经济开发区。项目计划总投资15000万元,建设年产3万台立体视觉传感器(产业创新融合产品)。该项目的落地加强了三山经开区与清华大学未来在
    的头像 发表于 02-20 08:36 341次阅读
    总投资1.5亿!苏州清研微视<b class='flag-5'>立体视觉</b>传感器项目落户安徽芜湖

    教你该如何操作体视显微镜

    科技体视显微镜也称解刨显微镜,是微量物证检验常用的仪器。主要用于痕迹检验、文件检验中的细小物证,如指纹、工具、文字的显微观察和分析检验。体视显微镜主要操作有:调焦,视度调节,瞳距调节和灯泡更换
    的头像 发表于 01-26 08:35 2183次阅读
    教你该如何操作<b class='flag-5'>体视</b>显微镜

    三维视觉测量威廉希尔官方网站 :被动视觉测量和主动视觉测量

    与人眼的立体感知类似,双目立体视觉用两个相机从不同的角度对被测物体成像。依据两幅图像中对应点的立体视差( stereo disparity) ,根据三角测量原理实现三维信息测量。
    的头像 发表于 01-03 11:30 857次阅读
    三维<b class='flag-5'>视觉</b>测量威廉希尔官方网站
:被动<b class='flag-5'>视觉</b>测量和主动<b class='flag-5'>视觉</b>测量