📄 hinfdm.m
字号:
add_line([sys,'/','Plant'],[200,145;305,145;305,65;315,65])
add_line([sys,'/','Plant'],[285,105;295,105;295,55;315,55])
add_line([sys,'/','Plant'],[225,45;240,45;240,100;245,100])
add_line([sys,'/','Plant'],[130,90;195,90;195,110;245,110])
add_line([sys,'/','Plant'],[225,45;315,45])
add_line([sys,'/','Plant'],[350,55;355,55])
add_line([sys,'/','Plant'],[90,45;150,45])
% Finished composite block 'Plant'.
set_param([sys,'/','Plant'],...
'position',[345,128,375,182])
% Subsystem ['About the musyn',13,'demo1'].
new_system([sys,'/',['About the musyn',13,'demo1']])
set_param([sys,'/',['About the musyn',13,'demo1']],'Location',[2,439,106,512])
set_param([sys,'/',['About the musyn',13,'demo1']],...
'Mask Display','?',...
'Mask Type','',...
'Mask Dialogue','eval(''clc; more(24); help hinfdata; more off'')',...
'Mask Translate','',...
'Mask Help','')
% Finished composite block ['About the musyn',13,'demo1'].
set_param([sys,'/',['About the musyn',13,'demo1']],...
'hide name',0,...
'Drop Shadow',4,...
'position',[543,287,576,318])
add_block('built-in/Scope',[sys,'/','Scope'])
set_param([sys,'/','Scope'],...
'Vgain','3.000000',...
'Hgain','10.000000',...
'Vmax','3.000000',...
'Hmax','20.000000',...
'Window',[0,0,453,204],...
'position',[550,172,570,198])
add_block('built-in/Transfer Fcn',[sys,'/',['Performance Weighting ',13,'Inv(W1) function']])
set_param([sys,'/',['Performance Weighting ',13,'Inv(W1) function']],...
'Numerator','num1',...
'Denominator','den1',...
'Mask Display','plot(log10(w1),log10(ma1));',...
'Mask Type','polynomial: num/den')
set_param([sys,'/',['Performance Weighting ',13,'Inv(W1) function']],...
'Mask Dialogue','Transfer function\n numerator and denominator|numerator:|denominator:',...
'Mask Translate','num1=@1;den1=@2;[ma1,ph1,w1]=bode(num1,den1);')
set_param([sys,'/',['Performance Weighting ',13,'Inv(W1) function']],...
'Mask Help','Transfer function ',...
'Mask Entries','num1\/den1\/',...
'position',[200,22,300,68])
add_block('built-in/Transfer Fcn',[sys,'/',['Input Weighting',13,'W2 Function']])
set_param([sys,'/',['Input Weighting',13,'W2 Function']],...
'Numerator','num2',...
'Denominator','den2',...
'Mask Display','plot(log10(w2),log10(ma2));',...
'Mask Type','polynomial: num/den')
set_param([sys,'/',['Input Weighting',13,'W2 Function']],...
'Mask Dialogue','Transfer Function\nnumerator and denominator:|numerator:|denominator:',...
'Mask Translate','num2=@1;den2=@2;[ma2,pa2,w2]=bode(num2,den2);')
set_param([sys,'/',['Input Weighting',13,'W2 Function']],...
'Mask Help','Transfer Function',...
'Mask Entries','num2\/den2\/',...
'position',[365,66,470,114])
add_block('built-in/Transfer Fcn',[sys,'/',['Robustness Weighting',13,'Inv(W3) function']])
set_param([sys,'/',['Robustness Weighting',13,'Inv(W3) function']],...
'Numerator','num3',...
'Denominator','den3',...
'Mask Display','plot(log10(w3),log10(ma3))',...
'Mask Type','polynomial: num/den')
set_param([sys,'/',['Robustness Weighting',13,'Inv(W3) function']],...
'Mask Dialogue','Transfer Function\nnumerator and denominator:|numerator:|denominator:',...
'Mask Translate','num3=@1;den3=@2;[ma3,ph3,w3]=bode(num3,den3);')
set_param([sys,'/',['Robustness Weighting',13,'Inv(W3) function']],...
'Mask Help','Transfer Function',...
'Mask Entries','num3\/den3\/',...
'position',[430,201,535,249])
% Subsystem ['Double click here',13,'to show bode plot ',13,'of controller'].
new_system([sys,'/',['Double click here',13,'to show bode plot ',13,'of controller']])
set_param([sys,'/',['Double click here',13,'to show bode plot ',13,'of controller']],'Location',[2,439,106,512])
set_param([sys,'/',['Double click here',13,'to show bode plot ',13,'of controller']],...
'Mask Display','Closed-Loop\nNyquist',...
'Mask Type','')
set_param([sys,'/',['Double click here',13,'to show bode plot ',13,'of controller']],...
'Mask Dialogue','eval(''if ~exist(''''ae''''), printf(''''Must Load Data & Desgin First''''), else,[x,y,z,w]=feedback(a,b,c,d,ae,be,ce,de,-1); clg, nyquist(x,y,z,w); end'')')
set_param([sys,'/',['Double click here',13,'to show bode plot ',13,'of controller']],...
'Mask Translate','',...
'Mask Help','')
% Finished composite block ['Double click here',13,'to show bode plot ',13,'of controller'].
set_param([sys,'/',['Double click here',13,'to show bode plot ',13,'of controller']],...
'hide name',0,...
'position',[361,277,442,318])
% Subsystem ['Double click here',13,'to show zero-pole',13,'plot of closed-loop4'].
new_system([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of closed-loop4']])
set_param([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of closed-loop4']],'Location',[2,439,106,512])
set_param([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of closed-loop4']],...
'Mask Display','Controller\nBode Plot',...
'Mask Type','')
set_param([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of closed-loop4']],...
'Mask Dialogue','eval(''if ~exist(''''ae''''),fprintf(''''\nMust Load Data & Design First\n''''),else [x,y,w]=bode(ae,be,ce,de); clg; subplot(211); loglog(w,x); subplot(212); semilogx(w,y); subplot(111); end'')')
set_param([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of closed-loop4']],...
'Mask Translate','',...
'Mask Help','')
% Finished composite block ['Double click here',13,'to show zero-pole',13,'plot of closed-loop4'].
set_param([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of closed-loop4']],...
'hide name',0,...
'position',[281,277,353,318])
% Subsystem ['Double click here',13,'to start loading data',13,'and mu-syn design1'].
new_system([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design1']])
set_param([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design1']],'Location',[2,439,106,512])
set_param([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design1']],...
'Mask Display','Re-Design',...
'Mask Type','')
set_param([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design1']],...
'Mask Dialogue','eval(''if ~exist(''''obalreal''''),fprintf(''''\nMust be licensed for RCT Toolbox\n''''), else, fprintf(''''\nCtrl_C to abort RCT Calculation\n\n''''); hinfdes1; end'')')
set_param([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design1']],...
'Mask Translate','',...
'Mask Help','')
% Finished composite block ['Double click here',13,'to start loading data',13,'and mu-syn design1'].
set_param([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design1']],...
'hide name',0,...
'position',[102,277,177,318])
% Subsystem ['Double click here',13,'to show bode plot',13,'of closed-loop3'].
new_system([sys,'/',['Double click here',13,'to show bode plot',13,'of closed-loop3']])
set_param([sys,'/',['Double click here',13,'to show bode plot',13,'of closed-loop3']],'Location',[2,439,106,512])
set_param([sys,'/',['Double click here',13,'to show bode plot',13,'of closed-loop3']],...
'Mask Display','Closed-Loop\nBode Plot',...
'Mask Type','')
set_param([sys,'/',['Double click here',13,'to show bode plot',13,'of closed-loop3']],...
'Mask Dialogue','eval(''if ~exist(''''ae''''),fprintf(''''\nMust Load Data & Design First\n''''),else [x,y,z,w]=series(a,b,c,d,ae,be,ce,de);[x,y,z,w]=cloop(x,y,z,w,-1); [x,y,w]=bode(x,y,z,w); clg; subplot(211); loglog(w,x(:,1)); subplot(212); semilogx(w,y(:,1)); subplot(111); end'')')
set_param([sys,'/',['Double click here',13,'to show bode plot',13,'of closed-loop3']],...
'Mask Translate','',...
'Mask Help','')
% Finished composite block ['Double click here',13,'to show bode plot',13,'of closed-loop3'].
set_param([sys,'/',['Double click here',13,'to show bode plot',13,'of closed-loop3']],...
'hide name',0,...
'position',[188,277,269,318])
% Subsystem ['Double click here',13,'to start loading data',13,'and mu-syn design'].
new_system([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design']])
set_param([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design']],'Location',[2,439,106,512])
set_param([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design']],...
'Mask Display','Re-Load\nData',...
'Mask Type','')
set_param([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design']],...
'Mask Dialogue','eval(''if ~exist(''''obalreal''''),fprintf(''''\nMust be licensed for RCT Toolbox\n''''), else, fprintf(''''\nCtrl_C to abort RCT Calculation\n\n''''); hinfdata; end'')')
set_param([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design']],...
'Mask Translate','',...
'Mask Help','')
% Finished composite block ['Double click here',13,'to start loading data',13,'and mu-syn design'].
set_param([sys,'/',['Double click here',13,'to start loading data',13,'and mu-syn design']],...
'hide name',0,...
'position',[23,275,92,317])
% Subsystem ['Double click here',13,'to show zero-pole',13,'plot of controller'].
new_system([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of controller']])
set_param([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of controller']],'Location',[2,439,106,512])
set_param([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of controller']],...
'Mask Display','Controller\nNyquist',...
'Mask Type','')
set_param([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of controller']],...
'Mask Dialogue','eval(''if ~exist(''''ae''''), printf(''''Must Load Data & Desgin First''''), else,clg; nyquist(ae,be,ce,de), end'')',...
'Mask Translate','')
set_param([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of controller']],...
'Mask Help','')
% Finished composite block ['Double click here',13,'to show zero-pole',13,'plot of controller'].
set_param([sys,'/',['Double click here',13,'to show zero-pole',13,'plot of controller']],...
'hide name',0,...
'position',[450,278,521,318])
add_block('built-in/Note',[sys,'/','* Curves inside weighting function blocks are the weighting function bode plot'])
set_param([sys,'/','* Curves inside weighting function blocks are the weighting function bode plot'],...
'position',[299,335,300,336])
add_line(sys,[305,45;545,45])
add_line(sys,[380,155;490,155;490,140;545,140])
add_line(sys,[400,155;400,225;90,225;90,170;105,170])
add_line(sys,[400,225;420,225])
add_line(sys,[540,225;550,225])
add_line(sys,[380,155;490,155;490,185;540,185])
add_line(sys,[300,155;335,155])
add_line(sys,[310,155;310,90;355,90])
add_line(sys,[80,155;105,155])
add_line(sys,[70,95;85,95;85,140;105,140])
add_line(sys,[140,155;170,155])
add_line(sys,[140,155;155,155;155,45;190,45])
add_line(sys,[475,90;540,90])
% Return any arguments.
if (nargin | nargout)
% Must use feval here to access system in memory
if (nargin > 3)
if (flag == 0)
eval(['[ret,x0,str]=',sys,'(t,x,u,flag);'])
else
eval(['ret =', sys,'(t,x,u,flag);'])
end
else
[ret,x0,str] = feval(sys);
end
end
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -