ToF原理记录

2024-06-13 14:20
文章标签 记录 原理 tof

本文主要是介绍ToF原理记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

    • 1. ToF是什么?
    • 2. ToF深度测量原理
      • 2.1 脉冲调制法
      • 2.2 连续波调制法

1. ToF是什么?

飞行时间(Time-of-Flight,ToF)基本原理是通过连续发射光脉冲(一般为不可见光)到目标物体上,然后接收从物体反射回来的光脉冲,通过探测光脉冲往返的飞行时间来计算被测物体的距离。其根据调制方法的不同,一般可分为两种:脉冲调制(Pulsed Modulation)和连续波调制(Continuous Wave Modulation)。

2. ToF深度测量原理

2.1 脉冲调制法

在这里插入图片描述

图1.脉冲调制法测距原理图

脉冲调制法一般采用方波脉冲,是通过计时器直接计算脉冲发射和接收的时间差,进而求得距离。这种测量方法简单,响应较快,但是对物理器件性能要求很高,对时间测量精度要求也较高。

在这里插入图片描述

在脉冲调制方案中,一般采用方波调制的照射光源,在数字电路中较容易实现。光探测器的每一个像素都是由一个将入射光转换为电流感光单元组成,连接2个由调解模块控制的开关(图3中的G0和G1)可以把电流导入不同的可以储存电荷的电容(图3中的C1和C2)里根据图2和图3可知,在测距过程中,当激光器发射光脉冲的同时,高频开关调到G1、光敏元件连接C1电容、产生相位A的脉冲窗口,C1电容开始接收电荷,一个光脉冲发射完毕,开关调到G0、光敏元件连接C2电容、产生另一个延迟相位B的脉冲窗口,C2电容开始接收电荷。根据电容C1和C2中各自存储的电荷量就可计算得到目标物体和ToF的距离。记光的速度为 c c c t p t_p tp为光脉冲的持续时间, Q 1 Q_1 Q1表示C1电容收集的电荷量, Q 2 Q_2 Q2表示C2电容收集的电荷量, t d t_d td表示光脉冲从发射、反射到被接收的飞行时间,则距离 d d d的计算如下:
t d = t p × Q 2 Q 1 + Q 2 t_d = t_p\times\frac{Q_2}{Q_1+Q_2} td=tp×Q1+Q2Q2

d = c × t d 2 d = \frac{c\times{t_d}}{2} d=2c×td

在实际场景中由于单个光脉冲的持续时间非常短,所以单帧测量时间内上面所述的发射、接收过程会重复几千次,直到达到曝光时间,将不同电容接收的电荷量进行积分,然后用上面公式的方法计算出脉冲飞行时间,从而得到目标距离

  • 最小可测量距离 d m i n d_{min} dmin:物体距离很近,光脉冲从发射到被反射接收的过程很快,在较早的采样周期内电容C1就收集了所有的电荷,而在延迟的采样周期内电容C2没有收集电荷,即 E 2 = 0 E_2=0 E2=0,代入公式会得到 d m i n = 0 d_{min}=0 dmin=0
  • 最大可测量距离 d m a x d_{max} dmax:物体距离远,较早的采样周期内光脉冲还没发射到接收器处,即电容C2收集了所有电荷,电容C1中根本没有收集到电荷。然后根据公式可得 d m a x = 0.5 × c × t p d_{max}=0.5\times{c}\times{t_p} dmax=0.5×c×tp,因此最大可测量距离是由光脉冲宽度决定的。例如, t p = 50 n s t_p=50ns tp=50ns,代入上式可得到 d m a x = 0.5 × ( 3 × 1 0 8 m / s ) × ( 5 × 1 0 − 8 s ) = 7.5 m d_{max}=0.5\times(3\times10^8m/s)\times(5\times10^{-8}s)=7.5m dmax=0.5×(3×108m/s)×(5×108s)=7.5m

🔔 相位模糊现象

下图中Case 1为正常情况下的脉冲ToF测距场景,但当测量距离较远,光脉冲飞行一个来回的时间超过了两次连续发射脉冲的间隔,传感器在发射第二个光脉冲后才接收到第一个光脉冲的反射波,就会把该反射波错认为是第二个光脉冲的近距离反射波,这时就会出现相位模糊现象,如Case 2。相位模糊现象会限制ToF的有效探测距离。在测量远距离物体时,可以适当降低测量频率、增加两次测量之间的距离、减少测量次数。但是,减少测量次数会同时降低测量精度,相当于是用精度换取有效探测距离。

在这里插入图片描述

这种方法对物理器件性能要求很高,控制开关的时钟精度要求非常高,要产生高精度、高重复性的高频脉冲,照射单元和ToF传感器均需要高速信号的控制,才能实现高精度的深度测量。

2.2 连续波调制法

在连续波调制法中,一般采用连续正弦波调制,通过光源不断发射调制过的红外激光,光束经被测物体表面反射后,有一部分光线按原路径返回并被探测器接收,由于发射、接收信号之间存在相位差,因此可以通过相位差检测技术间接地计算光的飞行时间差。

在这里插入图片描述

图4.连续波调制法测距原理图

与脉冲波调制不同的是,连续波调制法每次测量获取多个样本,每个样本之间相位差为90°,共采4个样本,分别是C1-C4,大部分的ToF都是使用这种方法,即4相法,这样在数字运算中比较容易实现。

在这里插入图片描述

假设发射的信号 s ( t ) s(t) s(t)的振幅是 A e A_e Ae,正弦波调制的频率是 f f f,经过 Δ t \Delta{t} Δt时间延迟之后收到的正弦信号为 r ( t ) r(t) r(t),光信号能量衰减后的振幅为 A r A_r Ar,由环境光、系统内部偏移引起的偏移为 B r B_r Br。连续波深度传感器发送的正弦波信号可以表示为:
s ( t ) = A e ( 1 + s i n ( 2 π f t ) ) s(t)=A_e(1+sin(2\pi{ft})) s(t)=Ae(1+sin(2πft))
信号 s ( t ) s(t) s(t)遇到目标物体会发生反射,有一部分光线沿原路径返回并被传感器所接收,会有一个相位延迟 Δ φ \Delta{\varphi} Δφ,因此反射后的信号可表示为:
r ( t ) = A r ( 1 + s i n ( 2 π f t − Δ φ ) ) + B r r(t)=A_r(1+sin(2\pi{ft}-\Delta{\varphi}))+B_r r(t)=Ar(1+sin(2πftΔφ))+Br
4次采样(C1-C4)时间间隔T/4,即采样时间分别为0,1/4T,1/2T,3/4T。所以4次采样所接收的信号可以表示为:
r i = r ( t ) = A r s i n ( 2 π f t − Δ φ ⏟ i π 2 − Δ φ ) + ( A r + B r ) , i = 0 , 1 , 2 , 3 r_i=r(t)=A_rsin(\underbrace{2\pi{ft}-\Delta{\varphi}}_{\frac{i\pi}{2}-\Delta{\varphi}})+(A_r+B_r),i=0,1,2,3 ri=r(t)=Arsin(2Δφ 2πftΔφ)+(Ar+Br),i=0,1,2,3
从而可以得到下列方程式:
{ r 2 − r 0 = A r s i n ( π − Δ φ ) − A r s i n ( − Δ φ ) = 2 A r s i n Δ φ r 1 − r 3 = A r s i n ( π 2 − Δ φ ) − A r s i n ( 3 π 2 − Δ φ ) = 2 A r c o s Δ φ \begin{cases} r_2-r_0=A_rsin(\pi-\Delta{\varphi})-A_rsin(-\Delta{\varphi})=2A_rsin\Delta{\varphi} \\ r_1-r_3=A_rsin(\frac{\pi}{2}-\Delta{\varphi})-A_rsin(\frac{3\pi}{2}-\Delta{\varphi})=2A_rcos\Delta{\varphi} \end{cases} {r2r0=Arsin(πΔφ)Arsin(Δφ)=2ArsinΔφr1r3=Arsin(2πΔφ)Arsin(23πΔφ)=2ArcosΔφ
从而计算出 Δ φ \Delta{\varphi} Δφ的值:
Δ φ = a r c t a n ( r 2 − r 0 r 1 − r 3 ) = a r c t a n ( Q 2 − Q 1 Q 3 − Q 4 ) \Delta{\varphi}=arctan\left(\frac{r_2-r_0}{r_1-r_3}\right)=arctan\left(\frac{Q_2-Q_1}{Q_3-Q_4}\right) Δφ=arctan(r1r3r2r0)=arctan(Q3Q4Q2Q1)
可以看出,电荷量 Q 3 − Q 4 Q_3-Q_4 Q3Q4 Q 2 − Q 1 Q_2-Q_1 Q2Q1可以抵消由测量器件或者环境光而引起的固定偏差,这二者的比值则可以消除距离测量中增益常量的影响,比如系统中的放大或衰减、或者反射的强度。由此也能计算得到测量距离:
d = c × Δ t 2 = c × Δ φ 4 π f d=\frac{c\times\Delta{t}}{2}=\frac{c\times{\Delta{\varphi}}}{4\pi{f}} d=2c×Δt=4πfc×Δφ
信号衰减后的振幅 A r A_r Ar和信号强度偏移 B r B_r Br可得:
{ A r = ( Q 3 − Q 4 ) 2 + ( Q 2 − Q 1 ) 2 2 B r = Q 1 + Q 2 + Q 3 + Q 4 4 − A r \begin{cases} A_r=\frac{\sqrt{(Q_3-Q_4)^2+(Q_2-Q_1)^2}}{2} \\ B_r=\frac{Q_1+Q_2+Q_3+Q_4}{4}-A_r \end{cases} {Ar=2(Q3Q4)2+(Q2Q1)2 Br=4Q1+Q2+Q3+Q4Ar

反射波振幅 A r A_r Ar与偏移 B r B_r Br会影响到深度测量精度,深度值方差可由下式进行估计:
σ = c 4 2 π f × A r + B r c d × A r \sigma=\frac{c}{4\sqrt{2}\pi{f}}\times{\frac{\sqrt{A_r+B_r}}{c_d\times{A_r}}} σ=42 πfc×cd×ArAr+Br
调制常量为 c d c_d cd,其表示ToF传感器分离和收集光电信号的好坏程度。由该方差公式可知,大幅度 A r A_r Ar、高调制频率 f f f和高的调制对比度(即低的 B r B_r Br,调制对比度指调制信号的最大振幅和最小振幅之间的比率, B r B_r Br可以影响调制对比度,环境光会增加背景噪声,从而降低调制对比度;系统内部偏移也会导致信号的失真,降低调制对比度,因此ToF系统需要适当的信号处理和校准来抵消这些影响)可以增加测量精度。此外,在高频的情况下,由于芯片硅半导体的特性,会导致调制对比度衰减。连续波调制的测量是基于相位的,每 2 π 2\pi 2π重复一次,距离会产生锯齿(相位模糊现象),而产生锯齿的距离被称为模糊距离,可用下面公式表示:
d a m b = c 2 f d_{amb}=\frac{c}{2f} damb=2fc
所以最大的有效观测距离就是 d a m b d_{amb} damb,若需要增加有效观测距离,和脉冲调制法一样的,需要减小调制的频率,同样这样会导致测量精度下降。但是,连续波ToF可以利用双频解决相位模糊现象,利用两个不同频率的测量数据去求解相位模糊度,从而恢复正确深度值。借助双频测量可以同时实现高精度测量和高有效探测距离

相对于脉冲波调制方案,连续波调制法要求更低而测量精度更高,因而大多数采用连续波调制法。


以上资料来自ToF与立体视觉技术相结合的三维重建方法研究_知网

这篇关于ToF原理记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1057551

相关文章

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

Servlet中配置和使用过滤器的步骤记录

《Servlet中配置和使用过滤器的步骤记录》:本文主要介绍在Servlet中配置和使用过滤器的方法,包括创建过滤器类、配置过滤器以及在Web应用中使用过滤器等步骤,文中通过代码介绍的非常详细,需... 目录创建过滤器类配置过滤器使用过滤器总结在Servlet中配置和使用过滤器主要包括创建过滤器类、配置过滤

正则表达式高级应用与性能优化记录

《正则表达式高级应用与性能优化记录》本文介绍了正则表达式的高级应用和性能优化技巧,包括文本拆分、合并、XML/HTML解析、数据分析、以及性能优化方法,通过这些技巧,可以更高效地利用正则表达式进行复杂... 目录第6章:正则表达式的高级应用6.1 模式匹配与文本处理6.1.1 文本拆分6.1.2 文本合并6

python与QT联合的详细步骤记录

《python与QT联合的详细步骤记录》:本文主要介绍python与QT联合的详细步骤,文章还展示了如何在Python中调用QT的.ui文件来实现GUI界面,并介绍了多窗口的应用,文中通过代码介绍... 目录一、文章简介二、安装pyqt5三、GUI页面设计四、python的使用python文件创建pytho

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

hdu4407(容斥原理)

题意:给一串数字1,2,......n,两个操作:1、修改第k个数字,2、查询区间[l,r]中与n互质的数之和。 解题思路:咱一看,像线段树,但是如果用线段树做,那么每个区间一定要记录所有的素因子,这样会超内存。然后我就做不来了。后来看了题解,原来是用容斥原理来做的。还记得这道题目吗?求区间[1,r]中与p互质的数的个数,如果不会的话就先去做那题吧。现在这题是求区间[l,r]中与n互质的数的和

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

hdu4407容斥原理

题意: 有一个元素为 1~n 的数列{An},有2种操作(1000次): 1、求某段区间 [a,b] 中与 p 互质的数的和。 2、将数列中某个位置元素的值改变。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.Inpu

hdu4059容斥原理

求1-n中与n互质的数的4次方之和 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.io.PrintWrit

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓