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 xi0, which under the transformation A become multiples of themselves;

That is,

Axi=λixi

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

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 xi0.

To find the eigenvectors, we arrange equation (1). The eigenvectors, xi, satisfy

0=(λiIA)xi

Solving for xi

by premultiplying both sides by (λiIA)1 yields

xi=(λiIA)1=adj(λiIA)1det(λiIA)1=0

Since xi0,

a nonzero solution exists if

det(λiIA)=0

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(λiIA)=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

  1. First find the eigenvalues, λi, using det(λiIA)=0

  2. 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

dxdt=Ax+BudTwdt=ATw+BuTdwdt=ATw+Budwdt=T1ATw+T1Bu

7.5.4.2. Ouput transformation

Similarly for the output equation:

y=Cx+Duy=CTw+Du

7.5.4.3. Transformed Model

Therefore the new state space model is:

dwdt=Aw+Buy=Cw+Du

where A=T1AT, B=T1B, 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 T1AT is a similarity transform. That is the eigenvalues are the same as for A.

Proof

Ax=λxT1Ax=λT1x

Let x=Tw then

T1ATw=λT1Tw(T1AT)w=λw

Therefore if λ is an eigenvalue of A then it is also one of A=T1AT.

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.

T=[x1,x2,x3,,xn]

Since xi are eigenvectors,

Axi=λixi, can be written equivalently as a set of equations expressed by

AT=TΛ

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 T1, we get

Λ=T1AT

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:

w0=T1x0

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=T1x0, 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

A=[3113]

7.5.9.1.1. Solution

The eigenvectors, xi, satisfy Eq. (2). First, use det(λiIA)=0 to find the eigenvalues, λi, for Eq. (1):

det(λIA)=|[λ00λ][3113]|=|λ+311λ+3|=λ2+6λ+8

from which the eigenvalues are λ1=2 and λ2=4.

Using Eq. (1) successively with each eigenvalue, we have

Axi=λxi[3113][x1x2]=2[x1x2]

or

3x1+x2=2x1x13x2=2x2

from which x1=x2. Thus,

x=[cc]

Using the other eigenvalue, 4, we have

x=[cc]

Using Eqs. (5) and (6), one choice of eigenvectors is

x1=[11]andx2=[11]

7.5.9.2. Example 2: Similarity transformations on state equations

Given the system represented in state space by the following equations

˙x=[010001257]x+[001]uy=[100]x

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:

w1=2x1w2=3x1+2x2w3=x1+4x2+5x3

7.5.9.2.1. Solution

Expressing the transformed states in vector-matrix form,

w=[200320145]x=T1x

Thus

T1AT=[200320145][010001257][0.5000.750.500.50.40.2]=[1.5101.250.70.42.50.46.2]
T1B=[200320145][001]=[005]
CT=[100][0.5000.750.500.50.40.2]=[0.500]

Therefore the transformed system is

˙w=[1.5101.250.70.42.50.46.2]w+[005]uy=[0.500]w

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.

˙x=[3113]x+[12]uy=[23]x

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.

T=[1111]

finally form the similar systems’s system matrix, input matrix and output matrix respectively.

T1AT=[1/21/21/21/2][3113][1111]=[2004]T1B=[1/21/21/21/2][12]=[3/21/2]CT=[23][1111]=[51]

Substituting this result into the equivalent state equations gives

˙w=[2004]w+[3/21/2]uy=[51]w

Notice that the transformed system matrix is diagonal, with the eigenvalues on the diagonal.

7.5.9.4. Example 4

Solve the state equations

˙x=[3210]x+[10]u

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:

det(λIA)=0
det([λ00λ][3210])=|λ+321λ|=0(λ+3)λ+2=λ2+3λ+2=(λ+1)(λ+2)=0

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

[3210][x1x2]x1=(1)λ1[x1x2]3x12x2=x1x1+0x2=x2

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

T=[x1x2]=[1110.5]T1=[1222]

Finally solve the state equations of the transformed system

Transform the initial states:

w0=T1x0=[1222][10]=[12]

Solve for the transformed states:

w1=w1,0eλ1tw1=(1)et

and

w2=w2,0eλ2tw2=(2)e2t

Transform the answers back to the original states:

x=Tw=[1110.5][et2e2t]

Therefore

x1=et+2e2tx2=ete2t

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.

clear all
format compact
imatlab_export_fig('print-svg')  % Static svg figures.
Copy to clipboard

7.5.10.1. Eigenvalues and eigenvectors

Solution of Example 1

A = [-3 1; 1 -3]
[T, Lambda] = eig(A)
Copy to clipboard
A =
    -3     1
     1    -3
Copy to clipboard
T =
    0.7071    0.7071
   -0.7071    0.7071
Copy to clipboard
Lambda =
    -4     0
     0    -2
Copy to clipboard

Note T is the transform matrix whose columns are the eigenvectors, Λ is the diagonal matrix of eigenvalues.

7.5.10.2. Similarity transforms

Solution of Example 2

Tinv = [2 0 0; 3 2 0; 1 4 5];
T = inv(Tinv)
           
Copy to clipboard
T =
    0.5000         0         0
   -0.7500    0.5000         0
    0.5000   -0.4000    0.2000
Copy to clipboard
Ax = [0 1 0; 0 0 1; -2 -5 -7];
Bx = [0; 0; 1];
Cx = [ 1 0 0];
Copy to clipboard

Transform

Aw = Tinv*Ax*T
Copy to clipboard
Aw =
   -1.5000    1.0000         0
   -1.2500    0.7000    0.4000
   -2.5000    0.4000   -6.2000
Copy to clipboard
Bw = Tinv*Bx
Copy to clipboard
Bw =
     0
     0
     5
Copy to clipboard
Cw = Cx*T
Copy to clipboard
Cw =
    0.5000         0         0
Copy to clipboard

7.5.10.3. Using Control System Toolbox

Tinv = [2 0 0; 3 2 0; 1 4 5];
Copy to clipboard

Ax, Bx, Cx as previously defined. Dx = 0.

sysx = ss(Ax, Bx, Cx, 0)
           
Copy to clipboard
sysx =
Copy to clipboard
  A = 
Copy to clipboard
       x1  x2  x3
   x1   0   1   0
   x2   0   0   1
   x3  -2  -5  -7
Copy to clipboard
  B = 
Copy to clipboard
       u1
   x1   0
   x2   0
   x3   1
Copy to clipboard
  C = 
Copy to clipboard
       x1  x2  x3
   y1   1   0   0
Copy to clipboard
  D = 
Copy to clipboard
       u1
   y1   0
Copy to clipboard
Continuous-time state-space model.
Copy to clipboard

Perform transformation

sysw = ss2ss(sysx, Tinv)
Copy to clipboard
sysw =
Copy to clipboard
  A = 
Copy to clipboard
          x1     x2     x3
   x1   -1.5      1      0
   x2  -1.25    0.7    0.4
   x3   -2.5    0.4   -6.2
Copy to clipboard
  B = 
Copy to clipboard
       u1
   x1   0
   x2   0
   x3   5
Copy to clipboard
  C = 
Copy to clipboard
        x1   x2   x3
   y1  0.5    0    0
Copy to clipboard
  D = 
Copy to clipboard
       u1
   y1   0
Copy to clipboard
Continuous-time state-space model.
Copy to clipboard

7.5.10.4. Diagonalization

Example 3

A = [-3 1; 1 -3]; B = [1; 2]; C = [2 3];
[T,Lambda] = eig(A)
Copy to clipboard
T =
    0.7071    0.7071
   -0.7071    0.7071
Copy to clipboard
Lambda =
    -4     0
     0    -2
Copy to clipboard
Adt = inv(T)*A*T
Copy to clipboard
Adt =
   -4.0000         0
         0   -2.0000
Copy to clipboard
Bdt = inv(T)*B
Copy to clipboard
Bdt =
   -0.7071
    2.1213
Copy to clipboard
Cdt = C*T
Copy to clipboard
Cdt =
   -0.7071    3.5355
Copy to clipboard

7.5.10.5. Diagonalization using CST canon function

Example 3

A = [-3 1; 1 -3]; B = [1; 2]; C = [2 3];
Copy to clipboard
S = ss(A, B, C, 0)
Copy to clipboard
S =
Copy to clipboard
  A = 
Copy to clipboard
       x1  x2
   x1  -3   1
   x2   1  -3
Copy to clipboard
  B = 
Copy to clipboard
       u1
   x1   1
   x2   2
Copy to clipboard
  C = 
Copy to clipboard
       x1  x2
   y1   2   3
Copy to clipboard
  D = 
Copy to clipboard
       u1
   y1   0
Copy to clipboard
Continuous-time state-space model.
Copy to clipboard
Sp = canon(S, 'modal')
Copy to clipboard
Sp =
Copy to clipboard
  A = 
Copy to clipboard
       x1  x2
   x1  -2   0
   x2   0  -4
Copy to clipboard
  B = 
Copy to clipboard
           u1
   x1   2.121
   x2  0.7071
Copy to clipboard
  C = 
Copy to clipboard
           x1      x2
   y1   3.536  0.7071
Copy to clipboard
  D = 
Copy to clipboard
       u1
   y1   0
Copy to clipboard
Continuous-time state-space model.
Copy to clipboard

7.5.11. Footnotes

  1. 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(λIA)=0 that is used to find the eignenvalues of a system is mathematically identical to det(sIA)=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.

  2. 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!