Main Content

Model Reference Adaptive Control

The Model Reference Adaptive Control block computes control actions to make an uncertain controlled system track the behavior of a given reference plant model. Using this block, you can implement the following model reference adaptive control (MRAC) algorithms.

  • Direct MRAC — Estimate the feedback and feedforward controller gains based on the real-time tracking error between the states of the reference plant model and the controlled system.

  • Indirect MRAC — Estimate the parameters of the controlled system based on the tracking error between the states of the reference plant model and the estimated system. Then, derive the feedback and feedforward controller gains based on the parameters of the estimated system and the reference model.

Both direct and indirect MRAC also estimate a model of the external disturbances and uncertainty in the system being controlled. The controller then uses this model to compensate for the disturbances and uncertainty when computing control actions.

In both cases, the controller updates the estimated parameters and disturbance model in real-time based on the tracking error.

Reference Model

For both direct and indirect MRAC, the following reference plant model is the ideal system that characterizes the desired behavior that you want to achieve in practice.

x˙m(t)=Amxm(t)+Bmr(t)

Here:

  • r(t) is the external reference signal.

  • xm(t) is the state of the reference plant model. Since r(t) is known, you can simulate the reference model to get xm(t).

  • Am is a constant state matrix. For a stable reference model, Am must be a Hurwitz matrix for which every eigenvalue must have a strictly negative real part.

  • Bm is a control effective matrix.

Disturbance and Uncertainty Model

The Model Reference Adaptive Control block maintains an internal model uad of the disturbance and model uncertainty in the controlled system.

uad=wTϕ(x)

Here, ϕ(x) is a vector of model features. w is an adaptive control weight vector that the controller updates in real time based on the tracking error.

To define ϕ(x), you can use one of the following feature definitions.

  • State vector of the controlled plant — This approach can under-represent the uncertainty in the system. Using the states as features can be a useful starting point when you do not know the complexity of the disturbance and model uncertainty.

  • Gaussian radial basis functions — Use this option when the disturbance and model uncertainty are nonlinear and the structure of the disturbance model is unknown. Radial basis functions require some prior knowledge of the operation domain of the model, which can be difficult for some cases.

  • Single hidden layer neural network — Use this option when the disturbance and model uncertainty are nonlinear and the structure of the disturbance model is unknown and you do not have prior knowledge of the operating domain. The neural network is a universal function approximator that can approximate any continuous function.

  • External source provided to the controller block — Use this option to define your own custom feature vector. You can use this option when you know the structure of the disturbance and uncertainty model. For example, you can use a custom feature vector to identify specific unknown plant parameters.

Direct MRAC

A direct MRAC controller has the following control structure.

Direct MRAC control structure with feedforward and feedback gains and a disturbance model all updated based on the tracking error between the states of a reference model and the controlled system.

The controller computes the control input u(t) as follows.

u(t)=kxx(t)+krr(t)uaduad=wTϕ(x)

Here:

  • x(t) is the state of the controlled system.

  • r(t) is the external reference signal.

  • kx and kr are the feedback and feedforward controller gains, respectively.

  • uad is the adaptive control component derived from the disturbance model.

    ϕ(x) contains the disturbance model features.

  • w is an adaptive disturbance model weight vector.

  • V is the hidden layer weight vector.

For a single hidden layer neural network, uad is:

uad=wTσ(VTx)

Here:

  • V is the hidden layer weight vector.

  • σ is a sigmoid activation function.

The controller computes the error e(t) between the states of the controlled system and the states of the reference model. It then uses that error to adapt the values of kx, kr, and w in real time.

Nominal Model

The controlled system, which typically exhibits modeling uncertainty and external disturbances, has the following nominal state equation. The controller uses this expected nominal plant behavior when updating the controller parameters.

x˙(t)=Ax(t)+B(u(t)+f(x))

Here:

  • x(t) is the state of the system you want to control.

  • u(t) is the control input.

  • A is a constant state-transition matrix.

  • B is a constant control effective matrix.

  • f(x) is the matched uncertainty in the system.

Parameter Updates

A direct MRAC controller uses the following equations to update the controller gains and disturbance model weights for state vector, radial basis function, and external source feature definitions [1] [2].

k˙x=Γxx(t)eT(t)PBk˙r=Γrr(t)eT(t)PBw˙=Γwϕ(x)eT(t)PB

A single hidden layer disturbance model update equations use the same controller gain updates along with the following update equations.

w˙=(σ(VTx)σ(VTx)VTx)eT(t)PBΓwV˙=ΓVxeT(t)PBwTσ(VTx)

Here, P is the solution to the following Lyapunov function based on the reference model state matrix and B is the control effective matrix from the nominal plant model.

AmTP+PAm+Q=0

Here, Q is a positive definite matrix of size N-by-N, where N is size of state vector x(t)

Indirect MRAC

An indirect MRAC controller has the following control structure. The reference model is

Indirect MRAC control structure with a disturbance model and estimator model updated based on tracking errors

The controller computes the control input u(t) as follows.

u(t)=kxx(t)+krr(t)uaduad=wTϕ(x)

Here:

  • x^(t) is the estimated state of the controlled system produced by an estimator model.

  • r(t) is the external reference signal.

  • kx and kr are the feedback and feedforward controller gains, respectively.

  • uad is the adaptive control component derived from the disturbance model.

    ϕ(x) contains the disturbance model features.

  • w is an adaptive disturbance model weight vector.

The controller computes the error e(t) between the actual and estimated system states. It then uses that error to adapt the values of w in real time. The controller also uses e(t) to update the parameters of the estimator model in real time. The values of gains kx and kr are derived from the parameters of the estimator model and reference model.

Estimator Model and Controller Gains

The indirect MRAC controller contains the following estimator model of the controlled system.

x^˙(t)=A^x(t)+B^u(t)

Here:

  • x^(t) is the estimated system state.

  • u(t) is the control input.

  • A^ is the state-transition matrix of the estimator.

  • B^ is the control effective matrix of the estimator.

During operation the controller updates A^ and B^ based on the estimation error e(t).

Rather than estimate the controller gains directly, an indirect MRAC controller derives the feedback gain kx and feedforward gain kr from the parameters of the reference and estimator models using a dynamic inversion-based approach as follows.

kr=BmB^kx=1B^(AmA^)

Here, 1B^ is the Moore-Penrose pseudoinverse of the matrix B^.

Parameter Updates

An indirect MRAC controller uses the following equations to update the estimator model parameters and disturbance model weights for state vector, radial basis function, and external source feature definitions [1] [2].

A^˙=Γax(t)eT(t)PB^˙=Γbu(t)eT(t)Pw˙=Γwϕ(x)eT(t)PB

A single hidden layer disturbance model update equations use the same estimator model parameter updates along with the following update equations.

w˙=(σ(VTx)σ(VTx)VTx)eT(t)PBΓwV˙=ΓVxeT(t)PBwTσ(VTx)

Here, P is the solution to the following Lyapunov function.

kτTP+Pkτ+Q=0

kτ is the estimator feedback gain. By default, this value corresponds to the reference model state-transition matrix Am. However, you can specify a different estimator feedback gain value.

Learning Modification

For both direct and indirect MRAC, to add robustness at higher learning rates, you can modify the parameter updates to include an optional momentum term. You can choose one of two possible learning modification methods: sigma modification and e-modification.

For sigma modification, the momentum term for each parameter update is the product of the momentum weight parameter σ and the current parameter value. For example, the following update equations for a direct MRAC controller include a sigma modification term.

k˙x=Γxx(t)eT(t)PB+σkxk˙r=Γrr(t)eT(t)PB+σkxw˙x=Γwϕ(t)eT(t)PB+σw

For e-modification, the controller scales the sigma-modification momentum term by the norm of the error vector. For example, the following update equations for an indirect MRAC controller include an e-modification term.

A^˙=Γax(t)eT(t)P+σ|e(t)|A^B^˙=Γbu(t)eT(t)P+σ|e(t)|B^w˙x=Γwϕ(t)eT(t)PB+σ|e(t)|w

To adjust the amount of the learning modification for either method, change the value of the momentum weight parameter σ.

More About Model Reference Adaptive Control

For more information on model reference adaptive control, play the video. This video is part of the Learning-Based Control video series.

Model Reference Adaptive Control Introduction and Overview
Video Player is loading.
Current Time 0:00
Duration 0:00
Loaded: 0%
Stream Type LIVE
Remaining Time 0:00
 
1x
  • Chapters
  • descriptions off, selected
  • captions off, selected

      References

      [1] Ioannou, Petros A., and Jing Sun. Robust Adaptive Control, Courier Corporation, 2012.

      [2] Narendra, Kumpati S, and Anuradha M Annaswamy. Stable Adaptive Systems. Courier Corporation, 2012.

      [3] Narendra, Kumpati S., and Anuradha M. Annaswamy. “Robust Adaptive Control.” In 1984 American Control Conference, 333–35. San Diego, CA, USA: IEEE, 1984. https://doi.org/10.23919/ACC.1984.4788398.

      See Also

      Blocks

      Related Topics

      Go to top of page