Model Predictive Control (MPC) is an advanced method of process control that is used to control a process while satisfying a set of constraints. It has been in use in the process industries in chemical plants and oil refineries since the 1980s. In recent years it has also been used in power system balancing models and in power electronics. Model predictive controllers rely on dynamic models of the process, most often linear empirical models obtained by system identification. The main advantage of MPC is the fact that it allows the current timeslot to be optimized, while keeping future timeslots in account. This is achieved by optimizing a finite time-horizon, but only implementing the current timeslot and then optimizing again, repeatedly, thus differing from Linear-Quadratic Regulator (LQR). Also MPC has the ability to anticipate future events and can take control actions accordingly. PID controllers do not have this predictive ability. MPC is nearly universally implemented as a digital control, although there is research into achieving faster response times with specially designed analog circuitry.

State Matrix

In order to use MPC, we have to model the plant by state variables. State variable models are basically time domain models where we are interested in the dynamics of some characterizing variables called state variables which along with the input represent the state of a system at a given time.

The general structure of a state-space model of a nthn^{th} order continuous time dynamical system with mm input is given by:

x˙(t)=Ax(t)+Bu(t):StateEquationy(t)=Cx(t)+Du(t):OutputEquation(1)\dot{x}(t) = Ax(t) + Bu(t) : \quad State \quad Equation \\ y(t) = Cx(t) + Du(t) : \quad Output \quad Equation \tag{1}

Where x(t)x(t) is the nn dimensional state vector, u(t)u(t) is the mm dimensional input vector, y(t)y(t) is the pp dimensional output vector and ARn×n,BRn×m,CRp×n,DRp×mA \in R^{n \times n}, B \in R^{n \times m}, C \in R^{p \times n}, D \in R^{p \times m}

Derivation

But how to get this State Matrix from differential equations? Consider a nthn^{th} order differential equation,

dnydtn+a1dn1ydtn1+...+any=u\frac{d^ny}{dt^n} + a_1\frac{d^{n-1}y}{dt^{n-1}}+ ... + a_ny = u

Define following variables,

y=x1dydt=x2=dn1ydtn1=xndydtn=a1xn1a2xn2...anx1+uy = x_1 \\ \frac{dy}{dt} = x_2 \\ \vdots = \vdots \\ \frac{d^{n-1}y}{dt^{n-1}} = x_n \\ \frac{d^y}{dt^n} = -a_1x_{n-1} - a_2x_{n-2} - ... - a_nx_1 + u

The n^{th} order differential equation may be written in the form of nn first order differential equation as,

x˙1=x2x˙2=x3=xn˙=a1xn1a2xn2...anx1+u\dot{x}_1 = x_2 \\ \dot{x}_2 = x_3 \\ \vdots = \vdots \\ \dot{x_n} = -a_1x_{n-1} - a_2x_{n-2} - ... - a_nx_1 + u

or in matrix forms as,

x˙=Ax+Bu\dot{x} = Ax + Bu

where

A=[010...0001...0......000...1]B=[001]A = \begin{bmatrix} 0 \quad 1 \quad 0 \quad ... \quad 0 \\ 0 \quad 0 \quad 1 \quad ... \quad 0 \\ \vdots \quad ... \quad \quad ... \quad \vdots \\ 0 \quad 0 \quad 0 \quad ... \quad 1 \end{bmatrix} \quad B = \begin{bmatrix} 0 \\ 0 \\ \vdots \\ 1 \end{bmatrix}

The output can be one of states or a combination of many states. Since y=x1y=x_1,

y=[10...0]xy = [1 \quad 0 \quad ... \quad 0]x

Solution

Solve the equation (1), we could get its solution as,

x(t)=eA(tt0)x(t0)+t0teA(tτ)Bu(τ)dτx(t) = e^{A(t-t_0)}x(t_0) + {\int}_{t_0}^t e^{A(t-\tau)}Bu(\tau)d\tau

where, eAt=Φ(t)e^{At}=\Phi(t) is known as the state transition matrix and x(t0)x(t_0) is the intial state of the system.

Discretization

To be continued …

References