TransferFunction.Plot.impulse(tf) or TransferFunction.Plot.impulse( tf, dt, tSpan, x0, columnLabels, defaultDiagram=Modelica_LinearSystems2.Internal.DefaultDiagramTimeResponse(), device=Modelica_LinearSystems2.Utilities.Plot.Records.Device())
This function plots the impulse response of a transfer function. It is based on timeResponse.
TransferFunction s = Modelica_LinearSystems2.TransferFunction.s(); Modelica_LinearSystems2.TransferFunction tf =(s + 1)/(s^2 + 5*s + 12); algorithm Modelica_LinearSystems2.TransferFunction.Plot.impulse(tf, dt=0.02, tSpan=3) // gives:
encapsulated function impulse import Modelica; import Modelica_LinearSystems2; import Modelica_LinearSystems2.TransferFunction; import Modelica_LinearSystems2.Utilities.Types.TimeResponse; import Modelica_LinearSystems2.Utilities.Plot; input Modelica_LinearSystems2.TransferFunction tf "transfer function"; input Real dt = 0 "Sample time [s]"; input Real tSpan = 0 "Simulation time span [s]"; input Real x0[TransferFunction.Analysis.denominatorDegree(tf)] = zeros(TransferFunction.Analysis.denominatorDegree(tf)) "Initial state vector"; extends Modelica_LinearSystems2.Internal.PartialPlotFunction(defaultDiagram = Modelica_LinearSystems2.Internal.DefaultDiagramTimeResponse(heading = "Impulse response of tf = " + String(tf))); end impulse;