1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
| function [sys,x0,str,ts] = intarzii(t,x,u,flag,vect1,vect2,samples)
switch flag,
case 0,
[sys,x0,str,ts]=mdlInitializeSizes(vect1,vect2,samples);
case 1,
sys=mdlDerivatives(t,x,u);
case 2,
sys=mdlUpdate(t,x,u,vect1,vect2,samples);
case 3,
sys=mdlOutputs(t,x,u,vect1,vect2,samples);
case 4,
sys=mdlGetTimeOfNextVarHit(t,x,u);
case 9,
sys=mdlTerminate(t,x,u);
otherwise
error(['Unhandled flag = ',num2str(flag)]);
end
function [sys,x0,str,ts]=mdlInitializeSizes(vect1,vect2,samples)
sizes = simsizes;
lungime=(sum(vect1)+sum(vect2)+1)*samples;
nr=(length(vect1)+length(vect2)+2*(samples-1));
sizes.NumContStates = 0;
sizes.NumDiscStates = nr;
sizes.NumOutputs = lungime;
sizes.NumInputs = 2;
sizes.DirFeedthrough = 1;
sizes.NumSampleTimes = 1;
sys = simsizes(sizes);
x0=zeros(1,nr);
str = [];
ts = [-1 0];
function sys=mdlDerivatives(t,x,u)
sys = []; |
Partager