stm32蓝牙控制循迹避障小车源代码——3.舵机、超声波测距模块
时间: 2023-09-08 13:02:56 浏览: 295
舵机和超声波测距模块是STM32蓝牙控制循迹避障小车中常用的两个重要组件。
首先,舵机用于控制小车的转向。舵机通过PWM信号控制电机的转动角度,通过改变PWM信号的占空比,可以实现不同的转向角度。通常情况下,舵机的控制信号需要与STM32的定时器模块相连,通过调整定时器的周期和占空比,可以控制舵机的转向角度。在源代码中,通常会包括一些函数用于控制舵机的转向,如设置舵机转动角度等。
其次,超声波测距模块用于检测小车前方的障碍物距离。超声波测距模块通过发射超声波脉冲,然后检测超声波脉冲的回波时间,从而计算出前方障碍物的距离。在源代码中,通常会包括一些函数用于控制超声波测距模块的工作方式,如初始化超声波模块、发送超声波脉冲、接收回波信号等。
舵机和超声波测距模块是实现循迹避障功能的关键组件之一。在源代码中,我们需要同时处理舵机和超声波测距模块的数据,并根据测距结果调整舵机的转向角度。通过不断的测距和调整转向角度,小车可以根据前方障碍物的距离来做出合适的转向动作,从而实现循迹和避障的功能。
在实际应用中,舵机和超声波测距模块的代码通常需要与其他组件的代码进行协调和集成,以实现整个小车的控制逻辑。通过合理的编程和调试,我们可以使得小车根据测距结果和算法判断,实现自动避障和循迹控制的功能。
相关问题
基于STM32F103C8T6的超声波循迹避障小车
<think>我们正在设计一个基于STM32F103C8T6的超声波循迹避障小车。根据引用资料,我们可以将设计分为几个部分:硬件连接、舵机控制(用于超声波转向)、超声波测距、电机驱动以及循迹模块。下面将逐步说明设计过程。
### 1. 硬件组成
- **主控芯片**:STM32F103C8T6(最小系统板)
- **超声波模块**:HC-SR04,用于避障测距
- **舵机**:SG90,用于控制超声波模块的转向(实现多方向测距)
- **电机驱动模块**:L298N,驱动直流电机
- **循迹模块**:红外对管,用于检测地面黑线
- **电源**:18650锂电池(7.4V)或USB供电(5V)
### 2. 舵机控制(SG90)
根据引用[2],舵机控制需要20ms周期的PWM信号,高电平时间在0.5ms~2.5ms之间对应0°~180°。因此,我们需要配置STM32的定时器产生PWM波。
**关键参数**:
- 定时器时钟频率:72MHz(假设系统时钟为72MHz)
- PWM周期:20ms(50Hz)
- PWM分辨率:定时器计数周期 = 20ms / (1/72MHz) = 1,440,000个计数周期。但定时器是16位的,最大65535,因此需要分频。
**配置步骤**:
1. 设置预分频器(Prescaler)和自动重装载值(Auto-reload Register, ARR)以产生50Hz的PWM。
- 例如:预分频系数设为72-1,则定时器时钟为1MHz(72MHz/72=1MHz)。
- 周期20ms对应计数值:20ms / (1/1MHz) = 20000。
- 所以ARR=19999(因为从0开始计数)。
2. 设置捕获/比较寄存器(CCR)的值来控制高电平时间。例如,要设置90°(中位):
- 高电平时间1.5ms,则CCR = 1500(因为1.5ms/1us=1500)。
3. 初始化定时器并输出PWM到舵机信号线。
示例代码(使用HAL库):
```c
// 初始化TIM3,通道1(PA6)输出PWM
TIM_HandleTypeDef htim3;
TIM_OC_InitTypeDef sConfigOC = {0};
htim3.Instance = TIM3;
htim3.Init.Prescaler = 72-1; // 72分频,1MHz
htim3.Init.CounterMode = TIM_COUNTERMODE_UP;
htim3.Init.Period = 20000-1; // 20ms周期
htim3.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
HAL_TIM_PWM_Init(&htim3);
sConfigOC.OCMode = TIM_OCMODE_PWM1;
sConfigOC.Pulse = 1500; // 初始位置90°
sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
HAL_TIM_PWM_ConfigChannel(&htim3, &sConfigOC, TIM_CHANNEL_1);
HAL_TIM_PWM_Start(&htim3, TIM_CHANNEL_1);
```
### 3. 超声波模块(HC-SR04)
超声波模块有4个引脚:VCC、GND、Trig(触发)、Echo(回响)。工作流程:
1. 向Trig引脚发送至少10us的高电平触发信号。
2. 模块自动发送8个40kHz的超声波脉冲,并检测回波。
3. 通过Echo引脚输出高电平,高电平持续时间即为超声波往返时间。
**距离计算**:
- 距离 = (高电平时间 * 声速) / 2 = (高电平时间 * 340m/s) / 2
- 注意:高电平时间单位为秒,实际使用微秒,所以:距离(cm)= (高电平时间(us) * 0.034) / 2 = 高电平时间(us) / 58.0
**代码实现**:
使用一个GPIO触发,另一个GPIO(或同一引脚)接收回响(可用输入捕获或外部中断+定时器测量高电平时间)。
示例代码(使用输入捕获):
```c
// 初始化定时器用于输入捕获(例如TIM2)
// 配置Trig引脚(输出)和Echo引脚(输入捕获)
void trigger_ultrasonic(void) {
HAL_GPIO_WritePin(Trig_GPIO_Port, Trig_Pin, GPIO_PIN_SET);
delay_us(10);
HAL_GPIO_WritePin(Trig_GPIO_Port, Trig_Pin, GPIO_PIN_RESET);
}
// 在输入捕获中断中测量高电平时间
// 具体实现略(可参考HAL库的输入捕获例程)
```
### 4. 电机驱动(L298N)
L298N模块可驱动两个直流电机。控制方式:
- 使能端(ENA, ENB):接PWM可调速
- 输入引脚(IN1, IN2, IN3, IN4):控制电机转向
**电机控制真值表**(以左边两个引脚控制一个电机为例):
| IN1 | IN2 | 电机状态 |
|-----|-----|----------|
| 0 | 0 | 停止 |
| 1 | 0 | 正转 |
| 0 | 1 | 反转 |
| 1 | 1 | 停止(刹车) |
**代码实现**:
配置两个PWM通道控制使能端(调速),配置4个GPIO控制方向。
### 5. 循迹模块
通常使用4路或5路红外循迹模块。每个通道包括一个红外发射管和一个接收管。当遇到黑线时,红外被吸收,接收管输出高电平(或低电平,取决于模块设计)。
**循迹逻辑**:
- 根据多个传感器的状态判断小车位置(例如:中间两个传感器检测到黑线则直行,左边检测到则左转等)。
### 系统设计整合
1. **初始化**:配置系统时钟、GPIO、定时器(PWM、输入捕获)、ADC(如果需要)等。
2. **主循环**:
- 读取循迹模块状态,控制电机转向以跟随黑线。
- 使用舵机旋转超声波模块(例如0°、90°、180°)进行多方向测距。
- 根据超声波测距结果避障:当前方距离小于阈值时,停止并转向避开障碍物。
- 结合循迹和避障,实现复杂路径的导航。
**注意**:避障优先级高于循迹,即检测到障碍物时优先避障。
### 示例主循环框架
```c
while (1) {
// 1. 循迹控制
track_status = read_track_sensors();
control_motor_by_track(track_status); // 根据循迹结果控制电机
// 2. 避障控制(每200ms检测一次)
current_time = HAL_GetTick();
if (current_time - last_ultrasonic_time >= 200) {
last_ultrasonic_time = current_time;
// 旋转舵机到不同角度并测距
set_servo_angle(90); // 向前
distance_front = get_ultrasonic_distance();
if (distance_front < SAFE_DISTANCE) {
// 前方有障碍,停止并转向
stop_motors();
// 旋转舵机向左和向右检测,决定转向方向
set_servo_angle(180);
distance_left = get_ultrasonic_distance();
set_servo_angle(0);
distance_right = get_ultrasonic_distance();
set_servo_angle(90); // 回正
if (distance_left > distance_right) {
turn_left(); // 向左转避开
} else {
turn_right(); // 向右转避开
}
// 避开后继续循迹
}
}
}
```
### 注意事项
- 电源管理:电机启动时电流较大,可能导致电压波动,建议使用稳压模块。
- 中断优先级:超声波输入捕获中断和系统定时器中断的优先级设置需合理。
- 调试:可通过串口打印调试信息。
§§相关问题§§
1. 如何优化超声波测距的准确性和抗干扰能力?
2. 在STM32中如何实现多任务调度(如循迹、避障、舵机控制)?
3. 如何对循迹避障小车进行PID速度控制?</think>### 基于STM32F103C8T6的超声波循迹避障小车设计与实现
#### 1. 系统架构设计
- **核心控制器**:STM32F103C8T6(72MHz主频,64KB Flash,20KB RAM)
- **感知层**:
- 超声波模块(HC-SR04):障碍物检测(2cm~400cm)
- 红外循迹模块(TCRT5000):地面黑线识别
- SG90舵机:控制超声波旋转扫描(0°~180°)
- **执行层**:
- L298N电机驱动:控制直流电机
- 直流减速电机(带编码器可选)
- **供电系统**:7.4V锂电池 + AMS1117稳压模块(5V/3.3V)
- **控制逻辑**:
```mermaid
graph TD
A[主控STM32F103C8T6] --> B[循迹模块]
A --> C[超声波避障]
A --> D[舵机控制]
A --> E[电机驱动]
C --> F{障碍距离<15cm?}
F -->|是| G[转向避障]
F -->|否| H[继续循迹]
```
#### 2. 硬件连接关键点
| 模块 | STM32引脚 | 说明 |
|-------------|---------------|--------------------------|
| 超声波Trig | PA1 | 触发信号输出 |
| 超声波Echo | PA2 | 回波信号输入(EXTI中断) |
| SG90舵机 | PA6(TIM3CH1)| PWM控制(周期20ms) |
| L298N ENA | PA7(TIM1CH1)| 左轮PWM调速 |
| L298N IN1/2 | PB0/PB1 | 左轮方向控制 |
| TCRT5000 | PB12-PB15 | 4路红外循迹信号 |
> 注:舵机PWM参数:0.5ms(0°) ~ 2.5ms(180°),对应CCR=500~2500(72MHz/72分频)[^2]
#### 3. 超声波避障实现
**测距流程**:
1. Trig发送10us高电平触发
2. 检测Echo高电平持续时间$t$
3. 计算距离:$d = \frac{t \times 340}{2} \times 10^{-4} \text{cm}$
($t$单位:μs)
**多方向扫描代码**:
```c
void obstacle_scan() {
set_servo(90); // 正前方
float front_dist = get_distance();
if(front_dist < 15) {
set_servo(180); // 向左扫描
float left_dist = get_distance();
set_servo(0); // 向右扫描
float right_dist = get_distance();
// 选择安全方向
(left_dist > right_dist) ? turn_left() : turn_right();
}
}
```
#### 4. 循迹算法设计
**红外传感器布局**:
```
[左2] [左1] [右1] [右2] → 4路数字输入
```
**控制逻辑**:
| 传感器状态 | 动作 | PWM调整 |
|------------|------------|---------------|
| 0100 | 轻微左偏 | 左轮70%,右轮100% |
| 0010 | 轻微右偏 | 左轮100%,右轮70% |
| 1100 | 急左转 | 左轮反转,右轮正转 |
| 0011 | 急右转 | 左轮正转,右轮反转 |
| 0110 | 直行 | 双轮100% |
> 注:1=检测到黑线,0=未检测
#### 5. 电机控制优化
```c
// 带加减速的电机控制
void motor_ctrl(uint8_t dir, uint16_t pwm) {
static uint16_t current_pwm = 0;
// 斜坡加速
while(current_pwm < pwm) {
current_pwm += 5;
__HAL_TIM_SET_COMPARE(&htim1, TIM_CHANNEL_1, current_pwm);
HAL_Delay(10);
}
// 方向控制
if(dir == FORWARD) {
HAL_GPIO_WritePin(IN1_GPIO_Port, IN1_Pin, GPIO_PIN_SET);
HAL_GPIO_WritePin(IN2_GPIO_Port, IN2_Pin, GPIO_PIN_RESET);
}
// ...其他方向类似
}
```
#### 6. 系统整合与调试
**主循环逻辑**:
```c
int main() {
HAL_Init();
SystemClock_Config();
MX_GPIO_Init();
MX_TIM1_Init(); // 电机PWM
MX_TIM3_Init(); // 舵机PWM
while(1) {
track_status = read_track_sensors(); // 读取4路循迹
motor_adjust(track_status); // 电机调整
if(cycle_count % 10 == 0) { // 每10周期避障检测
obstacle_scan();
}
cycle_count++;
HAL_Delay(50); // 20Hz控制频率
}
}
```
**调试技巧**:
1. 使用串口打印实时距离:`printf("Dist: %.1fcm\n", distance);`
2. 用LED指示传感器状态:`HAL_GPIO_WritePin(LED_GPIO_Port, LED_Pin, sensor_state);`
3. 通过可变电阻调节红外灵敏度
#### 7. 关键问题解决
- **超声波干扰**:添加30ms测量间隔,多次采样取中值
- **电机干扰**:在VCC并联100μF电容,信号线加磁环
- **舵机抖动**:PWM信号线远离电机电源线
- **循迹误判**:地面光照补偿算法:
$$ \text{阈值} = \frac{\text{白区值} + \text{黑线值}}{2} + 10\% $$
> 完整工程建议采用模块化设计:
> - `ultrasonic.c/h`:超声波驱动
> - `motor.c/h`:电机控制
> - `tracking.c/h`:循迹算法
> - `servo.c/h`:舵机控制
stm32智能循迹避障小车实习报告
### 关于STM32智能循迹避障小车的设计与实施方案
#### 1. 系统概述
基于STM32F407的智能小车设计方案主要围绕核心处理器STM32F407ZET6展开,该芯片具备高性能32位ARM Cortex-M4内核以及丰富的外设资源[^1]。此设计采用四轮式底盘结构作为承载平台,并集成了MCU主控电路、电机驱动电路、舵机控制电路、循迹传感器阵列和超声波避障模块等功能单元。
#### 2. 主要功能模块分析
- **循迹功能**
循迹功能依赖红外反射原理检测地面黑白边界线的变化情况。通常会布置一组或多组红外发射接收管组成的传感器阵列用于实时采集路径信息并反馈给MCU进行处理。
- **避障机制**
避障部分则利用超声波测距传感器完成障碍物距离测量工作。当探测到前方存在物体且小于设定阈值时触发转向动作避开目标。
- **通信接口配置**
对于涉及无线传输的应用场景如远程监控或指令下发,则需考虑蓝牙模块初始化设置问题。由于不同品牌型号间可能存在差异,默认波特率并非统一标准(常见值有9600bps/115200bps),实际操作前应查阅具体产品手册确认参数详情[^3]。
#### 3. 软件架构说明
软件层面遵循分层设计理念构建整体框架,分为底层驱动程序开发(含各外围设备寄存器配置)、中间件服务封装(提供通用API调用接口)以及顶层应用逻辑编写三大部分[^2]:
```c
// 初始化函数示例代码片段
void System_Init(void){
GPIO_Config(); // 设置GPIO模式
TIM_PWM_Init(); // 定义PWM输出周期占空比调节方法
USART_BaudRate_Setup();// 如果使用串口通讯还需调整相应速率数值
}
int main(){
System_Init();
while (true){
Track_Detection(); // 执行轨迹追踪算法流程
Obstacle_Avoidance(); // 同步监测周围环境是否存在阻碍因素
}
}
```
上述伪码展示了典型循环体内的两个重要环节——持续扫描路面标记点位置关系以便维持既定路线行驶方向的同时也要时刻警惕可能出现的风险源从而及时作出反应措施避免碰撞事故发生。
---
####
阅读全文
相关推荐
















