www.gusucode.com > mpc_featured 案例源码 matlab代码程序 > mpc_featured/mpcweightsdemo.m

    %% Specifying Alternative Cost Function with Off-Diagonal Weight Matrices
% This example shows how to use non-diagonal weight matrices in a model
% predictive controller.

% Copyright 1990-2014 The MathWorks, Inc.  

%% Define Plant Model and MPC Controller
% The linear plant model has two inputs and two outputs.
plant = ss(tf({1,1;1,2},{[1 .5 1],[.7 .5 1];[1 .4 2],[1 2]}));
[A,B,C,D] = ssdata(plant);
Ts = 0.1;               % sampling time
plant = c2d(plant,Ts);  % convert to discrete time
%%
% Create MPC controller.
p=20;       % prediction horizon
m=2;        % control horizon 
mpcobj = mpc(plant,Ts,p,m);
%%
% Define constraints on the manipulated variable.
mpcobj.MV = struct('Min',{-3;-2},'Max',{3;2},'RateMin',{-100;-100},'RateMax',{100;100});
%%
% Define non-diagonal output weight. Note that it is specified inside a
% cell array.
OW = [1 -1]'*[1 -1]; 
% Non-diagonal output weight, corresponding to ((y1-r1)-(y2-r2))^2
mpcobj.Weights.OutputVariables = {OW}; 
% Non-diagonal input weight, corresponding to (u1-u2)^2
mpcobj.Weights.ManipulatedVariables = {0.5*OW};

%% Simulate Using SIM Command
% Specify simulation options.
Tstop = 30;               % simulation time
Tf = round(Tstop/Ts);     % number of simulation steps
r = ones(Tf,1)*[1 2];     % reference trajectory
%%
% Run the closed-loop simulation and plot results.
[y,t,u] = sim(mpcobj,Tf,r);
subplot(211)
plot(t,y(:,1)-r(1,1)-y(:,2)+r(1,2));grid
title('(y_1-r_1)-(y_2-r_2)');
subplot(212)
plot(t,u);grid
title('u');

%% Simulate Using Simulink(R)
% To run this example, Simulink(R) is required.
if ~mpcchecktoolboxinstalled('simulink')
    disp('Simulink(R) is required to run this part of the example.')
    return
end
%%
% Now simulate closed-loop MPC in Simulink(R).
mdl = 'mpc_weightsdemo';
open_system(mdl);
sim(mdl) 

%%
bdclose(mdl);