STM32电机控制库5.4版:开源无感驱动注释详解——从寄存器设置到弱磁控制策略实现
STM32电机库5.4开源无感注释 KEIL工程文件 辅助理解ST库 寄存器设置AD TIM1 龙贝格PLL 前馈控制 弱磁控制 foc的基本流 svpwm占空比计算方法 斜坡启动 死区补偿 有详细的注释 当前是无传感器版本龙贝格观测,三电阻双AD采样搞STM32电机控制就像在玩硬件版的俄罗斯方块寄存器配置、算法参数、硬件特性这些方块要是没对齐就等着炸板子吧。最近在啃ST官方那个无感FOC方案基于MotorControl库5.4魔改的三电阻双AD采样方案实测效果能跟商业驱动器掰手腕。先看工程结构KEIL项目里这几个文件是核心├── User │ ├── main.c // 主状态机与保护逻辑 │ ├── mc_config.c // 外设寄存器初始化 │ └── mc_tasks.c // 电流环/速度环任务重点在mc_config.c里的TIM1配置这个负责产生SVPWM波形。看这段寄存器操作// TIM1时钟源配置 TIM_SelectInputTrigger(TIM1, TIM_TS_ITR2); TIM_InternalClockConfig(TIM1); // 内部时钟源72MHz // 死区时间计算t_d1.5us 72MHz DBGMCU-CR | DBGMCU_TIM1_STOP; // 调试时冻结计数器 TIM1-BDTR TIM_OSSR_ENABLE | TIM_OSSI_ENABLE | (21 TIM_BDTR_DTG_BIT_POS); // 死区生成器配置这里有个坑——死区补偿需要结合开关管特性。我们项目用的IGBT需要1.5us死区但实际调试中发现换向时有轻微震荡后来在速度环里加了补偿系数才解决。三电阻采样的双AD交替触发是关键ADC1和ADC2用TIM1的TRGO信号同步触发// 双ADC交替采样配置 ADC_RegularChannelConfig(ADC1, ADC_Channel_1, 1, ADC_SampleTime_7Cycles5); ADC_RegularChannelConfig(ADC2, ADC_Channel_2, 1, ADC_SampleTime_7Cycles5); TIM_SelectOutputTrigger(TIM1, TIM_TRGOSource_Update); // 更新事件触发AD采样时机必须卡在PWM中点这个在TIM_CR2寄存器的CCPC位控制。实测波形发现ADC触发时刻偏差超过200ns就会导致电流波形畸变。STM32电机库5.4开源无感注释 KEIL工程文件 辅助理解ST库 寄存器设置AD TIM1 龙贝格PLL 前馈控制 弱磁控制 foc的基本流 svpwm占空比计算方法 斜坡启动 死区补偿 有详细的注释 当前是无传感器版本龙贝格观测,三电阻双AD采样龙贝格观测器PLL的实现比传统滑模观测安静多了代码里这个结构体藏着玄机typedef struct { int16_t ElectSpeed; // 电气转速 int16_t MechSpeed; // 机械转速 int16_t DeltaAngle; // 角度增量 int32_t Angle; // 累计角度 } OBSERVER_TypeDef;观测器核心算法在mc_math.c里用定点数运算实现// 龙贝格速度估算伪代码 void Luenberger_SpeedEstimator(int32_t Ialpha, int32_t Ibeta) { int32_t emf_alpha Ibeta * Rs - Vbeta; // 反电动势估算 int32_t emf_beta -Ialpha * Rs Valpha; // 龙贝格校正项 speed_correction (emf_alpha * sin_theta - emf_beta * cos_theta) 15; // PLL锁相环跟踪 est_speed Kp * speed_correction; est_angle Ki * speed_correction est_speed; }这里有个骚操作——为了避开浮点运算把PI系数放大2^15倍用整数运算实现。调试时发现观测器对电机参数敏感特别是定子电阻Rs温飘会影响精度后来加了在线辨识才稳定。SVPWM占空比计算有个节省CPU时间的技巧void SVM_CalcDutyCycles(int32_t Ualpha, int32_t Ubeta) { // 扇区判断 uint8_t sector (Ualpha 0) | ((Ubeta 0) 1) | ((Ualpha * Ubeta 0) 2); // 矢量作用时间计算 int32_t T1 (Ualpha * 886 - Ubeta * 1772) 12; // 886sqrt(3)*512 int32_t T2 (Ubeta * 1024) 12; // 占空比标准化 PWM_DutyCycleA (T1 T2 2048) 2; // 映射到0-ARR范围 }这个版本把sqrt(3)近似为886/512用移位代替浮点除法。实测谐波失真比精确计算增加不到0.8%但节省了30%的计算时间。斜坡启动时遇到个坑爹问题——空载启动正常但带载启动会失步。后来发现是观测器收敛速度不够修改了启动流程// 改良后的启动流程 void Motor_Startup(void) { OpenLoop_Inject(30); // 预定位1秒 CurrentLoop_Enable(); while(1) { Angle Speed_ramp; // 角度斜坡 if(Speed_ramp 1000) Speed_ramp 50; if(Observer_Converged()) // 观测器收敛标志 break; } CloseLoop_Enable(); // 切闭环 }加入预定位和双斜坡控制后带载启动成功率从60%提升到98%。不过弱磁控制还没完全搞定在高速段有时会进入不可控状态看来前馈补偿的参数还得细调。这个方案最让我惊喜的是代码注释质量比如在电流采样模块看到这样的提示/* 注意ADC采样窗口必须覆盖PWM死区时间 采样时刻计算公式 t_sample (PWM_PERIOD - DEAD_TIME) / 2 如果采样电阻在低边需调整触发位置 */这种实战经验型的注释比手册管用多了。最后晒下调试成果——用JScope抓的波形显示转速环在1000RPM时的波动小于±3RPM电流THD控制在5%以内算是给这几个月的掉头发有个交代了。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2431717.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!