(y, t, x) = ZerosAndPoles.Analysis.impulseResponse(zp, dt, tSpan)
Function impulseResponse calculates the time response of a ZerosAndPoles transfer function with impulse input. The system is first transformed zo a state space system, which is transformed to a appropriate discrete state space system and, starting at x(t=0)=0 and y(t=0)=C*x0 + D*u0, the outputs y and x are calculated for each time step t=k*dt.
ZerosAndPoles.Analysis.impulseResponse(zp, dt, tSpan)
gives the same result as
ZerosAndPoles.Analysis.timeResponse(zp, dt, tSpan, response=Types.TimeResponse.Impulse, x0=fill(0,ZerosAndPoles.Analysis.denominatorDegree(zp))).
Modelica_LinearSystems2.ZerosAndPoles zp=zp=1/(p^2 + p + 1) Real Ts=0.1; Real tSpan= 0.4; Real y[5,1,1]; Real t[5]; Real x[5,1,1] algorithm (y,t,x):=Modelica_LinearSystems2.ZerosAndPoles.Analysis.impulseResponse(zp,Ts,tSpan); // y[:,1,1]={0, 0.095, 0.18, 0.2553, 0.321} // t={0, 0.1, 0.2, 0.3, 0.4} // x[:,1,1]={0, 0.095, 0.18, 0.2553, 0.321}
ZerosAndPoles.Analysis.timeResponse
encapsulated function impulseResponse import Modelica; import Modelica_LinearSystems2; import Modelica_LinearSystems2.ZerosAndPoles; extends Modelica_LinearSystems2.Internal.timeResponseMask2_zp; end impulseResponse;