07 Laser Sensor Vl53l1x Driver

一、硬件介绍

1. VL53L0X介绍

VL53L0X

VL53L0X 芯片内部集成了激光发射器和 SPAD 红外接收器,采用了第二代FightSenseTM 技术,通过接收器所接收到的光子时间来计算距离,最远测量距离可达两米,适合中短距离测量的应用.

  • VL53L0X传感器有3-4cm的盲区,有效测量范围3cm-200cm,精度+-3%

  • VL53L0X芯片IO电压为2.8V,3.3V供电需要串联120R电阻

  • 响应频率20ms(最快),误差+-5%

VL53L0X精度模式

2. VL53L1X介绍

在这里插入图片描述

VL53L1X是VL53L0X的升级版本,感光部分面积明显增大,有更远的探测距离,参数如下:

VL53L1X

3. VL53L1X典型电路

vl53l1x pinmap
vl53l1x典型电路
  • XSHUT为输入引脚,用于模式选择(休眠),需要上拉电阻放置漏电流

  • GPIO1为中断输出引脚,用于输出测量dataready中断

  • 为了达到极限传输率(400khz),上拉电阻需要根据电压和总线电容值选择,可以参见vl53l1x datasheet

4. VL53L0X与VL53L1X区别?

VL53L0X为2m测距版本,VL53L1X为4m版本.目前测试发现,这两颗芯片并不只是性能区别,官方给出的是两套库,不能相互通用.仔细阅读芯片手册甚至调用API的配置过程也是不同的,需要特别注意一下手中的芯片是哪个版本,然后对应的去找官网的库文件.

二、移植过程介绍

1. 官方库文件如何使用?

除了数据手册,我们还能从ST官方下载一个软件开发包,这里面包含了所有官方的API,和基于STM32的示例程序.

  1. VL53L1X软件包下载地址:X-CUBE-53L1A1:The X-CUBE-53L1A1 software package

  2. 解压后,依次进入 Drivers->BSP->Components->vl53l1x ,这里的所有文件我们都要复制到自己的工程,我们可以新建一个文件夹/vl53l1x/core存放.这里是与硬件无关的基础文件,是不需要任何改动的

在这里插入图片描述
  1. 以上源文件还不够,还有一部分是与硬件相关的文件和用户配置文件,我们可以打开一个示例工程,复制到自己工程的/vl53l1x/platform目录.这些文件路径比较长,可以看以下图片找到.

在这里插入图片描述
在这里插入图片描述

2. 如何移植到ESP32?

拿到官方库文件后,如果想移植VL53L1X到ESP32等平台,需要实现以下底层函数 .这些函数声明在vl53l1_platform.h,需要在vl53l1_platform.c中编写实现

感谢kazkojima在github上分享的移植代码,链接 这个工程下载下来并不能工作,还需要下载官方库文件,做少许的修改.我进行了进一步的修改:链接

同理VL53L0X需要移植以下函数

3. vl53l1x模式选择与启动顺序

根据XSHUT引脚的输入电平,可以切换传感器HW Standby模式和SW Standby模式.如果主机不管理传感器模式,XSHUT应该被上拉为高电平.

This option optimizes power consumption as the VL53L1X can be completely powwhen not used, and then woken up through a host GPIO (using the XSHUT pin).

  • HW Standby :XSHUT拉低时,传感器电源被关闭

  • SW Standby :XSHUT拉高,进入boot和SW Standby 模式

HW Standby
SW Standby

4. 使用官方API校准传感器

校准流程:调用顺序要完全一致.官方流程图缺少一步:在绿色校准函数调用前需要VL53L1_SetPresetMode !!!

vl53l1x校准流程图

5. 使用官方GUI程序校准传感器

调试了一周,遇到了无数的坑,大部分都是卡在初始化和校准阶段,很难处理.偶然发现官方还有用于配置和显示的GUI程序,相见恨晚啊.目前只有windows版本(需要配合官方硬件 STM32F401RE nucleo board 连接传感器使用).使用软件校准得到基准值后,初始化时填入的即可.如果使用API自己编写校准程序,非常容易出错,如下错误排查1.

STSW-IMG008

STSW-IMG008:Windows Graphical User Interface (GUI) for VL53L1X Nucleo packs. Works with P-NUCLEO-53L1A1

STSW-IMG008

三、测试代码分析

1. 初始化

  • 以上初始化步骤除VL53L1_SetUserROI,其余不可少

  • PerformRefSpadManagement等初始化函数用在VL53L1上会报错,不明原因(已解决,见上面校准流程图提示).

  • roi 配置参见2.4 ranging description 2.8 Sensing array optical center

在这里插入图片描述

2. 轮寻测量

测量流程图:

vl53l1x校准流程图

轮训测量有两种方法,如上图所示,一种是阻塞方式(drivers polling mode),一种是非阻塞方式(Host polling mode),下图展示了阻塞方式的测量.

3. 中断测量模式

中断测量模式

其实这种模式和轮训测量没什么大的区别,因为轮训测量也要进行清除中断标志的操作,只是通知的方式不一样.

4. 传感器校准

github源码:https://github.com/qljz1993/esp32-vl53l1x-test

四、 错误排查

1. 激光测量的潜在问题

  1. tof镜头检测的并不是到一个点的距离,而是一个椎体中的最短距离,这会导致一个问题,当飞行器靠近墙面飞行,返回的可能不是到地板的距离,而是到墙面的距离.

  2. 飞行器定高时,测距模式为长距离模式,要求在黑暗无红外光的环境,在室外强光下,激光传感器会受到很大的干扰,导致测量精度降低,在室外依旧建议气压定高.

在这里插入图片描述

2. 提示timeout

五、ESP32+VL53L1x例程

1. 例程说明

  1. 实现功能:通过VL53L1x 检测到高度变化(持续一秒),红灯亮起.高度恢复正常值(持续一秒),绿灯亮起.

  2. 可配置参数:通过make menuconfig 设置I2C 号码、端口号、LED端口号

  3. 例程解析见代码注释与用户手册

2. 注意事项

  1. 该例程只适用于VL53L1x,寄送的传感器为该型号.VL53L0x为老版本硬件,不适用本例程.

  2. 官方标称400cm测量距离,为黑暗环境下测得.室内正常灯光环境,可以保证10cm-260cm范围的有效测量

  3. 初始化函数vl53l1_init(VL53L1_Dev_t *) 中部分参数,需要根据实际使用环境确定,还有优化的空间.

  4. 传感器安装位置应确保在检测位置正上方

  5. 模块上电时自动矫正基准高度,如果基准高度有变化,需要重新上电重置参数

3. 例程链接

点击进入下载:esp32-vl53l1x-test 或者:

最后更新于

这有帮助吗?