www.egwald.com Egwald Web Services

Egwald Web Services
Domain Names
Web Site Design

Egwald Website Search Twitter - Follow Elmer Wiens Radio Podcasts - Geraldos Hour

 

Statistics Programs - Econometrics and Probability Economics - Microeconomics & Macroeconomics Operations Research - Linear Programming and Game Theory Egwald's Mathematics Egwald's Optimal Control
Egwald HomeMathematics HomeOptimal ControlRocket CarMissile InterceptLinear PendulumLinear-Quadratic RegulatorReferences & Links
 

Egwald Mathematics: Optimal Control

Linear-Quadratic Regulator

by

Elmer G. Wiens

Egwald's popular web pages are provided without cost to users.
Follow Elmer Wiens on Twitter: Twitter - Follow Elmer Wiens

Minimum Effort Servomechanism:

Suppose I can influence the evolution of a vector of n state variables x(t) = (x1(t), ..., xn(t))T with a vector of control variables u(t) = (u1(t), ..., ur(t))T  (here the symbol "T" represents the transpose of a vector) as given by:

dx / dt = A * x(t) + B * u(t)

where A is an n x n matrix and B is an n x r matrix.

At each instance of time t, I incur a cost that depends on the values of the state variables and control variables at that time. I want to minimize the total costs over a relevant planning interval of time. Formally, the problem is as follows:

Given symmetric, nonnegative, semidefinite matrices D, (nxn), M, (nxn), and R, (nxr), and a planning interval [t0, t], choose a piecewise smooth function u from [t0, t] to Rr so as to minimize the sum of the terminal cost and running cost given by:

min J[u] = x(t)T*D*x(t) + (x(t)T*M*x(t) + x(t)T*R*u(t) + u(t)T*RT*x(t) + u(t)T*u(t) ) dt

dx / dt = A * x(t) + B * u(t)

x(t0) = x0

Because the problem above has no constraint on x(t), it is a free final state problem, with a feedback optimal control.

With a fixed final state constraint of the form x(t) = xt, the optimal control will be an open-loop control.

 


 

Finite Horizon Time Problems

Matrix Ricatti Equation:

With a finite planning horizon, t < , linear-quadratic optimal control problems are solved by finding the symmetric n x n matrix K = K(t) that satisfies the Matrix Ricatti Equation (MRE):

dK / dt + AT * K + K * A - (K * B + R) * (BT* K + RT) + M = 0,   K(t) = D

Optimal Closed Loop (Feedback) Control:

If K(t) solves MRE, then the optimal closed loop control is:

u*(t) = - (BT * K + RT) * x(t)

Evolution of the Optimal State Variables:

dx(t) / dt = A * x(t) - B * (BT * K + RT) * x(t)

          = ( A - B * (BT * K + RT) ) * x(t)

Solving these differential equations with the initial conditions x(t0) = x0 yields x = (x1, ..., xn)T as a function of time and x0.

Example 1 (Pinch 167):

Consider a system with two state variables, and A = 0, B = I, D = I, M = 0, and R = 0, where I is the identity matrix. Then

dx1 / dt = u1(t)

dx2 / dt = u2(t)

min J[u] = x12(3) + x22(3) + (u12(s) + u22(s) ) ds

      1. MRE:

dK / dt = K * K,     K(3) = D = I

K =

| k1   k3 |
| k3   k2 |

      2. Optimal Closed Loop Control:

u*(t) = - BT * K * x(t)

      3. MRE Differential Equations:

dk1 / dt = k12 + k32          k1(3) = 1

dk3 / dt = k3 * (k1 + k2)     k3(3) = 0

dk2 / dt = k32 + k22          k2(3) = 1

      4. Integrating the differential equations:

k3 = 0

k1 = 1 / (4 - t)

k2 = 1 / (4 - t)

K = (1 / (4 - t)) * I

      5. Optimal control in feedback form:

u(t) = - BT * K * x(t) = (1 / (t - 4)) * x(t)


      6. Optimal state variable trajectory:

dx(t) /dt = u(t) = (1 / (t - 4)) * x(t)


      which integrates to yield:

x(t) = - ((t - 4) / 4) * x(0)


      7. Optimal control as a function of time and x(0):

u(t) = - 1/4 * x(0)

The time paths of the state variables, x(t), and the control variables, u(t), are shown in the diagram below.

 


 

Infinite Time Horizon Problems

If the planning horizon extends to infinity, then K(t) must remain finite as t -> , requiring dK / dt = 0. To find the equilibrium K(t) = Ke, solve the Algebraic (Steady-State) Ricatti Equation (ARE):

Algebraic (Steady-State) Ricatti Equation (ARE):

AT * K + K * A - (K * B + R) * (BT* K + RT) + M = 0

Optimal Feedback Control Law:

u*(x(t)) = - (BT * K + RT) * x*(t)

Minimum Cost Solution:

J[u*] = x(0)T * K * x(0)

Example 2 (Hocking 124-25):

Consider the Rocket-Car problem with costs that depend both on position, x1(t), and energy expended, u(t).

dx1 / dt = x2(t)

dx2 / dt = u(t)

min J[u] = (4 * x1(t) * x1(t) + u(t) * u(t) ) dt

with t0 = 0, and

A =

| 0   1 |
| 0   0 |

B =

| 0 |
| 1 |

M =

| 4   0 |
| 0   0 |

D = | 0 |     R = | 0 |

      1. MRE Differential Equations:

dk1 / dt = k32 - 4           k1(t) = 0

dk3 / dt = k2 * k3 - k1     k3(t) = 0

dk2 / dt = k22 - 2 * k3     k2(t) = 0

      2. ARE Solution:

k3 = 2, k1 = +/- 4, k2 = +/- 2

      For K to be a positive definite matrix:

K =

| 4   2 |
| 2   2 |

      3. Optimal Feedback Control Law:

u*(x(t)) = - (BT * K) * x*(t) = (-2, -2) * (x1(t), x2(t))T

      4. Optimal Evolution of State Variables:

dx / dt = A * x(t) + B * u*(x(t))

dx / dt =

| 0   1 |
| 0   0 |

* (x1(t), x2(t))T +

|  0    0 |
| -2   -2 |

* (x1(t), x2(t))T

dx / dt =

|  0    1 |
| -2   -2 |

* (x1(t), x2(t))T

= Â * x(t)

      5. Optimal Trajectories of the State Variables:

     The autonomous linear differential equation above has the solution:

x*(t) = expm(Â * t) * x(0),

      where expm( * t) is the matrix exponential, e * t. The explicit solution is:

x*(t) =

| exp(-t)*cos(t)+exp(-t)*sin(t)                 exp(-t)*sin(t)       |
|           -2*exp(-t)*sin(t)          exp(-t)*cos(t)-exp(-t)*sin(t) |

* x(0)

      6. Minimum Cost Solution with (x1(0), x2(0)) = ( 2, 1 ):

J[u*] = x(0)T * K * x(0) = 26

In the diagrams below, you can see the trajectories of the state and control variables plotted as a function of time, and the phase diagram of x2(t) plotted against x1(t), with an initial position of (x1(0), x2(0)) = ( 2, 1 ).

You can change the rocket car's initial situation by entering new values for x1(0) and x2(0) in the form below the phase diagram. See how the trajectories shift, and how the phase diagram changes after you click Fire Rockets. Try x1(0) = -2.5 and x2(0) = -3, for example. When u(t) is positive, the rear rocket is firing; when u(t) is negative, the front rocket is firing. (Go to the Rocket-Car page for a full description of this optimal control problem).

Rocket Car
Reset value of x1(0): [-3.5, 3.5]
Reset value of x2(0): [-3.5, 3.5]

 


 

Works Cited and Consulted

  • Hocking, Leslie M. Optimal Control: An Introduction to the Theory with Applications. Oxford: Clarendon, 1991.
  • Intriligator, Michael D. Mathematical Optimization and Economic Theory. Englewood Cliffs: Prentice-Hall, 1971.
  • Lewis, Frank L. Optimal Control. New York: Wiley, 1986.
  • Loewen, Philip D. Math 403 Lecture Notes. Department of Mathematics, University of British Columbia. 4 Apr 2003. http://www.math.ubc.ca/~loew/m403/.
  • Pinch, Enid R. Optimal Control and the Calculus of Variations. Oxford: Oxford UP, 1993.
 
   

      Copyright © Elmer G. Wiens:   Egwald Web Services       All Rights Reserved.    Inquiries