永磁同步電機(jī)具有體積小、轉(zhuǎn)動(dòng)慣量低、結(jié)構(gòu)簡(jiǎn)單等優(yōu)點(diǎn),被廣泛應(yīng)用于控制系統(tǒng)中。然而在實(shí)際應(yīng)用過程中,控制系統(tǒng)會(huì)受到高溫、負(fù)載等外界因素的影響,永磁同步電機(jī)的電感、轉(zhuǎn)子磁鏈等參數(shù)會(huì)發(fā)生變化,導(dǎo)致系統(tǒng)振蕩,影響實(shí)際控制效果。
因此精確的參數(shù)辨識(shí)是為了達(dá)到更好地控制效果的必要條件。目前常用的電機(jī)參數(shù)辨識(shí)方法有:卡爾曼濾波算法、最小二乘法、遺傳算法、粒子群算法等??紤]到最小二乘法結(jié)構(gòu)簡(jiǎn)單、易于實(shí)現(xiàn)的優(yōu)點(diǎn),本期采用基于最小二乘法的永磁同步電機(jī)參數(shù)辨識(shí)方法。基于對(duì)永磁同步電機(jī)的推導(dǎo),采用定子電壓等可測(cè)變量作為輸入輸出,辨識(shí)出電機(jī)的定子電阻及d、q軸電樞電感。
1、最小二乘法
最小二乘參數(shù)辨識(shí)方法可以解決線性時(shí)變系統(tǒng)、線性定常系統(tǒng)、含有噪聲的線性系統(tǒng)等問題。常見的最小二乘法有:遞推最小二乘法、遺忘因子遞推最小二乘法、修正補(bǔ)償最小二乘法等,這些方法均可以用于系統(tǒng)參數(shù)辨識(shí)中。
2、辨識(shí)模型的建立
永磁同步電機(jī)是一個(gè)非線性的多變量系統(tǒng)。在d、q旋轉(zhuǎn)坐標(biāo)下的電壓方程為:
式中,iq和id分別為q、d的電流;uq和ud分別為q、d的電壓;Rs、Lq、Ld分別為定子繞組的電阻和q、d軸的電感;Ψq、Ψd分別為q、d磁鏈的分量;ω為轉(zhuǎn)子的電角速度。
將上述公式修改為最小二乘法的表達(dá)形式:
3、仿真實(shí)驗(yàn)
將S函數(shù)編寫的參數(shù)辨識(shí)模塊加入到永磁同步電動(dòng)機(jī)控制系統(tǒng)模型中進(jìn)行仿真實(shí)驗(yàn)。
function [sys,x0,str,ts] = Synchronous_demarcate2(t,x,u,flag)
%此程序?yàn)楸孀R(shí)電機(jī)參數(shù)的轉(zhuǎn)動(dòng)慣量
switch flag
case 0 %初始化
[sys,x0,str,ts]=mdlInitializeSizes;
case 2 %離散狀態(tài)計(jì)算,下一步仿真時(shí)刻,終止仿真設(shè)定
sys=[];%mdlUpdates(t,x,u);
case 3 %輸出信號(hào)計(jì)算
sys=mdlOutputs(t,x,u);
case {1,4,9} %輸出信號(hào)計(jì)算
sys=[];
otherwise
DAStudio.error('Simulink:blocks:unhandledFlag', num2str(flag));
end
function [sys,x0,str,ts]=mdlInitializeSizes %系統(tǒng)的初始化
sizes = simsizes;
sizes.NumContStates = 0; %設(shè)置系統(tǒng)連續(xù)狀態(tài)的變量
sizes.NumDiscStates = 0; %設(shè)置系統(tǒng)離散狀態(tài)的變量
sizes.NumOutputs = 1; %設(shè)置系統(tǒng)輸出的變量
sizes.NumInputs = 3; %設(shè)置系統(tǒng)輸入的變量
sizes.DirFeedthrough = 1; %如果在輸出方程中顯含輸入變量u,則應(yīng)該將本參數(shù)設(shè)置為1,輸入不直接傳到輸出口
sizes.NumSampleTimes = 1; % 模塊采樣周期的個(gè)數(shù)
% 需要的樣本時(shí)間,一般為1.
% 猜測(cè)為如果為n,則下一時(shí)刻的狀態(tài)需要知道前n個(gè)狀態(tài)的系統(tǒng)狀態(tài)
sys = simsizes(sizes);
x0 = []; % 系統(tǒng)初始狀態(tài)變量
str = []; % 保留變量,保持為空
ts = [-1 0]; % 采樣時(shí)間[t1 t2] t1為采樣周期,如果取t1=-1則將繼承輸入信號(hào)的采樣周期;參數(shù)t2為偏移量,一般取為0
global P_past2 theta_past2
P_past2 = 1e4 * eye(2,2); %一般取1e4 - 1e10
theta_past2 = [0.0001; 0.0001]; %一般取一個(gè)極小的正實(shí)向量
function sys=mdlOutputs(t,x,u) %產(chǎn)生(傳遞)系統(tǒng)輸出
%初值的確定
lambda = 0.99; %遺忘因子0-1
global P_past2 theta_past2
xt = [u(1) u(2)]; %1*2 fait
y = u(3);
I = [1 0;0 1];
K = P_past2*xt'/(lambda + xt * P_past2*xt'); %2*1
P_new = 1/lambda*(I - K*xt) * P_past2; %2*2
theta_new = theta_past2 + K*(y-xt*theta_past2); %2*1
P_past2 = P_new ;
theta_past2 = theta_new;
sys(1) = theta_new(1);