19.单目测距原理介绍

文章目录

    • 相机成像模型的再次介绍
    • 单目测距的几何原理
      • reference


欢迎访问个人网络日志🌹🌹知行空间🌹🌹


根据相机成像的原理,在满足一定约束条件下,理论上是可以根据目标点的像素坐标计算出其对应的深度信息的。

相机成像模型的再次介绍

根据,

1.基本相机模型及参数

2.OpenCV相机标定

这两部分的介绍,我们可以知道相机的基本模型,其原理本质上还是小孔成像,感光芯片记录下成像信息变成图片来实现的。

现在我们来看下OpenCV相机标定的结果,为了简化介绍,畸变系数这里不再重复介绍,可以参考上面两个博客。

相机标定的内参矩阵为:

[ f x 0. c x 0 f y c y 0 0. 1 ] = [ 1044.43 0. 959.5 0 1047.87 541.5 0 0. 1 ] \begin{bmatrix} f_x & 0. & c_x \\ 0 & f_y & c_y \\ 0 & 0. & 1 \\ \end{bmatrix} = \begin{bmatrix} 1044.43 & 0. & 959.5 \\ 0 & 1047.87 & 541.5 \\ 0 & 0. & 1 \\ \end{bmatrix} fx000.fy0.cxcy1 = 1044.43000.1047.870.959.5541.51

相机原始分辨率为:WxH=1920x1080

相机的焦距为2.93mm

相机的感光芯片上像元大小是 d x × d y d_x\times d_y dx×dy=2.8umx2.8um

根据相机内参的公式: f x = f d x f_x=\frac{f}{d_x} fx=dxf,在这里其中 d x = 2.8 u m d_x=2.8um dx=2.8um是像元的大小, f = 2.93 m m f=2.93mm f=2.93mm是焦距,因此 f x = 2.93 2.8 × 1 0 − 3 = 1046.43 f_x=\frac{2.93}{2.8\times10^{-3}}=1046.43 fx=2.8×1032.93=1046.43这和上面标定的结果1044.43/1047.87十分接近,这也验证了相机模型的正确性。

单目测距的几何原理

单目测距的几何原理可以借用下面这张图来做介绍:

reference:
https://zhuanlan.zhihu.com/p/664389534

参考上图:

像平面是相机的成像平面,也就是感光芯片所在的平面。

光心O处的坐标系{C}是相机所在的坐标系,点 O 1 O_1 O1,点 O O O和点Z_c共线,线 O 1 Z c O_1Z_c O1Zc是相机的主轴,相机安装时有一定的俯仰角,因此相机主轴和水平线的夹较为 α \alpha α

相机的光心 O O O到待测对像所在平面的垂直高度为 O O 2 OO_2 OO2,记为 h h h

O 2 O_2 O2点沿相机坐标系的XY轴在待测对像所在平面建立坐标系 { x 1 O 2 y 1 } \{x_1O_2y_1\} {x1O2y1}

待测对像上的目标点为 Q Q Q,其在像平面上的成像点为 Q ′ Q' Q,记其在坐标系 { x 1 O 2 y 1 } \{x_1O_2y_1\} {x1O2y1}中的坐标为 ( x , y ) (x,y) (x,y),在图像上的像素坐标为 ( u , v ) (u,v) (u,v)

目标点Q向坐标系 { x 1 O 2 y 1 } \{x_1O_2y_1\} {x1O2y1}X轴做垂线,得点P,连接OP其和像平面的Y轴交于点 P ′ P' P,同时点 P ′ P' P也是 Q ′ Q' Q到像平面Y轴的垂足。

∠ P ′ O O 1 \angle{P'OO_1} POO1 β \beta β,作为其对角 ∠ P O Z c \angle{POZ_c} POZc也为 β \beta β,从图上看以看出 γ = α + β \gamma=\alpha+\beta γ=α+β

β \beta β角很容易求出:

β = a r c t a n P ′ O 1 O 1 O β = a r c t a n ( c y − v ) ∗ d y f \beta = arctan{\frac{P'O_1}{O_1O}} \\ \beta = arctan{\frac{(c_y -v)*d_y}{f}} \\ β=arctanO1OPO1β=arctanf(cyv)dy

求得 β \beta β后可得 γ \gamma γ,由此 P O 2 PO_2 PO2即目标点在 X X X轴上的距离为:

P O 2 = h t a n γ PO_2 = \frac{h}{tan\gamma} PO2=tanγh

以上就求出了目标点Q在坐标系 { x 1 O 2 y 1 } \{x_1O_2y_1\} {x1O2y1}X轴上的坐标。

再来看Y轴上的坐标:

根据三角形 △ P ′ Q ′ O \triangle P'Q'O PQO相似于三角形 △ P Q O \triangle PQO PQO,容易求得PQ的长度为:

P Q = ( u − c x ) ∗ d x ∗ h 2 + P O 2 2 [ ( c y − v ) ∗ d y ] 2 + f 2 PQ = \frac{(u-cx)*d_x * \sqrt{h^2+PO_2^2}}{\sqrt{[(cy-v)*d_y]^2+f^2}} PQ=[(cyv)dy]2+f2 (ucx)dxh2+PO22

如上,就可以求出目标点Q在坐标系 { x 1 O 2 y 1 } \{x_1O_2y_1\} {x1O2y1}Y轴上的坐标

值得注意的是:

  • 以上仅考虑了投影点出现在图像平面第二象限的情况,如果目标点在图像平面的第三/四象限,还需对计算结果符号进行调整。

  • 计算中涉及到除法,还需考虑除以零的情况。

reference

  • 1.https://zhuanlan.zhihu.com/p/664389534
  • 2.https://zhuanlan.zhihu.com/p/24651968

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/653324.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

文献解读-群体基因组第一期|《对BMI的影响:探究BMI的基因型-环境效应》

关键词:应用遗传流行病学;群体测序;群体基因组;基因组变异检测; 文献简介 标题(英文):The Impact of ACEs on BMI: An Investigation of the Genotype-Environment Effects of BMI标…

python Windows电脑设置定时启动程序,定时运行代码

Windows设置定时 一,新建文件txt, .txt改为.bat 路径填exe的路径D:\test\main.py 如下是启动exe,如果运行python代码则写入如:python D:\test\main.py 二,搜索计算机管理 三,点击创建基本任务 填写任意名称 选择什么时候开始…

“智能体时代:探索无限可能——零代码构建智能教练智能体“

随着智能体技术的飞速发展,各个领域正经历着空前的变革和新的发展机遇。作为人工智能的一个关键组成部分,智能体以其自我驱动、智能响应和适应能力,逐渐深入到我们日常生活的各个层面,成为促进社会发展和科技进步的新引擎。 顺应这…

adb获取包名和界面名

adb获取包名和界面名 mac adb shell dumpsys window windows | grep mFocusedApp windows adb shell dumpsys window windows | findstr mFocusedApp 这个是在当前手机打开哪个界面获取的就是哪个界面的包名与界面 注意第一次连接时会有提示,需要连接两次才可以 …

免费,Python蓝桥杯等级考试真题--第15级(含答案解析和代码)

Python蓝桥杯等级考试真题–第15级 一、 选择题 答案:B 答案:D 解析:集合的并集运算有两种方式,一种是使用“|”运算符进行操作,另一种是使用union()方法来实现,故答案为D。 答案:A 解析&…

20212313 2023-2024-2 《移动平台开发与实践》第5次作业

20212313 2023-2024-2 《移动平台开发与实践》第5次作业 1.实验内容 设计并开发一个地图应用系统。 该实验需提前申请百度API Key,调用接口实现百度地图的定位功能、地图添加覆盖物和显示文本信息。 2.实验过程 2.1 获取SHA1 (1)打开控制台…

全网首发!精选32个最新计算机毕设实战项目(附源码),拿走就用!

Hi 大家好,马上毕业季又要开始了,陆陆续续又要准备毕业设计了,有些学生轻而易举就搞定了,有些学生压根没有思路怎么做,可能是因为技术问题,也可能是因为经验问题。 计算机毕业相关的设计最近几年类型比较多…

K8s的CRI机制是什么?

1. 概述 进入 K8s 的世界,会发现有很多方便扩展的 Interface,包括 CRI, CSI, CNI 等,将这些接口抽象出来,是为了更好的提供开放、扩展、规范等能力。 K8s CRI(Container Runtime Interface) 是 K8s 定义的一组与容器运行时进行交…

红酒与不同烹饪方法的食物搭配原则

红酒与食物的搭配是一门艺术,而不同烹饪方法的食物与红酒的搭配也有其与众不同之处。红酒与食物的搭配不仅涉及到口感、风味和营养,还与烹饪方法和食物质地等因素息息相关。云仓酒庄雷盛红酒以其卓着的品质和丰富的口感,成为了实现完善搭配的…

AI批量剪辑视频素材,高效混剪快速出片/矩阵发布,一键管理自媒体账号。

今天给大家分享一个超级好用的办公神器。特别是玩矩阵的企业,这款工具高效解决短视频剪辑问题。 这款软件可以帮你快速生产出1000条视频内容,而且还能把内容同步到多个平台账号上,多平台矩阵发布。 这款系统真的太棒了! 不仅操作简单,而且功能超强大。 …

回归自然:拥抱生态农业

在这个喧嚣的时代,我们渴望回归大自然的怀抱,享受那份纯净与安宁。广西生态农业,正是我们追寻自然、健康生活的理想选择。它摒弃了传统农业的弊端,采用环保、可持续的种植方式,为我们带来了绿色、无污染的农产品。生态…

面试八-存泄漏是什么,有哪几种,怎么解决?

一、内存泄漏几种情况 当使用基类指针指向派生类对象时,如果基类的析构函数不是虚函数,那么在使用基类指针来删除这个对象时,只会调用基类的析构函数,而不会调用派生类的析构函数。这就导致了派生类中的资源无法正确释放&#xff…

Typora图床配置优化(PicGo-Core(command line) 插件 + gitee)

Typora图床配置优化(PicGo-Core(command line) 插件 gitee) 前言 在日常使用Typora编写markdown笔记时,经常需要插入图片来帮助理解和整理逻辑。然而,由于图片保存在本地,上传到网上时经常出现图片不见或错误警告的…

工业LED显示屏汉字乱码方式的解决

目录 研究背景 解决方法 原因分析 尝试的解决方法 本质原因 写在最后 研究背景 想实现LED显示屏数字、字母、汉字均能正常显示的效果(效果如下)。在将UTF-8改为GB2312 编码之前,数字和字母不乱,但是汉字会乱码。 解决方法 1…

【Docker】Linux 系统(CentOS 7)安装 Docker

文章目录 对 VMware 软件的建议官方说明文档Docker安装卸载旧版本docker设置仓库开始安装 docker 引擎最新版 Docker 安装指定版本 Docker 安装(特殊需求使用) 启动 Docker查看 Docker 版本查看 Docker 镜像设置 Docker 开机自启动 验证开机启动是否生效…

据阿谱尔APO Research调研显示,2023年全球热喷涂涂料市场销售额约为110.37亿美元

根据阿谱尔 (APO Research)的统计及预测,2023年全球热喷涂涂料市场销售额约为110.37亿美元,预计在2024-2030年预测期内将以超过4.82%的CAGR(年复合增长率)增长。 热喷涂涂层是指将熔融或加热的金属、合金或陶瓷等材料喷…

ORCLE删除数据库文件

在实际操作中很少会去删除数据库文件,但是凡事都有例外,由于一些特殊原因,例如存储方式变化、磁盘空间不够等,需要调整和删除一些无效的数据库文件,本文介绍一下实践出来的一种删除数据库文件的操作方式。 删除前请对数…

室内也可以用北斗定位?还能用RTK?

室内卫星顾名思义,就是在室内有遮挡环境中的卫星定位技术,众所周知,目前全球几大GNSS定位系统已经很完善,但是GNSS有个致命的弱点,就是地面如果有遮挡就没有信号,在这样的条件下,在室内定位场景…

HTML大雪纷飞

目录 写在前面 HTML简介 完整代码 代码分析 运行结果 系列文章 写在后面 写在前面 小编又又又出现啦!这次小编给大家带来大雪纷飞HTML版,不需要任何的环境,只要有一个浏览器,就可以随时随地下一场大雪哦! HTM…

申请免费通配符SSL证书教程

申请免费通配符SSL证书的步骤相对直接,但需要注意的是免费且支持通配符的证书提供商较为有限,JoySSL是一个被多次提及提供此类服务的机构。以下是一个基于汇总信息的简明教程,帮助你申请免费的通配符SSL证书: 1. 准备工作 确认兼…