基于滑模观测器的永磁同步电机无感FOC 1.采用两相静止坐标系的SMO,位置提取方法采用PLL(锁相环),开关函数包括符号函数、sigmoid函数、饱和函数,可进行对比分析; 2.提供算法对应的参考文献和仿真模型仿真模型纯手工搭建
永磁同步电机的无感FOC控制里有个挺有意思的玩意儿——滑模观测器(SMO)。这玩意儿不需要编码器就能把转子的位置和速度给扒拉出来,特别适合那些对成本敏感的应用场景。咱今天就聊聊怎么在α-β坐标系下整活,特别是三种不同的开关函数该怎么选。
先上硬菜,滑模观测器的核心方程长这样:
function e = SMO_equation(i_alpha_hat, i_beta_hat, V_alpha, V_beta) R = 2.3; L = 0.005; % 电机参数 dt = 1e-5; % 仿真步长 persistent i_alpha_prev i_beta_prev; % 滑模控制量计算 e_alpha = i_alpha_hat - i_alpha_prev; e_beta = i_beta_hat - i_beta_prev; % 这里就是开关函数的位置,后边会替换成不同版本 s_alpha = sign(e_alpha); s_beta = sign(e_beta); % 电流观测器更新 i_alpha_new = (V_alpha - R*i_alpha_prev + L/dt*(i_alpha_prev - i_alpha_hat) - L*s_alpha)/L; i_beta_new = (V_beta - R*i_beta_prev + L/dt*(i_beta_prev - i_beta_hat) - L*s_beta)/L; % 更新状态 i_alpha_prev = i_alpha_new; i_beta_prev = i_beta_new; e = [e_alpha; e_beta]; end这段代码里有个关键点——那个sign()函数就是最原始的开关函数。它的输出非+1即-1,就像个暴躁老哥,好处是响应贼快,但会把系统搞得疯狂抖动。这时候咱们就得考虑其他温柔点的操作,比如sigmoid或者饱和函数。
来个对比实验:
% 符号函数 s_sign = sign(e); % sigmoid函数(β控制斜率) beta = 100; s_sigmoid = 2./(1 + exp(-beta*e)) - 1; % 饱和函数(δ为边界层) delta = 0.1; s_sat = min(max(e/delta, -1), 1);把这三种函数扔进仿真里跑一圈,能看到sigmoid的输出曲线最丝滑,符号函数跟得了帕金森似的疯狂抖动,饱和函数处于两者之间。实际调参时得在收敛速度和抖动幅度之间做取舍,像高速场合用符号函数加低通滤波,精密控制场合更适合sigmoid。
位置提取这块得靠锁相环(PLL)来整。搭建PLL时有几个关键参数要折腾:
Kp = 150; % 比例增益 Ki = 5000; % 积分增益 theta_pll = 0; % 初始角度 % 在仿真循环中更新 error = e_alpha * cos(theta_pll) - e_beta * sin(theta_pll); omega_pll = Kp * error + Ki * error * dt; theta_pll = theta_pll + omega_pll * dt;这里的玄机在于误差信号的提取方式,用正交分量做鉴相操作,相当于把滑模观测器的输出当作带噪声的正弦信号来处理。调Kp和Ki的时候要小心,增益太大容易引发振荡,太小了跟踪不上转速变化。
仿真模型建议用Simulink手搓,别用现成的PMSM库。自己搭几个关键模块:
- 坐标变换模块(Clark变换)
- 滑模观测器子系统
- 锁相环模块
- 空间矢量调制模块
手搭模型虽然费劲,但能彻底搞清楚信号流向。比如在观测器输出端可以加个移动平均滤波器,代码实现也就三行:
buffer = circshift(buffer,1); buffer(1) = raw_signal; filtered = mean(buffer);但要注意滤波会引入相位延迟,别把系统搞不稳定了。
基于滑模观测器的永磁同步电机无感FOC 1.采用两相静止坐标系的SMO,位置提取方法采用PLL(锁相环),开关函数包括符号函数、sigmoid函数、饱和函数,可进行对比分析; 2.提供算法对应的参考文献和仿真模型仿真模型纯手工搭建
最后给几个参考文献备查:
[1] Zhou的《Sliding Mode Observer for PMSM Sensorless Control》讲基础理论
[2] Hwang的《Sigmoid Function in SMO》对比不同开关函数特性
[3] Utkin那本经典《Sliding Mode Control》第5章有PLL实现细节
仿真时遇到转速估计波动大的问题,八成是滑模增益没调好。记住一个原则:增益值和反电动势幅值成正比,所以高速时要适当降低增益,低速时反而需要增大。这招能有效拓宽观测器的速度适用范围。