3.2 StateSpace Representations
Continuoustime statespace systems (Figure 3.1)
and discretetime statespace systems (Figure 3.2)
are represented by the StateSpace data structure; this guide refers to component matrices using the same symbols, , , , and . Here is the state (or evolution) matrix, is the input (or control) matrix, is the output (or observation) matrix, and is the direct transmission (or feedthrough) matrix. Keeping the same notation for continuous and discretetime systems is common in the literature and allows sharing many concepts and algorithms that are essentially identical. (It is also common to use , , , and instead of , , , and for continuoustime systems and and instead of and in the discretetime case.)
To distinguish between the two types of systems, the option Sampled is introduced in Section 3.3.
Statespace data structure.
Figure 3.1. Statespace model of a continuoustime system.
Figure 3.2. Statespace model of a discretetime system.
The StateSpace objects can contain as few as two matrices a and b, but for most functions, at least matrix c and optionally d are required too. If matrices c and d are absent, no assumptions are made about them; if only matrix d is absent, it is routinely assumed to be a zero matrix. The truncated StateSpace[a, b] representation is, of course, of limited value, but contains all the necessary information, for instance, for state feedback regulator design (Section 9.1).
Here is a secondorder SISO system with no direct transition term.
In[22]:=
Out[22]=
This is the same system with a zero direct transition term added.
In[23]:=
Out[23]=
The two systems yield the same transfer function and so correspond to the same physical system.
In[24]:=
Out[24]=
Obtaining statespace realizations of transfer functions.
The statespace representation can be obtained directly from the differential equations of the system (difference equations in the case of a discretetime system) or from the transfer matrix. In the latter case, the target form of the statespace model can be specified by the option TargetForm, with the default value ControllableCompanion that corresponds to the controllable companion form, constructed by inspection. The adopted definition of the controllable companion form is due to, for example, Gopal (1993). (In the literature, this form is sometimes referred to as the controllable canonical form.) For the strictly proper transfer matrix
of size , where are of that size as well, and being the number of inputs and outputs, respectively, the controllable companion realization is assumed to be
where and are zero and identity matrices of size and the matrix is zero. The dimension of the system is . If the transfer matrix is proper (but not strictly proper), the same representation of the strictly proper part of holds while the matrix can be found as
Similarly, the observable companion realization is
where and are zero and the identity matrices of size and the dimension of the system is . This form can be obtained using the option TargetForm ObservableCompanion. Note that the controllable and observable companion forms may not be of minimal order and, as a rule, are illconditioned. Chapter 8 describes the methods to transform the model further.
Here is a transfer function.
In[25]:=
Out[25]=
This produces the controllable companion realization.
In[26]:=
Out[26]=
The structure of the statespace system is more transparent with the use of TraditionalForm (Section 3.4). Clearly, this is not the minimalorder model.
In[27]:=
Out[27]//TraditionalForm=
This reduces the order of the system using the function MinimalRealization described in Section 8.1. To obtain a simpler result, we assert that none of the symbolic variables are complex.
In[28]:=
Out[28]//TraditionalForm=
This produces the observable companion realization.
In[29]:=
Out[29]//TraditionalForm=
It is easy to demonstrate that both realizations correspond to the initial system.
In[30]:=
Out[30]=
By itself, StateSpace does not check the consistency of component matrices; however, the consistency is the prerequisite for many other functions to operate in a meaningful way. Consistency here means that matrix a must be square, , where is the number of states; matrix b must be , where is the number of inputs; matrix c must be , where is the number of outputs; and matrix d, if used, must be . When entering statespace objects manually, these requirements should be kept in mind. The function ConsistentQ checks that they are satisfied.
StateSpace, as well as other control objects, accepts options, which could, if so desired, come wrapped in lists. Therefore, caution should be exercised to not confuse an empty list of options with an empty matrix in a control object's description. For this reason, parsing an empty list as a valid list of options is disallowed for all control objects as well as in other functions in Control System Professional where this may cause a confusion.
