基于STM32的四轴飞行器控制系统设计

张开发
2026/4/10 20:51:09 15 分钟阅读

分享文章

基于STM32的四轴飞行器控制系统设计
一、系统概述四轴飞行器Quadcopter是一种垂直起降VTOL多旋翼无人机通过四个无刷电机的转速差实现姿态控制与稳定飞行。本系统以STM32高性能微控制器为核心融合传感器融合、姿态解算、PID控制、电机驱动等技术实现自主悬停、姿态稳定、航线飞行等功能适用于航拍、测绘、物流配送等场景。核心特点高实时性基于STM32F4/H7系列Cortex-M4/M7内核带FPU满足姿态解算与控制算法的实时性需求模块化设计传感器、执行器、通信模块独立封装便于维护与扩展多模式控制支持手动遥控、半自主悬停、全自主导航GPS/视觉安全冗余集成低电压保护、失控保护、传感器故障检测机制。二、系统总体架构2.1 硬件架构I2C/SPIPWMUART/SBUS3.3V/5V主控模块STM32F427/STM32H750传感器模块IMU气压计GPS磁力计执行器模块无刷电机电调通信模块遥控器数传蓝牙电源模块锂电池稳压电路ABCD2.2 软件架构底层驱动层传感器/电机/通信驱动中层算法层姿态解算PID控制导航上层应用层模式管理安全保护数据交互用户接口遥控器地面站三、核心硬件设计3.1 核心组件选型模块型号/参数功能说明主控STM32F427VIT6Cortex-M4180MHzFPU姿态解算、PID控制、任务调度或STM32H750更高性能IMUICM-206026轴陀螺仪加速度计SPI测量角速度°/s与加速度m/s²磁力计HMC5883L3轴I2C航向角测量罗盘校准气压计BMP388高精度I2C海拔高度测量定高用GPSNEO-M8NUBlox5HzUART位置与速度测量自主导航用电机朗宇X2212980KV无刷提供升力搭配4个电调电调好盈XRotor 20ABLHeli_S支持DShot将PWM信号转换为电机驱动电流通信SBUS接收机FrSkyUART 数传模块SiK Radio遥控器信号接收、地面站数据交互电源3S锂电池11.1V2200mAh LM25965V AMS11173.3V为各模块供电电机单独供电3.2 硬件电路设计要点3.2.1 主控最小系统时钟8MHz外部晶振PLL倍频至180MHzSTM32F427调试接口SWDSWDIOSWCLK 串口用于日志输出引脚分配I2C1连接IMUICM-20602、磁力计HMC5883L、气压计BMP388SPI1备用IMU或GPS接口UART1SBUS接收机波特率1000008E2UART2数传模块波特率57600TIM1/TIM8PWM输出4路控制4个电调频率400HzDShot600协议。3.2.2 电机驱动电路电调连接每个电调信号线接STM32的PWM输出引脚电源端接锂电池11.1VGND共地保护电路在电调电源端并联1000μF电容抑制电压波动螺旋桨安装X型布局前右/左后/后左/右前注意旋转方向相邻电机转向相反。四、核心软件设计4.1 开发环境与工具IDESTM32CubeIDE基于Eclipse集成HAL库RTOSFreeRTOS多任务调度优先级传感器读取姿态解算PID控制通信算法库ARM CMSIS-DSP浮点运算加速、Eigen矩阵运算用于扩展卡尔曼滤波地面站Mission Planner参数配置、数据监控、QGroundControl航线规划。4.2 核心算法实现4.2.1 姿态解算Mahony滤波算法功能融合IMU加速度计陀螺仪与磁力计数据输出飞行器姿态角 roll/pitch/yaw 。原理基于四元数表示姿态通过梯度下降法修正陀螺仪漂移结合加速度计重力方向和磁力计地磁方向校准。代码实现STM32 HAL库// Mahony滤波核心函数voidmahony_update(floatgx,floatgy,floatgz,floatax,floatay,floataz,floatmx,floatmy,floatmz){floatnorm;floathx,hy,bx,bz;floatvx,vy,vz,wx,wy,wz;floatex,ey,ez;floatq0q[0],q1q[1],q2q[2],q3q[3];// 四元数// 1. 归一化加速度计和磁力计数据normsqrt(ax*axay*ayaz*az);ax/norm;ay/norm;az/norm;normsqrt(mx*mxmy*mymz*mz);mx/norm;my/norm;mz/norm;// 2. 计算参考向量地球坐标系// 重力向量加速度计vx2*(q1*q3-q0*q2);vy2*(q0*q1q2*q3);vzq0*q0-q1*q1-q2*q2q3*q3;// 地磁向量磁力计hx2*mx*(0.5-q2*q2-q3*q3)2*my*(q1*q3-q0*q2)2*mz*(q0*q1q2*q3);hy2*mx*(q1*q3q0*q2)2*my*(0.5-q1*q1-q3*q3)2*mz*(q2*q3-q0*q1);bxsqrt(hx*hxhy*hy);bz2*mx*(q2*q3-q0*q1)2*my*(q0*q2q1*q3)2*mz*(0.5-q1*q1-q2*q2);// 3. 计算误差向量传感器测量值与参考向量的叉积ex(ay*vz-az*vy)(my*bz-mz*by);ey(az*vx-ax*vz)(mz*bx-mx*bz);ez(ax*vy-ay*vx)(mx*by-my*bx);// 4. 用PI控制器修正陀螺仪漂移ki0.01;// 积分系数kp0.1;// 比例系数integralFBxki*ex*dt;integralFByki*ey*dt;integralFBzki*ez*dt;gxkp*exintegralFBx;gykp*eyintegralFBy;gzkp*ezintegralFBz;// 5. 更新四元数陀螺仪积分q0(-q1*gx-q2*gy-q3*gz)*0.5f*dt;q1(q0*gxq2*gz-q3*gy)*0.5f*dt;q2(q0*gy-q1*gzq3*gx)*0.5f*dt;q3(q0*gzq1*gy-q2*gx)*0.5f*dt;// 6. 四元数归一化normsqrt(q0*q0q1*q1q2*q2q3*q3);q0/norm;q1/norm;q2/norm;q3/norm;// 7. 四元数转欧拉角roll, pitch, yawrollatan2(2*(q0*q1q2*q3),1-2*(q1*q1q2*q2))*RAD2DEG;pitchasin(2*(q0*q2-q3*q1))*RAD2DEG;yawatan2(2*(q0*q3q1*q2),1-2*(q2*q2q3*q3))*RAD2DEG;}4.2.2 PID控制串级PID功能根据姿态角误差计算电机转速调整量实现稳定飞行。结构内环角速度环输入陀螺仪测量的角速度输出期望角速度比例P控制快速响应外环角度环输入姿态角误差目标角-实际角输出期望角速度PI控制消除静差位置环可选输入GPS/气压计的位置误差输出期望姿态角用于自主导航。代码实现角度环角速度环// PID控制器结构体typedefstruct{floatKp,Ki,Kd;// 比例、积分、微分系数floatintegral;// 积分项floatprev_error;// 上次误差}PID_Controller;// PID计算函数floatpid_update(PID_Controller*pid,floatsetpoint,floatmeasured,floatdt){floaterrorsetpoint-measured;pid-integralerror*dt;floatderivative(error-pid-prev_error)/dt;floatoutputpid-Kp*errorpid-Ki*pid-integralpid-Kd*derivative;pid-prev_errorerror;returnoutput;}// 四轴电机转速分配X型布局voidmotor_mixing(floatroll_out,floatpitch_out,floatyaw_out,floatthrottle){// 基础油门四个电机相同floatbase_throttlethrottle;// 姿态调整量差速控制floatm1base_throttle-roll_outpitch_outyaw_out;// 前右电机floatm2base_throttleroll_outpitch_out-yaw_out;// 前左电机floatm3base_throttleroll_out-pitch_outyaw_out;// 后左电机floatm4base_throttle-roll_out-pitch_out-yaw_out;// 后右电机// 限幅0~100%油门m1constrain(m1,0,100);m2constrain(m2,0,100);m3constrain(m3,0,100);m4constrain(m4,0,100);// 输出PWMDShot协议esc_write(0,m1);esc_write(1,m2);esc_write(2,m3);esc_write(3,m4);}4.2.3 电机控制DShot协议功能通过数字信号DShot600控制电调比传统PWM更抗干扰、精度更高。实现STM32通过定时器输出DShot信号每 bit 1.67μs600kbps包含油门值0~2047和校验位。关键代码DShot600发送// 发送DShot信号单路voiddshot_send(uint8_tmotor_id,uint16_tvalue){// 计算校验位低11位求和的最低3位uint16_tchecksum(value^(value4)^(value8))0x0F;value(value4)|checksum;// 12位数据11位油门1位校验// 配置定时器为输出比较模式每1.67μs翻转一次TIM_HandleTypeDef*htimhtim1;// 假设用TIM1输出htim-Instance-ARR1;// 1.67μs 600MHz/3601.67MHz需根据主频调整for(inti0;i16;i){// 16位含2位起始位0uint16_tbit(value(15-i))0x01;HAL_GPIO_WritePin(GPIOA,GPIO_PIN_0,bit);// 假设用PA0输出__HAL_TIM_SET_COMPARE(htim,TIM_CHANNEL_1,1);// 触发翻转HAL_Delay_us(1.67);// 精确延时或用定时器中断}}4.3 主程序流程FreeRTOS任务调度异常系统初始化时钟/外设/GPIO创建FreeRTOS任务传感器读取任务IMU/气压计/GPS100Hz姿态解算任务Mahony滤波100HzPID控制任务姿态环位置环200Hz电机控制任务DShot输出400Hz通信任务遥控器/数传50Hz安全监控任务低电压/失控保护10Hz紧急降落/返航参考代码 基于STM32 四轴飞行器控制系统硬件、源码、设计报告www.youwenfan.com/contentcst/124192.html五、系统测试与调试5.1 地面测试传感器校准加速度计水平静止放置校准零偏磁力计旋转飞行器360°绘制椭球校准陀螺仪静态下观察角速度漂移调整积分系数。电机测试逐个解锁电机检查转向是否正确X型布局前右/后左顺时针前左/后右逆时针。5.2 试飞调试手动模式通过遥控器控制姿态观察PID参数是否合适如震荡则减小Kp静差则增大Ki半自主模式开启气压计定高测试悬停稳定性调整高度环PID全自主模式上传航线Waypoints测试GPS导航精度需开阔场地。5.3 常见问题与解决问题现象可能原因解决方案飞行器自旋陀螺仪零偏未校准/电机转向错误重新校准IMU检查电机转向交换任意两相线悬停时上下波动高度环PID参数不当/气压计噪声减小高度环Kp增加气压计滤波移动平均遥控器信号丢失SBUS协议解析错误/天线接触不良检查UART配置8E2更换接收机天线六、扩展功能视觉避障添加OV2640摄像头用OpenMV实现前方障碍物检测TOF或光流跟随模式通过UWB模块如Decawave实现“主人跟随”自动返航RTHGPS失联时按预设高度返回起飞点集群控制多机通过数传模块组网实现编队飞行需TDMA协议。七、总结本系统基于STM32实现了四轴飞行器的全流程控制从传感器数据采集、姿态解算到PID控制与电机驱动形成了完整的闭环控制链路。核心优势在于模块化设计便于替换传感器/算法、实时性FreeRTOS任务调度和安全性多重保护机制。

更多文章