核心内容摘要
连接你我:打破孤岛,共筑情感的桥梁
永磁同步电机pmsm全速度切换无位置传感器控制高速可以是超螺旋滑模 低速可以是脉振高频方波注入if开环等仿真模型。
切换有加权切换和双坐标切换。
单个链接只有一种。
可以送单独卡尔曼滤波或者扩张状态观测器。
高速段的超螺旋滑模别被论文里的数学推导吓到核心就三行代码function [theta_hat] Super_Twisting(e_omega) alpha
8; % 滑模增益别贪心容易振荡 lambda
2; % 收敛速度看负载惯量 theta_hat -lambda*abs(e_omega)^
5*sign(e_omega) integral(-alpha*sign(e_omega)); end这里的积分项要加抗饱和处理实测中发现当转速突变超过300rad/s时直接积分会爆表。
建议用动态限幅integralterm min(max(integralterm, -
1.
,
1.
;低速段的高频注入方波注入的相位对齐是老大难这段代码实现了自动相位补偿void HF_Injection(float Vh, float theta_est) { static uint8_t count 0; float Vh_signal (count
? Vh : -Vh; // 10kHz下5个采样点切换 if(count
count 0; // 坐标变换里的相位补偿 float delta
1*(theta_est - theta_real_prev); // 补偿量别超过
3rad clarke_transform(Vh_signal, delta); }注意注入频率和PWM载波频率的互质关系推荐用质数比如1973Hz。
遇到过载波谐波干扰的试试在SVPWM里加个随机载波偏移。
永磁同步电机pmsm全速度切换无位置传感器控制高速可以是超螺旋滑模 低速可以是脉振高频方波注入if开环等仿真模型。
切换有加权切换和双坐标切换。
单个链接只有一种。
可以送单独卡尔曼滤波或者扩张状态观测器。
切换策略实战双坐标切换比加权切换更抗揍关键在q轴电流突变的处理def switch_strategy(omega): threshold
15 * rated_omega # 切换阈值建议取10%-20%额定转速 if omega threshold hysteresis_band: enable_hfi False kalman_enable True current_ramp_rate 50 # A/s 防止电流冲击 elif omega threshold - hysteresis_band: enable_hfi True kalman_enable False current_ramp_rate 20 # 低速时降电流变化率遇到过切换震荡的把滞环带宽从5%调到8%立马见效。
有个隐藏BUG切换瞬间的磁链观测器要重置否则会带着误差进新模式。
观测器选型心得卡尔曼滤波在高速段稳如老狗但别直接用现成库% 简化的扩展卡尔曼预测步 function [x_pred, P_pred] EKF_predict(x_est, u, P_prev) F [1 -Ts*R/L, Ts*we; -Ts*we, 1 -Ts*R/L]; % 状态矩阵必须在线计算 G [Ts/L 0; 0 Ts/L]; x_pred F*x_est G*u; P_pred F*P_prev*F Q; # Q矩阵别偷懒用单位阵 end实测发现Q矩阵取diag([
01,
01,1e-4])效果最佳。
有个骚操作把逆变器非线性压降作为扩张状态量观测精度直接提升20%。
仿真模型建议用分段编译高速低速模式分成独立子系统。
遇到过仿真卡死的把代数环检测级别调到最高多半是反馈路径没加单位延迟。
最后提醒切换瞬间的电流环参数记得在线自整定别一个PI参数走天下。