|
| KalmanFilter (Gaussian *prior) |
| Constructor.
|
|
virtual | ~KalmanFilter () |
| Destructor.
|
|
virtual Gaussian * | PostGet () |
| Get Posterior density.
|
|
void | AllocateMeasModel (const vector< unsigned int > &meas_dimensions) |
| Function to allocate memory needed during the measurement update,.
|
|
void | AllocateMeasModel (const unsigned int &meas_dimensions) |
| Function to allocate memory needed during the measurement update.
|
|
virtual void | Reset (Pdf< MatrixWrapper::ColumnVector > *prior) |
| Reset Filter.
|
|
virtual bool | Update (SystemModel< MatrixWrapper::ColumnVector > *const sysmodel, const MatrixWrapper::ColumnVector &u, MeasurementModel< MatrixWrapper::ColumnVector, MatrixWrapper::ColumnVector > *const measmodel, const MatrixWrapper::ColumnVector &z, const MatrixWrapper::ColumnVector &s) |
| Full Update (system with inputs/sensing params)
|
|
virtual bool | Update (SystemModel< MatrixWrapper::ColumnVector > *const sysmodel, MeasurementModel< MatrixWrapper::ColumnVector, MatrixWrapper::ColumnVector > *const measmodel, const MatrixWrapper::ColumnVector &z, const MatrixWrapper::ColumnVector &s) |
| Full Update (system without inputs, with sensing params)
|
|
virtual bool | Update (SystemModel< MatrixWrapper::ColumnVector > *const sysmodel, MeasurementModel< MatrixWrapper::ColumnVector, MatrixWrapper::ColumnVector > *const measmodel, const MatrixWrapper::ColumnVector &z) |
| Full Update (system without inputs/sensing params)
|
|
virtual bool | Update (SystemModel< MatrixWrapper::ColumnVector > *const sysmodel, const MatrixWrapper::ColumnVector &u, MeasurementModel< MatrixWrapper::ColumnVector, MatrixWrapper::ColumnVector > *const measmodel, const MatrixWrapper::ColumnVector &z) |
| Full Update (system with inputs, without sensing params)
|
|
virtual bool | Update (SystemModel< MatrixWrapper::ColumnVector > *const sysmodel, const MatrixWrapper::ColumnVector &u) |
| System Update (system with inputs)
|
|
virtual bool | Update (SystemModel< MatrixWrapper::ColumnVector > *const sysmodel) |
| System Update (system without inputs)
|
|
virtual bool | Update (MeasurementModel< MatrixWrapper::ColumnVector, MatrixWrapper::ColumnVector > *const measmodel, const MatrixWrapper::ColumnVector &z, const MatrixWrapper::ColumnVector &s) |
| Measurement Update (system with "sensing params")
|
|
virtual bool | Update (MeasurementModel< MatrixWrapper::ColumnVector, MatrixWrapper::ColumnVector > *const measmodel, const MatrixWrapper::ColumnVector &z) |
| Measurement Update (system without "sensing params")
|
|
int | TimeStepGet () const |
| Get current time.
|
|
|
void | PostSigmaSet (const MatrixWrapper::SymmetricMatrix &s) |
| Set covariance of posterior estimate.
|
|
void | PostMuSet (const MatrixWrapper::ColumnVector &c) |
| Set expected value of posterior estimate.
|
|
void | CalculateSysUpdate (const MatrixWrapper::ColumnVector &J, const MatrixWrapper::Matrix &F, const MatrixWrapper::SymmetricMatrix &Q) |
|
void | CalculateMeasUpdate (const MatrixWrapper::ColumnVector &z, const MatrixWrapper::ColumnVector &Z, const MatrixWrapper::Matrix &H, const MatrixWrapper::SymmetricMatrix &R) |
|
virtual void | SysUpdate (SystemModel< MatrixWrapper::ColumnVector > *const sysmodel, const MatrixWrapper::ColumnVector &u)=0 |
| System Update.
|
|
virtual void | MeasUpdate (MeasurementModel< MatrixWrapper::ColumnVector, MatrixWrapper::ColumnVector > *const measmodel, const MatrixWrapper::ColumnVector &z, const MatrixWrapper::ColumnVector &s)=0 |
| Measurement Update (overloaded)
|
|
virtual bool | UpdateInternal (SystemModel< MatrixWrapper::ColumnVector > *const sysmodel, const MatrixWrapper::ColumnVector &u, MeasurementModel< MatrixWrapper::ColumnVector, MatrixWrapper::ColumnVector > *const measmodel, const MatrixWrapper::ColumnVector &z, const MatrixWrapper::ColumnVector &s) |
| Actual implementation of Update, varies along filters.
|
|
void | CalculateNis (const MatrixWrapper::ColumnVector &z, const MatrixWrapper::ColumnVector &Z, const MatrixWrapper::Matrix &H, const MatrixWrapper::SymmetricMatrix &R) |
|
Class representing the family of all Kalman Filters (EKF, IEKF, ...)
This is a class representing the family of all Kalman Filter (KF). Kalman filters are filters in which the Posterior density is represented by a Gaussian density. Kalman filters are only applicable to continuous systems.
The system of updating the Posterior density is implemented in this base class. However, the parameters used for this update differ for different KFs (Simple KF,EKF,IEKF): that's why the xUpdate members are still pure virtual functions.
This class is the base class for all sorts of KFs.
- See also
- Gaussian
-
LinearAnalyticSystemModelGaussianUncertainty
Definition at line 49 of file kalmanfilter.h.
virtual void MeasUpdate |
( |
MeasurementModel< MatrixWrapper::ColumnVector, MatrixWrapper::ColumnVector > *const | measmodel, |
|
|
const MatrixWrapper::ColumnVector & | z, |
|
|
const MatrixWrapper::ColumnVector & | s ) |
|
protectedpure virtual |
Measurement Update (overloaded)
Update the filter's Posterior density using the sensor measurements, an input and the measurement model. This method is used when the measurements depend on the inputs too (doesn't happen very often, does it?) BEWARE: the first time the measurment update is called with a new size of measurement, new allocations are done
- Parameters
-
measmodel | pointer to the measurement model the filter should use |
z | sensor measurement |
s | input to the system (must be of the same type as u for now, since this was not yet implemented in ConditionalPdf |
Implemented in ExtendedKalmanFilter, IteratedExtendedKalmanFilter, and SRIteratedExtendedKalmanFilter.
Pdf<MatrixWrapper::ColumnVector >* _post |
|
protectedinherited |
Pointer to the Posterior Pdf.
The Posterior Pdf represents the subjective belief of the person applying the filter AFTER processing inputs and measurements. A filter does not maintain the beliefs at all timesteps t, since this leads to non-constant (or ever growing if you prefer) memory requirements. However, it is possible, to copy the Posterior density at all timesteps in your application by means of the PostGet() member function
- See also
- PostGet()
Definition at line 95 of file filter.h.