The PID block can be initialized in different ways controlled by parameter initType. DoNotUse_InitialIntegratorState is added for backward compatibility reasons.
initType
|
Integrator initType
|
Derivative initType
|
NoInit
|
NoInit
|
NoInit
|
SteadyState
|
SteadyState
|
SteadyState
|
InitialState
|
InitialState
|
InitialState
|
InitialOutput and initial equation: y = y_start
|
NoInit
|
SteadyState
|
DoNotUse_InitialIntegratorState
|
InitialState
|
NoInit
|
|
|
In many cases, the most useful initial condition is SteadyState because initial transients are no longer present. If , then in some cases difficulties might occur. The reason is the equation of the integrator, . The steady state equation, leads to the condition that the input to the integrator is 0. If the input is already (directly or indirectly) defined by another initial condition, the initialization problem is singular (that is, has none or infinitely many solutions). This situation occurs often in mechanical systems, where, for example, . Because speed is both a state and a derivative, it is natural to initialize it with 0. As sketched, this is not possible. The solution is to not initialize or the variable that is used to compute by an algebraic equation. If the parameter Limits At Initial is , the limits at the output of this component are removed from the initialization problem, which leads to a much simpler equation system. After initialization has been performed, it is checked with an assert whether the output is in the defined limits.