matlab控制器参数整定方法

systune方法

在这里插入图片描述
针对上述控制结构图,利用matlab整定参数。

code

%% Tuning Control Systems with SYSTUNE
% systuneWorkflowExample.m
G = tf([2],[0.0015 0.009 2]);
C0 = tunablePID('C','pi');  % tunable PI

a = realp('a',1);    %  参数化
F0 = tf(a,[1 a]);    % 滤波器结构

AP = AnalysisPoint('u'); % 断点

T0 = feedback(G*AP*C0,F0);  % 广义闭环传函
T0.InputName = 'r';
T0.OutputName = 'y';
% 指定设计要求
% 设计要求参考链接:
% https://www.mathworks.com/help/control/tuning-goals-1.html?s_tid=srchtitle
Req1 = TuningGoal.Tracking('r','y',0.7);
Req2 = TuningGoal.Margins('u',6,45);
% 执行参数优化算法
rng('default')
Options = systuneOptions('RandomStart',3);
[T,fSoft] = systune(T0,[Req1,Req2],Options);
% 查看指标完成度
fSoft
% 显示整定最佳参数
showTunable(T)  % tuned values of all tunable elements
% 阶跃响应
clf, step(T)

simulink + code

在这里插入图片描述


%% 

G = tf([2],[0.0015 0.009 2]);
ST0 = slTuner('rct_diskdrive',{
    
    'C','F'});
% a = realp('a',1); % 参数化
% setBlockParam(ST0,'F',tf(a,[1 a])); % 明确指定如何参数化F块
T0 = getIOTransfer(ST0,{
    
    'r'},{
    
    'y'}); % 获取闭环传递函数的广义模型
% 指定设计要求
Req1 = TuningGoal.StepTracking('r','y',0.01);
% 参数整定
rng('default')
Options = systuneOptions('RandomStart',3);
[T,fSoft] = systune(T0,[Req1],Options);
fSoft %要求的完成度,小于1为达到要求
showTunable(T) %展示整定值
clf,step(T)
% 将整定数据写入simulink
ST = copy(ST0); % 复制ST0数据
setBlockValue(ST,T); % 将整定好的数据写入ST
writeBlockValue(ST); % 写入simulink
% 阶跃响应
Try = getIOTransfer(ST,'r','y');
step(Try)

在这里插入图片描述

HinfStruct方法

标准控制结构

在这里插入图片描述

simulink + code

在这里插入图片描述

% https://www.mathworks.com/help/robust/gs/fixed-structure-h-infinity-synthesis-with-hinfstruct.html

load hinfstruct_demo G
wc = 1000;  % target crossover
s = tf('s');
LS = (1+0.001*s/wc)/(0.001+s/wc);
% 创建slTuner接口的实例,并将Simulink块C和F标记为可调参数
ST0 = slTuner('rct_diskdrive',{
    
    'C','F'});
a = realp('a',1);
setBlockParam(ST0,'F',tf([a],[1 a])); % 明确指定如何参数化F块
T0 = getIOTransfer(ST0,{
    
    'r','n'},{
    
    'y','e'}); % 获取闭环传递函数的广义模型
T0 = blkdiag(1,LS) * T0 * blkdiag(1,1/LS); % 加权
% 随机数优化
rng(0)
opt = hinfstructOptions('Display','final','RandomStart',5);
T = hinfstruct(T0,opt);
% 查看最优参数值
showTunable(T)
step(T(1,1));

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/qq_34551090/article/details/112686371