DUECA/DUSIME
|
A specialization of LinearSystem that implements limits on the system state. More...
#include <LimitedLinearSystem.hxx>
Public Member Functions | |
LimitedLinearSystem () | |
Default constructor. | |
LimitedLinearSystem (const Vector &num, const Vector &den, double dt) | |
This constructs a SISO system, on the basis of continuous time transfer function. | |
LimitedLinearSystem (const LimitedLinearSystem &) | |
Copy constructor. | |
LimitedLinearSystem (const Matrix &A, const Matrix &B, const Matrix &C, const Matrix &D, double dt) | |
This constructs a system, on the basis of a continuous time state space system. | |
virtual | ~LimitedLinearSystem () |
Destructor. | |
LimitedLinearSystem & | operator= (const LimitedLinearSystem &o) |
Assignment of one system to another. | |
void | setSaturationLimits (const Vector &lower, const Vector &upper) |
Set the saturation limits for the states. | |
bool | isSaturated () const |
Returns true if one or more of the states are saturated. | |
void | acceptState (const Vector &x_new) |
Accept a new state. | |
void | reset () |
Reset state, output, and saturation. | |
virtual const Vector & | step (const Vector &u) |
Calculate a single time step, return the output vector. | |
virtual const Vector & | step (double u) |
Calculate a single time step, return the output vector. | |
![]() | |
LinearSystem () | |
Default constructor. | |
LinearSystem (const Vector &num, const Vector &den, double dt) | |
This constructs a SISO system, on the basis of continuous time transfer function. | |
LinearSystem (const LinearSystem &) | |
Copy constructor. | |
LinearSystem (const Matrix &A, const Matrix &B, const Matrix &C, const Matrix &D, double dt) | |
This constructs a system, on the basis of a continuous time state space system. | |
LinearSystem (const Matrix &phi, const Matrix &psi, const Matrix &C, const Matrix &D) | |
This constructs a system, on the basis of a discrete time state space system. | |
virtual | ~LinearSystem () |
Destructor. | |
LinearSystem & | operator= (const LinearSystem &o) |
Assignment of one system to another. | |
void | createFromNumDen (const Vector &num, const Vector &den, double dt) |
Create a system from numerator, denominator input. | |
void | createFromABCD (const Matrix &A, const Matrix &B, const Matrix &C, const Matrix &D, double dt) |
Create from matrices. | |
void | createFromPhiPsiCD (const Matrix &phi, const Matrix &psi, const Matrix &C, const Matrix &D) |
Create from matrices, discrete. | |
const Vector & | getY () const |
Obtain the output vector. | |
const Vector & | getX () const |
Obtain the state vector. | |
Vector & | getX () |
Obtain the state vector for modification. | |
const Matrix & | getPhi () const |
Additional output, transition. | |
const Matrix & | getPsi () const |
Input matrix discrete system. | |
const Matrix & | getC () const |
Output matrix. | |
const Matrix & | getD () const |
Feedthrough matrix. | |
Protected Attributes | |
Vector | ul |
Upper limit. | |
Vector | ll |
Lower limit. | |
bool | saturation |
Keep track of saturation. | |
![]() | |
unsigned | n |
Order of the system. | |
unsigned | m |
Number of outputs. | |
Matrix | Phi |
Transition matrix. | |
Matrix | Psi |
Input matrix. | |
Matrix | C |
Output matrix. | |
Matrix | D |
Feedthrough matrix. | |
Vector | x |
The state vector. | |
Vector | y |
The output vector. | |
A specialization of LinearSystem that implements limits on the system state.
dueca::LimitedLinearSystem::LimitedLinearSystem | ( | const Vector & | num, |
const Vector & | den, | ||
double | dt ) |
This constructs a SISO system, on the basis of continuous time transfer function.
num | Numerator of the transfer function. Elements are arranged as num[0]*s^0 + num[1]*s^1 etc. |
den | Denominator. |
dt | Size, in seconds, of the discrete time step. |
dueca::LimitedLinearSystem::LimitedLinearSystem | ( | const Matrix & | A, |
const Matrix & | B, | ||
const Matrix & | C, | ||
const Matrix & | D, | ||
double | dt ) |
This constructs a system, on the basis of a continuous time state space system.
A | A matrix |
B | B matrix |
C | C matrix |
D | D matrix |
dt | Size, in seconds, of the discrete time step. |
|
virtual |
Accept a new state.
x_new | Vector with the new state. |
Reimplemented from dueca::LinearSystem.
|
virtual |
Reset state, output, and saturation.
Reimplemented from dueca::LinearSystem.
Calculate a single time step, return the output vector.
u | Input vector. |
Reimplemented from dueca::LinearSystem.
Reimplemented in dueca::Integrator.
|
virtual |
Calculate a single time step, return the output vector.
u | Input variable. Only valid for SI systems. |
Reimplemented from dueca::LinearSystem.
Reimplemented in dueca::Integrator.