Pull to refresh

Модальный метод синтеза в MATLAB

Level of difficultyEasy
Reading time2 min
Views1.6K

Частым заданием в различных курсах по теории автоматического управления является нахождение матрицы K для модального управления системой вида dx/dt = Ax+Bu y = Cx.

Такой тип задач легко решается в среде MATLAB.

Сперва наперво требуется задать нашу систему. Для примера возьмем типовую модель электродвигателя:

J = 0.01;   % Момент инерции ротора kg.m^2
b = 0.1;    % Коэффициент затухания мех. системы Nms
K = .01;    % ЭДС константа Nm/A
R = 1.0;    % Сопротивление Ohms
L = 0.5;    % Индуктивность Henrys
A = [-b/J K/J; -K/L -R/L];
B = [0; 1/L];
C = [1 1];
D = 0;
W = ss(A,B,C,D); % создаем модель в пространстве состояний

Далее проверим критерий устойчивости и управляемость системы

pole(W) % найдем полюса системы
% ans = 2×1 -9.9975 -2.0025
rank(ctrb(A,B)) % если ранг равен порядку системы то она полностью управляема
% ans = 2

Полюса все оба два отрицательны, а значит система устойчива. Ранг матрицы управления равен порядку системы, а значит система полностью управляема.

Найдем реакцию системы на ступенчатый сигнал:

step(W)
grid on

Устоявшееся конечное значение чуть больше единицы, попытаемся исправить это замкнув систему обратной связью -Kx так, чтобы полюса итоговой системы оказались равны p = 4.45*[-1 -1.1] и конечное значение оказалось близко к единице.

В пакете MATLAB это делается буквально парой строк:

p = 4.45*[-1 -1.1]; % заданные полюса
K = place(A,B,p) % матрица К
% K = 1×2 14.1564 -1.3275

% Проверим полюса замкнутой системы
AClosed = A - B*K;
BClosed = B;
CClosed = C;
DClosed = D;
Wclosed = ss(AClosed,BClosed,CClosed,DClosed);
pole(Wclosed)
% ans = 2×1 -4.8950 -4.4500

Как можно видеть, полюса замкнутой системы точно такие же, как в векторе p.

Найдем реакцию замкнутой системы на ступенчатый сигнал:

step(Wclosed)
grid on

Устоявшееся значение замкнутой системы около единицы, и сама реакция системы на ступенчатое воздействие раза в 2 быстрее.

Теперь, для сравнения, можно найти ту же матрицу K классическим алгоритмом:

% Запишем матрицу замкнутой системы
L = length(B);
k = sym('k',[1,L]);
F = A - B*k % найдем матрицу F
% Найдем характеристический полином
syms lamda
polyF = det(lamda*eye(L)-F) % характеристический полином
CoefF = fliplr(coeffs(polyF,lamda)) % коэффициенты полинома
CoefF(1) = [];
% Назначим желаемый характеристический полином
polyL = (lamda-p(1))*(lamda-p(2)) % желаемый полином
CoefL = fliplr(coeffs(polyL,lamda)) % коэффициенты полинома
CoefL(1) = [];
% Найдем элементы матрицы К
K = solve(CoefF == CoefL);
K = double([K.k1 K.k2]) % матрица К
% K = 1×2 14.1564 -1.3275

Строк кода много больше, но ответ вышел точно такой же.

UPD1

В MATLAB есть еще одна функция для вычисления матрицы K, которая использует формулу Аккермана, но которая, в отличие от функции place, работает только если система имеет один вход.

K = acker(A,B,p) % матрица К
% K = 1×2 14.1564 -1.3275

Еще один способ найти коэффициенты матрицы усиления K это решение матричного уравнения Сильвестра.

Запишем матрицы описания эталонной модели:

G = [0 -CoefL(2); 1 -CoefL(1)]; % матрица nxn определяющая требуемые свойства
H = [0 1]; % матрица mxn выхода эталонной модели

Решим уравнение Сильвестра:

% найдем такую матрицу М, чтобы выполнялось M*G-A*M-B*H == 0
M = lyap(-A,G,-B*H)
% ans M = 2×2
% [ -0.0265 -0.0176;
% -0.2826 0.5657]

Найдем матрицу усиления:

K = -H*M^-1
% K = 1×2 14.1564 -1.3275

Найдем полюса системы:

eig(A - B*K)
% ans = 2×1 -4.8950 -4.4500

Как можно увидеть, результат одинаков для каждого из способов.

Ссылка на исходники

Tags:
Hubs:
Total votes 4: ↑3 and ↓1+4
Comments3

Articles