A Constrained constrained model is a specialization of Diagonal which allows some or all of the sigmas to be zero, forcing the error to be zero there.
All other Gaussian models are guaranteed to have a non-singular square-root information matrix, but this class is specifically equipped to deal with singular noise models, specifically: whiten will return zero on those components that have zero sigma and zero error, unchanged otherwise.
While a hard constraint may seem to be a case in which there is infinite error, we do not ever produce an error value of infinity to allow for constraints to actually be optimized rather than self-destructing if not initialized correctly.
|
| Constrained (const Vector &sigmas=Z_1x1) |
| protected constructor takes sigmas. More...
|
|
bool | isConstrained () const override |
| true if a constrained noise mode, saves slow/clumsy dynamic casting More...
|
|
bool | constrained (size_t i) const |
| Return true if a particular dimension is free or constrained.
|
|
const Vector & | mu () const |
| Access mu as a vector.
|
|
double | squaredMahalanobisDistance (const Vector &v) const override |
| The squaredMahalanobisDistance function for a constrained noisemodel, for non-constrained versions, uses sigmas, otherwise uses the penalty function with mu. More...
|
|
void | print (const std::string &name) const override |
|
Vector | whiten (const Vector &v) const override |
| Calculates error vector with weights applied. More...
|
|
Matrix | Whiten (const Matrix &H) const override |
| Whitening functions will perform partial whitening on rows with a non-zero sigma. More...
|
|
void | WhitenInPlace (Matrix &H) const override |
| In-place version. More...
|
|
void | WhitenInPlace (Eigen::Block< Matrix > H) const override |
| In-place version. More...
|
|
Diagonal::shared_ptr | QR (Matrix &Ab) const override |
| Apply QR factorization to the system [A b], taking into account constraints Q' * [A b] = [R d] Dimensions: (r*m) * m*(n+1) = r*(n+1), where r = min(m,n). More...
|
|
shared_ptr | unit () const |
| Returns a Unit version of a constrained noisemodel in which constrained sigmas remain constrained and the rest are unit scaled.
|
|
| Diagonal () |
| constructor - no initializations, for serialization
|
|
void | print (const std::string &name) const override |
|
Vector | sigmas () const override |
| Calculate standard deviations. More...
|
|
Vector | whiten (const Vector &v) const override |
| Whiten an error vector. More...
|
|
Vector | unwhiten (const Vector &v) const override |
| Unwhiten an error vector. More...
|
|
Matrix | Whiten (const Matrix &H) const override |
| Multiply a derivative with R (derivative of whiten) Equivalent to whitening each column of the input matrix. More...
|
|
void | WhitenInPlace (Matrix &H) const override |
| In-place version. More...
|
|
void | WhitenInPlace (Eigen::Block< Matrix > H) const override |
| In-place version. More...
|
|
double | sigma (size_t i) const |
| Return standard deviations (sqrt of diagonal)
|
|
const Vector & | invsigmas () const |
| Return sqrt precisions.
|
|
double | invsigma (size_t i) const |
|
const Vector & | precisions () const |
| Return precisions.
|
|
double | precision (size_t i) const |
|
Matrix | R () const override |
| Return R itself, but note that Whiten(H) is cheaper than R*H. More...
|
|
| Gaussian (size_t dim=1, const boost::optional< Matrix > &sqrt_information=boost::none) |
| constructor takes square root information matrix
|
|
void | print (const std::string &name) const override |
|
bool | equals (const Base &expected, double tol=1e-9) const override |
|
Vector | sigmas () const override |
| Calculate standard deviations. More...
|
|
Vector | whiten (const Vector &v) const override |
| Whiten an error vector. More...
|
|
Vector | unwhiten (const Vector &v) const override |
| Unwhiten an error vector. More...
|
|
Matrix | Whiten (const Matrix &H) const override |
| Multiply a derivative with R (derivative of whiten) Equivalent to whitening each column of the input matrix. More...
|
|
virtual void | WhitenInPlace (Matrix &H) const |
| In-place version. More...
|
|
virtual void | WhitenInPlace (Eigen::Block< Matrix > H) const |
| In-place version. More...
|
|
void | WhitenSystem (std::vector< Matrix > &A, Vector &b) const override |
| Whiten a system, in place as well. More...
|
|
void | WhitenSystem (Matrix &A, Vector &b) const override |
|
void | WhitenSystem (Matrix &A1, Matrix &A2, Vector &b) const override |
|
void | WhitenSystem (Matrix &A1, Matrix &A2, Matrix &A3, Vector &b) const override |
|
virtual boost::shared_ptr< Diagonal > | QR (Matrix &Ab) const |
| Apply appropriately weighted QR factorization to the system [A b] Q' * [A b] = [R d] Dimensions: (r*m) * m*(n+1) = r*(n+1), where r = min(m,n). More...
|
|
virtual Matrix | R () const |
| Return R itself, but note that Whiten(H) is cheaper than R*H. More...
|
|
virtual Matrix | information () const |
| Compute information matrix.
|
|
virtual Matrix | covariance () const |
| Compute covariance matrix.
|
|
| Base (size_t dim=1) |
| primary constructor More...
|
|
virtual bool | isConstrained () const |
| true if a constrained noise model, saves slow/clumsy dynamic casting More...
|
|
virtual bool | isUnit () const |
| true if a unit noise model, saves slow/clumsy dynamic casting More...
|
|
size_t | dim () const |
| Dimensionality.
|
|
virtual void | print (const std::string &name="") const =0 |
|
virtual bool | equals (const Base &expected, double tol=1e-9) const =0 |
|
virtual Vector | sigmas () const |
| Calculate standard deviations. More...
|
|
virtual Vector | whiten (const Vector &v) const =0 |
| Whiten an error vector. More...
|
|
virtual Matrix | Whiten (const Matrix &H) const =0 |
| Whiten a matrix. More...
|
|
virtual Vector | unwhiten (const Vector &v) const =0 |
| Unwhiten an error vector. More...
|
|
virtual double | squaredMahalanobisDistance (const Vector &v) const |
| Squared Mahalanobis distance v'*R'*R*v = <R*v,R*v> More...
|
|
virtual double | mahalanobisDistance (const Vector &v) const |
| Mahalanobis distance.
|
|
virtual double | loss (const double squared_distance) const |
| loss function, input is Mahalanobis distance More...
|
|
virtual void | WhitenSystem (std::vector< Matrix > &A, Vector &b) const =0 |
|
virtual void | WhitenSystem (Matrix &A, Vector &b) const =0 |
|
virtual void | WhitenSystem (Matrix &A1, Matrix &A2, Vector &b) const =0 |
|
virtual void | WhitenSystem (Matrix &A1, Matrix &A2, Matrix &A3, Vector &b) const =0 |
|
virtual void | whitenInPlace (Vector &v) const |
| in-place whiten, override if can be done more efficiently More...
|
|
virtual void | unwhitenInPlace (Vector &v) const |
| in-place unwhiten, override if can be done more efficiently More...
|
|
virtual void | whitenInPlace (Eigen::Block< Vector > &v) const |
| in-place whiten, override if can be done more efficiently More...
|
|
virtual void | unwhitenInPlace (Eigen::Block< Vector > &v) const |
| in-place unwhiten, override if can be done more efficiently More...
|
|
virtual Vector | unweightedWhiten (const Vector &v) const |
| Useful function for robust noise models to get the unweighted but whitened error. More...
|
|
virtual double | weight (const Vector &v) const |
| get the weight from the effective loss function on residual vector v More...
|
|
|
static shared_ptr | MixedSigmas (const Vector &mu, const Vector &sigmas) |
| A diagonal noise model created by specifying a Vector of standard devations, some of which might be zero.
|
|
static shared_ptr | MixedSigmas (const Vector &sigmas) |
| A diagonal noise model created by specifying a Vector of standard devations, some of which might be zero.
|
|
static shared_ptr | MixedSigmas (double m, const Vector &sigmas) |
| A diagonal noise model created by specifying a Vector of standard devations, some of which might be zero.
|
|
static shared_ptr | MixedVariances (const Vector &mu, const Vector &variances) |
| A diagonal noise model created by specifying a Vector of standard devations, some of which might be zero.
|
|
static shared_ptr | MixedVariances (const Vector &variances) |
|
static shared_ptr | MixedPrecisions (const Vector &mu, const Vector &precisions) |
| A diagonal noise model created by specifying a Vector of precisions, some of which might be inf.
|
|
static shared_ptr | MixedPrecisions (const Vector &precisions) |
|
static shared_ptr | All (size_t dim) |
| Fully constrained variations.
|
|
static shared_ptr | All (size_t dim, const Vector &mu) |
| Fully constrained variations.
|
|
static shared_ptr | All (size_t dim, double mu) |
| Fully constrained variations with a mu parameter.
|
|
static shared_ptr | Sigmas (const Vector &sigmas, bool smart=true) |
| A diagonal noise model created by specifying a Vector of sigmas, i.e. More...
|
|
static shared_ptr | Variances (const Vector &variances, bool smart=true) |
| A diagonal noise model created by specifying a Vector of variances, i.e. More...
|
|
static shared_ptr | Precisions (const Vector &precisions, bool smart=true) |
| A diagonal noise model created by specifying a Vector of precisions, i.e. More...
|
|
static shared_ptr | SqrtInformation (const Matrix &R, bool smart=true) |
| A Gaussian noise model created by specifying a square root information matrix. More...
|
|
static shared_ptr | Information (const Matrix &M, bool smart=true) |
| A Gaussian noise model created by specifying an information matrix. More...
|
|
static shared_ptr | Covariance (const Matrix &covariance, bool smart=true) |
| A Gaussian noise model created by specifying a covariance matrix. More...
|
|