simpendzzy.m

来自「MATLAB 6.5 从基础讲解其功能」· M 代码 · 共 45 行

M
45
字号
function [sys,x0,str,ts] = simpendzzy(t,x,u,flag,dampzzy,gravzzy,angzzy)

switch flag,
  case 0,       % Initialization
    [sys,x0,str,ts]=mdlInitializeSizes(angzzy);
  case 1,       % Derivatives
    sys=mdlDerivatives(t,x,u,dampzzy,gravzzy);
  case 2,       % Update
    sys=mdlUpdate(t,x,u);
  case 3,       % Outputs
    sys=mdlOutputs(t,x,u);
  case 9,       % Terminate
    sys=mdlTerminate(t,x,u);
  otherwise     % Unexpected flags
    error(['Unhandled flag = ',num2str(flag)]);
end

% ------ mdlInitializeSizes ------------------------
function [sys,x0,str,ts]=mdlInitializeSizes(angzzy)
sizes = simsizes;
sizes.NumContStates  = 2;
sizes.NumDiscStates  = 0;
sizes.NumOutputs     = 1;
sizes.NumInputs      = 1;
sizes.DirFeedthrough = 0;
sizes.NumSampleTimes = 1;  
sys = simsizes(sizes);
x0  = angzzy;
str = [];
ts  = [0,0];
% -----mdlDerivatives -----------------------------
function sys=mdlDerivatives(t,x,u,dampzzy,gravzzy)
dx(1)=-dampzzy*x(1)-gravzzy*sin(x(2))+u;
dx(2)=x(1);
sys =dx ;
% -----mdlUpdate ----------------------------------
function sys=mdlUpdate(t,x,u)
sys = [];
% -----mdlOutputs ---------------------------------
function sys=mdlOutputs(t,x,u)
sys = x(2);
% -----mdlTerminate -------------------------------
function sys=mdlTerminate(t,x,u)
sys = [];

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?