概述
"自主模式"(Autonomous mode)通常指的是設備或系統(tǒng)能夠在沒有外部輸入的情況下獨立完成任務。對于傳感器,如VL53L5,自主模式可能意味著傳感器可以獨立、定期地進行測量,而不需要來自主控制器或主機的每一次單獨指令。
最近在弄ST的課程,需要樣片的可以加群申請:615061293 。
選擇使用自主模式的原因可能包括:
簡化控制:一旦配置完成,傳感器可以獨立工作,減少主控制器與傳感器之間的通信需求。
穩(wěn)定的測量頻率:在自主模式下,傳感器可以以固定的頻率進行測量,從而確保數(shù)據(jù)的穩(wěn)定性和連續(xù)性。
減少響應延遲:由于傳感器持續(xù)地或定期地進行測量,數(shù)據(jù)可能會更快地準備好,從而減少了從請求到獲取數(shù)據(jù)的延遲。
主控制器工作量減少:主控制器可以被釋放出來執(zhí)行其他任務,而不是持續(xù)地向傳感器發(fā)送測量命令。
低功耗應用:對于某些傳感器,自主模式可能更加能效,因為它可以在測量之間進入低功耗狀態(tài)。
實現(xiàn)預定任務:自主模式允許傳感器在特定條件下執(zhí)行預定的任務,例如當檢測到某個特定值時觸發(fā)警報。
然而,是否使用自主模式取決于特定的應用需求。有些應用可能更傾向于連續(xù)模式,其中主控制器更頻繁地與傳感器交互,以獲得實時數(shù)據(jù)或更高的控制精度。
視頻教學
[https://www.bilibili.com/video/BV1xc411d79n/](
樣品申請
[https://www.wjx.top/vm/OhcKxJk.aspx#]
源碼下載
[https://download.csdn.net/download/qq_24312945/88482187]
自主模式與連續(xù)模式區(qū)別
VL53L5CX 傳感器的自主模式 (AUTONOMOUS) 和連續(xù)模式 (CONTINUOUS) 都允許連續(xù)的測量操作,但它們的工作方式和使用場景略有不同:
連續(xù)模式 (CONTINUOUS):
● 在此模式下,傳感器連續(xù)進行測量,每次測量后,就會產生一個新的結果。
● 傳感器會盡可能快地測量,基于所設置的時間預算。
● 主機通常需要周期性地從傳感器中讀取數(shù)據(jù)。
● 適用于需要高更新率或實時響應的應用。
自主模式 (AUTONOMOUS):
● 傳感器獨立地進行測量,而無需主機的常規(guī)干預。
● 主機可以進入低功耗休眠模式,而傳感器仍然獨立地執(zhí)行測量。當傳感器完成測量時,它可以通過中斷喚醒主機,通知它讀取數(shù)據(jù)。
● 這種模式特別適用于低功耗應用,因為大部分時間主機可以處于休眠狀態(tài)。
● 這種模式可能與設置的測量頻率或時間間隔一起使用,以確定傳感器執(zhí)行測量的頻率。
總的來說,選擇哪種模式取決于應用的需求。如果需要實時的高更新率數(shù)據(jù),則連續(xù)模式可能更合適;而對于低功耗或不需要實時數(shù)據(jù)的應用,自主模式可能是更好的選擇。
硬件準備
首先需要準備一個開發(fā)板,這里我準備的是自己繪制的開發(fā)板,需要的可以進行申請。
串口配置
查看原理圖,PB14和PB15設置為開發(fā)板的串口。
配置串口。
IIC配置
在這個應用中,VL53L5CX模塊通過I2C(IIC)接口與主控器通信。具體來說,VL53L5CX模塊的I2C引腳連接到主控器的PC8和PC9兩個IO口。
配置IIC為快速模式,速度為400k。
INT設置
自主模式可以通過獲取INT管腳進行判斷數(shù)據(jù)是否準備好。
配置PA8為輸入模式。
配置使能與復位
驅動中有對模塊進行復位的操作。
配置PC7和PA9為輸出管腳。
X-CUBE-TOF1
本節(jié)介紹在不需要使用樣例應用時如何使用STM32CubeMX將X-CUBE-TOF1軟件包添加到項目中。有了這樣的設置,就只配置了驅動層。
由于需要自主模式,所以可以不開啟主程序TOF執(zhí)行代碼。
串口重定向
打開魔術棒,勾選MicroLIB
在main.c中,添加頭文件,若不添加會出現(xiàn) identifier "FILE" is undefined報錯。
/* USER CODE BEGIN Includes */
#include "stdio.h"
/* USER CODE END Includes */
函數(shù)聲明和串口重定向:
/* USER CODE BEGIN PFP */
int fputc(int ch, FILE *f){
HAL_UART_Transmit(&huart1 , (uint8_t *)&ch, 1, 0xFFFF);
return ch;
}
/* USER CODE END PFP */
代碼配置
在custom_ranging_sensor.c代碼中,有IO口驅動VL53L5CX進行復位的代碼,由于沒有配置對應的IO,所以需要注釋掉。
由于沒加載串口定義,所以注釋掉#include "custom.h"
TOF代碼配置
在main.c中添加刷新速率,500ms刷新一次,所以頻率為2Hz。
/* USER CODE BEGIN Includes */
#include "lcd_init.h"
#include "lcd.h"
#include "pic.h"
#include "stdio.h"
#include "custom_ranging_sensor.h"
#define TIMING_BUDGET (5U) /* 5 ms < TimingBudget < 1000 ms */
#define RANGING_FREQUENCY (200U) /* Ranging frequency Hz (shall be consistent with TimingBudget value) */
#define POLLING_PERIOD (1000U/RANGING_FREQUENCY) /* refresh rate for polling mode (milliseconds) */
/* USER CODE END Includes */
函數(shù)與變量定義:
/* USER CODE BEGIN PFP */
int fputc(int ch, FILE *f){
HAL_UART_Transmit(&huart1 , (uint8_t *)&ch, 1, 0xFFFF);
return ch;
}
static uint8_t map_target_status(uint8_t status);
//將從VL53L5CX傳感器獲取的數(shù)據(jù)轉換
static int32_t convert_data_format(VL53L5CX_Object_t *pObj,VL53L5CX_ResultsData *data, RANGING_SENSOR_Result_t *pResult);
//打印數(shù)據(jù)
static void print_result(RANGING_SENSOR_Result_t *Result);
static RANGING_SENSOR_ProfileConfig_t Profile;
static int32_t status = 0;
static RANGING_SENSOR_Result_t Result;
/* USER CODE END PFP */
添加TOF初始化。
若需要為8*8,修改對應vl53l5cx_set_resolution參數(shù)即可。
其中vl53l5cx_set_integration_time_ms和vl53l5cx_set_ranging_frequency_hz加載了對應的刷新速率。
/* USER CODE BEGIN 2 */
LCD_Init();//LCD初始化
LCD_Fill(0,0,320,480,RED) ;
LCD_Fill(0,0,320,480,WHITE) ;
LCD_ShowString(0,0,"MCU:STM32H503RBT6",BLACK,WHITE,32,0);
LCD_ShowString(0,32,"TOF:VL53L5CX",BLACK,WHITE,32,0);
LCD_ShowString(0,64,"MODE: ",BLACK,WHITE,32,0); ;
//
LCD_ShowChinese32x32(96,64,"自",BLACK,WHITE,32,0);
LCD_ShowChinese32x32(128,64,"主",BLACK,WHITE,32,0);
LCD_ShowChinese32x32(160,64,"模",BLACK,WHITE,32,0);
LCD_ShowChinese32x32(192,64,"式",BLACK,WHITE,32,0);
HAL_Delay(500);
/*********************************/
/* Set ranging mode autonomous */
/*********************************/
VL53L5CX_Object_t *pL5obj = CUSTOM_RANGING_CompObj[CUSTOM_VL53L5CX];
static VL53L5CX_ResultsData data;
uint8_t NewDataReady = 0;
// 設置測距的配置文件為 4x4 的連續(xù)測量模式
Profile.RangingProfile = RS_PROFILE_8x8_CONTINUOUS;
// 設置測量的時間預算,這通常決定了測量的速度和準確度
Profile.TimingBudget = TIMING_BUDGET; /* 5 ms < TimingBudget < 1000 ms */
// 設置測量的頻率,這決定了傳感器執(zhí)行測量的速率
Profile.Frequency = RANGING_FREQUENCY; /* Ranging frequency Hz (shall be consistent with TimingBudget value) */
// 確定是否啟用環(huán)境光測量,0為禁用,1為啟用
Profile.EnableAmbient = 0; /* Enable: 1, Disable: 0 */
// 確定是否啟用信號測量,0為禁用,1為啟用
Profile.EnableSignal = 0; /* Enable: 1, Disable: 0 */
pL5obj- >IsAmbientEnabled = Profile.EnableAmbient;
pL5obj- >IsSignalEnabled = Profile.EnableSignal;
/*
use case VL53L5CX_PROFILE_4x4_CONTINUOUS:
*/
// 設置傳感器的測量分辨率為 4x4
status = vl53l5cx_set_resolution(&(pL5obj- >Dev), VL53L5CX_RESOLUTION_8X8);
// 設置傳感器的測量模式為自主模式
status |= vl53l5cx_set_ranging_mode(&(pL5obj- >Dev), VL53L5CX_RANGING_MODE_AUTONOMOUS);
// 設置傳感器的集成時間,這通常關聯(lián)到測量的時間預算
status |= vl53l5cx_set_integration_time_ms(&(pL5obj- >Dev), TIMING_BUDGET);
// 設置傳感器的測量頻率,決定了傳感器執(zhí)行測量的速率
status |= vl53l5cx_set_ranging_frequency_hz(&(pL5obj- >Dev), RANGING_FREQUENCY);
if (status != VL53L5CX_STATUS_OK)
{
printf("ERROR : Configuration programming error!nn");
while (1);
}
status = vl53l5cx_start_ranging(&(pL5obj- >Dev));
if (status != VL53L5CX_STATUS_OK)
{
printf("vl53l5cx_start_ranging failedn");
while (1);
}
/* USER CODE END 2 */
積分時間/曝光時間(Integration time)
積分時間是一項僅在使用自主測距模式時可用的功能(請參閱第 4.5 節(jié)測距模式)。 它允許用戶在啟用 VCSEL 時更改時間。 如果測距模式設置為連續(xù),則更改積分時間無效。 默認積分時間設置為 5 ms。
對于 4x4 和 8x8 分辨率,積分時間的影響是不同的。 分辨率 4x4 由一個積分時間組成,8x8 分辨率由四個積分時間組成。 下圖表示兩種分辨率的 VCSEL 發(fā)射。
所有積分時間之和 + 1 ms 開銷必須低于測量周期,否則測距周期將自動增加。
主程序
主程序來獲取對應的INT位狀態(tài)來判定數(shù)據(jù)是否準備好。
/* Infinite loop */
/* USER CODE BEGIN WHILE */
while (1)
{
/* polling mode */
if(HAL_GPIO_ReadPin ( GPIOA, GPIO_PIN_8) ==0)
{
do {
(void)vl53l5cx_check_data_ready(&(pL5obj- >Dev), &NewDataReady);
} while (!NewDataReady);
if (NewDataReady != 0)
{
status = vl53l5cx_get_ranging_data(&(pL5obj- >Dev), &data);
if (status == VL53L5CX_STATUS_OK)
{
/*
Convert the data format to Result format.
Note that you can print directly from data format
*/
if (convert_data_format(pL5obj, &data, &Result) < 0)
{
printf("convert_data_format failedn");
while (1);
}
print_result(&Result);
}
}
}
uint32_t colour=0;
if(LCD_flag)
{
LCD_flag=0;
uint8_t H,L;
for(int i=0;i< 64;i++)
{
H=7-i/8;
L=7-i%8;
if(tof_data[i]< 500)
{
LCD_ShowIntNum(L*40,H*40+160,tof_data[i],5,WHITE,RED,16);
LCD_Fill(L*40,H*40+160+16,L*40+40,H*40+160+40, RED);
}
else if(tof_data[i] >=500&&tof_data[i]< 700)
{
LCD_ShowIntNum(L*40,H*40+160,tof_data[i],5,WHITE,GREEN,16);
LCD_Fill(L*40,H*40+160+16,L*40+40,H*40+160+40, GREEN);
}
else if(tof_data[i] >=700&&tof_data[i]< 9000)
{
LCD_ShowIntNum(L*40,H*40+160,tof_data[i],5,WHITE,BLACK,16);
LCD_Fill(L*40,H*40+160+16,L*40+40,H*40+160+40, BLACK);
}
else
{
LCD_ShowString(L*40,H*40+160," X ",WHITE,BLACK,16,0);
LCD_Fill(L*40,H*40+160+16,L*40+40,H*40+160+40, BLACK);
}
}
}
/* USER CODE END WHILE */
/* USER CODE BEGIN 3 */
}
/* USER CODE END 3 */
狀態(tài)說明
正常的數(shù)據(jù)返回狀態(tài)為5,為了保持數(shù)據(jù)一致,用戶需要過濾無效的目標器狀態(tài)。為了給出信心評級,狀態(tài)為5的目標被認為是100%有效的。6或9的狀態(tài)可以用50%的置信度來考慮。所有其他狀態(tài)都低于50%置信度。
演示結果
-
STM32
+關注
關注
2264文章
10854瀏覽量
354286 -
LCD顯示
+關注
關注
0文章
132瀏覽量
18337 -
TOF
+關注
關注
9文章
475瀏覽量
36224
發(fā)布評論請先 登錄
相關推薦
評論