⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hinfdm.m

📁 本书是电子通信类的本科、研究生辅助教材
💻 M
📖 第 1 页 / 共 2 页
字号:
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 + -