7.5. Transformation of States and System Diagonalization¶
The canonical forms described in the last section give different descriptions of the same transfer function (TF) and are therefore equivalent in their overall input-output relationship. This means that it should be possible to convert one canonical form into another by the operation of simple matrix operations. Furthermore, by transforming a system to the normal form, determining the response and mapping back, it is possible to determine the total system response of any state space system.
The eigenvalues of the state matrix A have an important influence on the system response and understanding them is key to understanding the general solution of state-space systems.
In this section we define eigenvalues and eigenvectors, show the system transformation method and prove that it has no impact on the system eigenvalues, show how it can be used to transform an arbitrary state-space model into one with a diagonal (normal) structure, and finally we use these results to find a general time-response solution to the state space equations.
7.5.1. Pre-Class Presentation: Transformation of State Models¶
For a given transfer function the canonical forms are equivalent in their input-output relationships.
We can convert one form of canonical system into another by the application of simple matrix operations.
Transforming to normal form simplifies the calculation of system response.
The eigenvalues of the A matrix are key to the process.
Knowledge of a system’s eigenvalues means that we can determine the system response of any LTI system.
7.5.2. Section Contents¶
Eigenvalues and eigenvectors
System transformation
Diagonalization of a state space model
Solution to the general state equations
7.5.3. Eigenvalues and Eigenvectors¶
7.5.3.1. Definition of an Eigenvector¶
The eignevectors1 of the matrix A are all vectors xi≠0, which under the transformation A become multiples of themselves;
That is,
where each λi is a constant called an eigenvalue.
Figure 1 illustrates this definition of eigenvectors. If Ax is not collinear with x after the transformation, x is not an eigenvector. If Ax is collinear with x after the transformation, x is an eigenvector.
7.5.3.2. Figure 1: Eigenvectors and Transformations¶
To be an eigenvector, the transformation Ax must be collinear with x. Thus, in (a), x is not an eigenvector: in (b), it is.
7.5.3.3. Eigenvalues¶
The eigenvalues of the matrix A are the values of λi that satisfy (1) for xi≠0.
To find the eigenvectors, we arrange equation (1). The eigenvectors, xi, satisfy
Solving for xi
by premultiplying both sides by (λiI−A)−1 yields
Since xi≠0,
a nonzero solution exists if
From which λi, the eigenvalues, can be found.
We are now ready to show how to find the eigenvectors xi. First we find the eigenvalues, λi, using det(λiI−A)=0, and then we use equation (1) to find the eigenvectors.
7.5.3.4. Finding the eigenvectors of a system¶
To find the eigenvectors xi of a system matrix A
First find the eigenvalues, λi, using det(λiI−A)=0
Use Axi=λixi to find the eigenvectors.
We will work through an example in class.
7.5.4. Transformation of State Space Models¶
Suppose we have a state space model with states x and matrices A, B, C and D and we wish to transform to a model with states w where x=Tw. T is the transformation matrix for the states.
7.5.4.1. State transformation¶
7.5.4.3. Transformed Model¶
Therefore the new state space model is:
where A′=T−1AT, B′=T−1B, C′=CT, and D′=D.
This should not be surprising since the poles of the system being modelled correspond to the eigenvalues of the state matrix, whatever the choice of states.
7.5.4.4. Similarity Transform Preserves Eigenvalues¶
The transformation T−1AT is a similarity transform. That is the eigenvalues are the same as for A.
Proof
Let x=Tw then
Therefore if λ is an eigenvalue of A then it is also one of A′=T−1AT.
QED.
7.5.5. Diagonalization of a System Matrix¶
If we choose the eigenvectors of a system matrix A to be the basis of a transformation, T, the resulting system matrix will be in the diagonal normal form. Let the transformation matrix T consist of the eigenvectors of A, xi.
Since xi are eigenvectors,
Axi=λixi, can be written equivalently as a set of equations expressed by
where Λ is a matrix which has the eigenvalues λi on the diagonal in some order and zeros elsewhere, and T is as defined in Eq. (8).
Solving Eq. (9) for Λ by premultiplying by T−1, we get
which is the system matrix in normal canonical form.2
In summary, under the transformation T, consisting of the eigenvalues of the system matrix, the transformed system is identical to that obtained using the partial fraction expansion of the transfer function with distinct real roots.
7.5.6. Using Diagonalization to Solve State Equations¶
It is possible to obtain solutions for the state equations in any set of states, x, by transforming to normal canonical form and solving the latter’s states, w, as shown in Section 7.4.
The initial states are found, using the inverse transformation, as:
The solutions to the original states can then be found from w using the transformation $x=Tw$
Since the state space model for w is in normal form then the state matrix, A′=Λ, is diagonal with the eigenvalues of A in some order on the diagonal.
As demonstrated above, the columns of the transformation matrix, T will be formed by concatenation of the corresponding eigenvectors of A in the same order.
7.5.6.1. Solution of General State Equations¶
In Section 7.4 we showed how we could determine the solution to a state equation in normal (diagonal form).
Here we have demonstrated how to use the eignenvalues and eigenvectors to transform a model in state space form to the normal form.
Thus if we have w the initial states will be w0=T−1x0, and
The solutions to the original states can then be found from w using the transformation x=Tw
Example 4 illustrates the procedure.
7.5.7. Summary of Pre-Class Presentation¶
Eigenvalues and eigenvectors
System transformation
Diagonalization of a state space model
Solution to the general state equations
7.5.8. Activities for Class¶
Worked Examples (solutions in notes)
System Transformations in Matlab
7.5.9. Worked Examples¶
7.5.9.1. Example 1: finding eigenvectors¶
Find the eigenvectors of the matrix
7.5.9.1.1. Solution¶
The eigenvectors, xi, satisfy Eq. (2). First, use det(λiI−A)=0 to find the eigenvalues, λi, for Eq. (1):
from which the eigenvalues are λ1=−2 and λ2=−4.
Using Eq. (1) successively with each eigenvalue, we have
or
from which x1=x2. Thus,
Using the other eigenvalue, −4, we have
Using Eqs. (5) and (6), one choice of eigenvectors is
7.5.9.2. Example 2: Similarity transformations on state equations¶
Given the system represented in state space by the following equations
transform the system to a new set of state variables, w, where the new state variables are related to the original state variables, x, as follows:
7.5.9.2.1. Solution¶
Expressing the transformed states in vector-matrix form,
Thus
Therefore the transformed system is
7.5.9.3. Example 3: Diagonalization of a system in state space¶
Given the system shown below, find the diagonal (normal form) system that is similar.
7.5.9.3.1. Solution¶
First find the eigenvalues and the eigenvectors. This step was performed in Example 1. Next form the transformation matrix T, whose columns are the eignevectors.
finally form the similar systems’s system matrix, input matrix and output matrix respectively.
Substituting this result into the equivalent state equations gives
Notice that the transformed system matrix is diagonal, with the eigenvalues on the diagonal.
7.5.9.4. Example 4¶
Solve the state equations
given x0=[1,0]T at t=0 and u=0.
7.5.9.4.1. Solution¶
First find the eigenvalues: The eigenvalues of the state matrix are the roots of:
Thus λ1=−1 and λ2=−2.
Next, find the transformation matrix: The eigenvectors are the solutions of Axi=λixi for i=1,2.
For i=1
These equations are linearly dependent, and if we let x1=1 then x2=−1 giving x1=[1, −1]T.
Similarly, for i=2 we obtain x2=[1,−0.5]T.
Then
Finally solve the state equations of the transformed system
Transform the initial states:
Solve for the transformed states:
and
Transform the answers back to the original states:
Therefore
7.5.10. System Transformations in MATLAB¶
MATLAB provides a rich set of tools for finding eigenvalues and eigenvectors, transforming state equations using similarity transforms and solving state space equations. We conclude this lecture by reworking the first three examples in Matlab. You should repeat these examples during the self-directed learning session.
7.5.10.1. Eigenvalues and eigenvectors¶
Solution of Example 1
Note T is the transform matrix whose columns are the eigenvectors, Λ is the diagonal matrix of eigenvalues.
7.5.10.3. Using Control System Toolbox¶
Ax
, Bx
, Cx
as previously defined. Dx
= 0.
Perform transformation
7.5.11. Footnotes¶
The world eigen is from the German for “characteristic” so another name for eigenvalue might be characteristic value. There is a very close relationship between the eigenvalues and the characteristic equation we have discussed in earlier lectures. Indeed as we shall see, the equation det(λI−A)=0 that is used to find the eignenvalues of a system is mathematically identical to det(sI−A)=0 that determines the poles of the system defined in transfer function form. That is, (s=pi is a pole of system with transfer function G(s) if p1=λi). From this is should be clear that the eigenvalues of the A matrix are the same as the poles of the corresponding transfer function.
Note we need to perform some additional manipulations if there are repeated or complex eigenvalues. We leave the discovery of these extra steps as an exercise for the interested student. It will not be examined!