MRPT
2.0.1
|
Declares a class that represents a Probability Density function (PDF) of a 2D pose .
This class implements that PDF as the following multi-modal Gaussian distribution:
Where the number of modes N is the size of CPosePDFSOG::m_modes
See mrpt::poses::CPosePDF for more details.
Definition at line 34 of file CPosePDFSOG.h.
#include <mrpt/poses/CPosePDFSOG.h>
Classes | |
struct | TGaussianMode |
The struct for each mode: More... | |
Public Types | |
using | CListGaussianModes = std::vector< TGaussianMode > |
using | const_iterator = CListGaussianModes::const_iterator |
using | iterator = CListGaussianModes::iterator |
enum | { is_3D_val = 0 } |
enum | { is_PDF_val = 1 } |
using | type_value = CPose2D |
The type of the state the PDF represents. More... | |
using | self_t = CProbabilityDensityFunction< CPose2D, STATE_LEN > |
using | cov_mat_t = mrpt::math::CMatrixFixed< double, STATE_LEN, STATE_LEN > |
Covariance matrix type. More... | |
using | inf_mat_t = cov_mat_t |
Information matrix type. More... | |
Public Member Functions | |
const CListGaussianModes & | getSOGModes () const |
CPosePDFSOG (size_t nModes=1) | |
Default constructor. More... | |
size_t | size () const |
Return the number of Gaussian modes. More... | |
bool | empty () const |
Return whether there is any Gaussian mode. More... | |
void | clear () |
Clear the list of modes. More... | |
const TGaussianMode & | operator[] (size_t i) const |
Access to individual beacons. More... | |
TGaussianMode & | operator[] (size_t i) |
Access to individual beacons. More... | |
const TGaussianMode & | get (size_t i) const |
Access to individual beacons. More... | |
TGaussianMode & | get (size_t i) |
Access to individual beacons. More... | |
void | push_back (const TGaussianMode &m) |
Inserts a copy of the given mode into the SOG. More... | |
iterator | begin () |
iterator | end () |
const_iterator | begin () const |
const_iterator | end () const |
iterator | erase (iterator i) |
void | resize (const size_t N) |
Resize the number of SOG modes. More... | |
void | mergeModes (double max_KLd=0.5, bool verbose=false) |
Merge very close modes so the overall number of modes is reduced while preserving the total distribution. More... | |
void | getMean (CPose2D &mean_pose) const override |
std::tuple< cov_mat_t, type_value > | getCovarianceAndMean () const override |
Returns an estimate of the pose covariance matrix (STATE_LENxSTATE_LEN cov matrix) and the mean, both at once. More... | |
void | getMostLikelyCovarianceAndMean (mrpt::math::CMatrixDouble33 &cov, CPose2D &mean_point) const |
For the most likely Gaussian mode in the SOG, returns the pose covariance matrix (3x3 cov matrix) and the mean. More... | |
void | normalizeWeights () |
Normalize the weights in m_modes such as the maximum log-weight is 0. More... | |
void | copyFrom (const CPosePDF &o) override |
Copy operator, translating if necesary (for example, between particles and gaussian representations) More... | |
bool | saveToTextFile (const std::string &file) const override |
Save the density to a text file, with the following format: There is one row per Gaussian "mode", and each row contains 10 elements: More... | |
void | changeCoordinatesReference (const CPose3D &newReferenceBase) override |
this = p (+) this. More... | |
void | rotateAllCovariances (double ang) |
Rotate all the covariance matrixes by replacing them by , where . More... | |
void | drawSingleSample (CPose2D &outPart) const override |
Draws a single sample from the distribution. More... | |
void | drawManySamples (size_t N, std::vector< mrpt::math::CVectorDouble > &outSamples) const override |
Draws a number of samples from the distribution, and saves as a list of 1x3 vectors, where each row contains a (x,y,phi) datum. More... | |
void | inverse (CPosePDF &o) const override |
Returns a new PDF such as: NEW_PDF = (0,0,0) - THIS_PDF. More... | |
void | operator+= (const mrpt::poses::CPose2D &Ap) |
Makes: thisPDF = thisPDF + Ap, where "+" is pose composition (both the mean, and the covariance matrix are updated). More... | |
double | evaluatePDF (const mrpt::poses::CPose2D &x, bool sumOverAllPhis=false) const |
Evaluates the PDF at a given point. More... | |
double | evaluateNormalizedPDF (const mrpt::poses::CPose2D &x) const |
Evaluates the ratio PDF(x) / max_PDF(x*), that is, the normalized PDF in the range [0,1]. More... | |
void | evaluatePDFInArea (double x_min, double x_max, double y_min, double y_max, double resolutionXY, double phi, mrpt::math::CMatrixDouble &outMatrix, bool sumOverAllPhis=false) |
Evaluates the PDF within a rectangular grid (and a fixed orientation) and saves the result in a matrix (each row contains values for a fixed y-coordinate value). More... | |
void | bayesianFusion (const CPosePDF &p1, const CPosePDF &p2, const double minMahalanobisDistToDrop=0) override |
Bayesian fusion of two pose distributions, then save the result in this object (WARNING: Currently p1 must be a mrpt::poses::CPosePDFSOG object and p2 a mrpt::poses::CPosePDFGaussian object) More... | |
template<class OPENGL_SETOFOBJECTSPTR > | |
void | getAs3DObject (OPENGL_SETOFOBJECTSPTR &out_obj) const |
Returns a 3D representation of this PDF (it doesn't clear the current contents of out_obj, but append new OpenGL objects to that list) More... | |
template<class OPENGL_SETOFOBJECTSPTR > | |
OPENGL_SETOFOBJECTSPTR | getAs3DObject () const |
Returns a 3D representation of this PDF. More... | |
virtual mxArray * | writeToMatlab () const |
Introduces a pure virtual method responsible for writing to a mxArray Matlab object, typically a MATLAB struct whose contents are documented in each derived class. More... | |
virtual void | getMean (type_value &mean_point) const=0 |
Returns the mean, or mathematical expectation of the probability density distribution (PDF). More... | |
virtual void | getCovarianceAndMean (cov_mat_t &c, CPose2D &mean) const final |
void | getCovarianceDynAndMean (mrpt::math::CMatrixDouble &cov, type_value &mean_point) const |
Returns an estimate of the pose covariance matrix (STATE_LENxSTATE_LEN cov matrix) and the mean, both at once. More... | |
type_value | getMeanVal () const |
Returns the mean, or mathematical expectation of the probability density distribution (PDF). More... | |
void | getCovariance (mrpt::math::CMatrixDouble &cov) const |
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix) More... | |
void | getCovariance (cov_mat_t &cov) const |
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix) More... | |
cov_mat_t | getCovariance () const |
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix) More... | |
virtual bool | isInfType () const |
Returns whether the class instance holds the uncertainty in covariance or information form. More... | |
virtual void | getInformationMatrix (inf_mat_t &inf) const |
Returns the information (inverse covariance) matrix (a STATE_LEN x STATE_LEN matrix) Unless reimplemented in derived classes, this method first reads the covariance, then invert it. More... | |
virtual void | drawSingleSample (CPose2D &outPart) const=0 |
Draws a single sample from the distribution. More... | |
double | getCovarianceEntropy () const |
Compute the entropy of the estimated covariance matrix. More... | |
RTTI classes and functions for polymorphic hierarchies | |
mrpt::rtti::CObject::Ptr | duplicateGetSmartPtr () const |
Makes a deep copy of the object and returns a smart pointer to it. More... | |
Static Public Member Functions | |
static void | jacobiansPoseComposition (const CPose2D &x, const CPose2D &u, mrpt::math::CMatrixDouble33 &df_dx, mrpt::math::CMatrixDouble33 &df_du, const bool compute_df_dx=true, const bool compute_df_du=true) |
This static method computes the pose composition Jacobians, with these formulas: More... | |
static void | jacobiansPoseComposition (const CPosePDFGaussian &x, const CPosePDFGaussian &u, mrpt::math::CMatrixDouble33 &df_dx, mrpt::math::CMatrixDouble33 &df_du) |
static constexpr bool | is_3D () |
static constexpr bool | is_PDF () |
Static Public Attributes | |
static constexpr size_t | state_length |
The length of the variable, for example, 3 for a 3D point, 6 for a 3D pose (x y z yaw pitch roll). More... | |
Protected Member Functions | |
void | enforceCovSymmetry () |
Ensures the symmetry of the covariance matrix (eventually certain operations in the math-coprocessor lead to non-symmetric matrixes!) More... | |
CSerializable virtual methods | |
uint8_t | serializeGetVersion () const override |
Must return the current versioning number of the object. More... | |
void | serializeTo (mrpt::serialization::CArchive &out) const override |
Pure virtual method for writing (serializing) to an abstract archive. More... | |
void | serializeFrom (mrpt::serialization::CArchive &in, uint8_t serial_version) override |
Pure virtual method for reading (deserializing) from an abstract archive. More... | |
CSerializable virtual methods | |
virtual void | serializeTo (CSchemeArchiveBase &out) const |
Virtual method for writing (serializing) to an abstract schema based archive. More... | |
virtual void | serializeFrom (CSchemeArchiveBase &in) |
Virtual method for reading (deserializing) from an abstract schema based archive. More... | |
Protected Attributes | |
CListGaussianModes | m_modes |
The list of SOG modes. More... | |
RTTI stuff | |
using | Ptr = std::shared_ptr< mrpt::poses ::CPosePDFSOG > |
using | ConstPtr = std::shared_ptr< const mrpt::poses ::CPosePDFSOG > |
using | UniquePtr = std::unique_ptr< mrpt::poses ::CPosePDFSOG > |
using | ConstUniquePtr = std::unique_ptr< const mrpt::poses ::CPosePDFSOG > |
static const mrpt::rtti::TRuntimeClassId | runtimeClassId |
static constexpr const char * | className = "mrpt::poses" "::" "CPosePDFSOG" |
static const mrpt::rtti::TRuntimeClassId * | _GetBaseClass () |
static constexpr auto | getClassName () |
static const mrpt::rtti::TRuntimeClassId & | GetRuntimeClassIdStatic () |
static std::shared_ptr< CObject > | CreateObject () |
template<typename... Args> | |
static Ptr | Create (Args &&... args) |
template<typename Alloc , typename... Args> | |
static Ptr | CreateAlloc (const Alloc &alloc, Args &&... args) |
template<typename... Args> | |
static UniquePtr | CreateUnique (Args &&... args) |
virtual const mrpt::rtti::TRuntimeClassId * | GetRuntimeClass () const override |
Returns information about the class of an object in runtime. More... | |
virtual mrpt::rtti::CObject * | clone () const override |
Returns a deep copy (clone) of the object, indepently of its class. More... | |
using mrpt::poses::CPosePDFSOG::CListGaussianModes = std::vector<TGaussianMode> |
Definition at line 65 of file CPosePDFSOG.h.
using mrpt::poses::CPosePDFSOG::const_iterator = CListGaussianModes::const_iterator |
Definition at line 66 of file CPosePDFSOG.h.
using mrpt::poses::CPosePDFSOG::ConstPtr = std::shared_ptr<const mrpt::poses :: CPosePDFSOG > |
Definition at line 36 of file CPosePDFSOG.h.
using mrpt::poses::CPosePDFSOG::ConstUniquePtr = std::unique_ptr<const mrpt::poses :: CPosePDFSOG > |
Definition at line 36 of file CPosePDFSOG.h.
|
inherited |
Covariance matrix type.
Definition at line 37 of file CProbabilityDensityFunction.h.
|
inherited |
Information matrix type.
Definition at line 39 of file CProbabilityDensityFunction.h.
using mrpt::poses::CPosePDFSOG::iterator = CListGaussianModes::iterator |
Definition at line 67 of file CPosePDFSOG.h.
using mrpt::poses::CPosePDFSOG::Ptr = std::shared_ptr< mrpt::poses :: CPosePDFSOG > |
A type for the associated smart pointer
Definition at line 36 of file CPosePDFSOG.h.
|
inherited |
Definition at line 35 of file CProbabilityDensityFunction.h.
|
inherited |
The type of the state the PDF represents.
Definition at line 34 of file CProbabilityDensityFunction.h.
using mrpt::poses::CPosePDFSOG::UniquePtr = std::unique_ptr< mrpt::poses :: CPosePDFSOG > |
Definition at line 36 of file CPosePDFSOG.h.
|
inherited |
Enumerator | |
---|---|
is_3D_val |
Definition at line 94 of file CPosePDF.h.
|
inherited |
Enumerator | |
---|---|
is_PDF_val |
Definition at line 99 of file CPosePDF.h.
CPosePDFSOG::CPosePDFSOG | ( | size_t | nModes = 1 | ) |
Default constructor.
nModes | The initial size of CPosePDFSOG::m_modes |
Definition at line 36 of file CPosePDFSOG.cpp.
|
staticprotected |
|
overridevirtual |
Bayesian fusion of two pose distributions, then save the result in this object (WARNING: Currently p1 must be a mrpt::poses::CPosePDFSOG object and p2 a mrpt::poses::CPosePDFGaussian object)
Implements mrpt::poses::CPosePDF.
Definition at line 272 of file CPosePDFSOG.cpp.
References mrpt::math::CMatrixFixed< T, ROWS, COLS >::asEigen(), ASSERT_, mrpt::poses::CPosePDFGaussian::bayesianFusion(), CLASS_ID, mrpt::poses::CPosePDFSOG::TGaussianMode::cov, mrpt::poses::CPosePDFGaussian::cov, mrpt::math::MatrixBase< Scalar, Derived >::det(), mrpt::poses::CPosePDF::GetRuntimeClass(), mrpt::math::MatrixBase< Scalar, Derived >::inverse_LLt(), mrpt::poses::CPosePDFSOG::TGaussianMode::log_w, M_2PI, mrpt::poses::CPosePDFSOG::TGaussianMode::mean, mrpt::poses::CPosePDFGaussian::mean, MRPT_END, and MRPT_START.
|
inline |
Definition at line 119 of file CPosePDFSOG.h.
References m_modes.
|
inline |
Definition at line 121 of file CPosePDFSOG.h.
References m_modes.
|
overridevirtual |
this = p (+) this.
This can be used to convert a PDF from local coordinates to global, providing the point (newReferenceBase) from which "to project" the current pdf. Result PDF substituted the currently stored one in the object.
Implements mrpt::poses::CPosePDF.
Definition at line 199 of file CPosePDFSOG.cpp.
References mrpt::math::MatrixVectorBase< Scalar, Derived >::block(), mrpt::poses::CPose2D::getHomogeneousMatrix(), and mrpt::math::multiply_HCHt().
void CPosePDFSOG::clear | ( | ) |
Clear the list of modes.
Definition at line 40 of file CPosePDFSOG.cpp.
|
overridevirtual |
Returns a deep copy (clone) of the object, indepently of its class.
Implements mrpt::rtti::CObject.
|
overridevirtual |
Copy operator, translating if necesary (for example, between particles and gaussian representations)
Implements mrpt::poses::CPosePDF.
Definition at line 157 of file CPosePDFSOG.cpp.
References CLASS_ID, mrpt::math::cov(), mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getCovariance(), mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getMean(), mrpt::poses::CPosePDF::GetRuntimeClass(), mrpt::math::mean(), MRPT_END, MRPT_START, and resize().
|
inlinestatic |
Definition at line 36 of file CPosePDFSOG.h.
|
inlinestatic |
Definition at line 36 of file CPosePDFSOG.h.
|
static |
|
inlinestatic |
Definition at line 36 of file CPosePDFSOG.h.
|
overridevirtual |
Draws a number of samples from the distribution, and saves as a list of 1x3 vectors, where each row contains a (x,y,phi) datum.
Reimplemented from mrpt::math::CProbabilityDensityFunction< CPose2D, 3 >.
Definition at line 258 of file CPosePDFSOG.cpp.
References MRPT_END, MRPT_START, and THROW_EXCEPTION.
|
pure virtualinherited |
Draws a single sample from the distribution.
|
override |
Draws a single sample from the distribution.
Definition at line 248 of file CPosePDFSOG.cpp.
References MRPT_END, MRPT_START, and THROW_EXCEPTION.
|
inlineinherited |
Makes a deep copy of the object and returns a smart pointer to it.
Definition at line 204 of file CObject.h.
References mrpt::rtti::CObject::clone().
Referenced by mrpt::obs::CRawlog::insert().
|
inline |
Return whether there is any Gaussian mode.
Definition at line 87 of file CPosePDFSOG.h.
References m_modes.
|
inline |
Definition at line 120 of file CPosePDFSOG.h.
References m_modes.
|
inline |
Definition at line 122 of file CPosePDFSOG.h.
References m_modes.
|
protected |
Ensures the symmetry of the covariance matrix (eventually certain operations in the math-coprocessor lead to non-symmetric matrixes!)
Definition at line 453 of file CPosePDFSOG.cpp.
Definition at line 123 of file CPosePDFSOG.h.
References m_modes.
double CPosePDFSOG::evaluateNormalizedPDF | ( | const mrpt::poses::CPose2D & | x | ) | const |
Evaluates the ratio PDF(x) / max_PDF(x*), that is, the normalized PDF in the range [0,1].
Definition at line 434 of file CPosePDFSOG.cpp.
References mrpt::math::normalPDF().
double CPosePDFSOG::evaluatePDF | ( | const mrpt::poses::CPose2D & | x, |
bool | sumOverAllPhis = false |
||
) | const |
Evaluates the PDF at a given point.
Definition at line 389 of file CPosePDFSOG.cpp.
References mrpt::math::normalPDF(), mrpt::poses::CPoseOrPoint< DERIVEDCLASS, DIM >::x(), and mrpt::poses::CPoseOrPoint< DERIVEDCLASS, DIM >::y().
void CPosePDFSOG::evaluatePDFInArea | ( | double | x_min, |
double | x_max, | ||
double | y_min, | ||
double | y_max, | ||
double | resolutionXY, | ||
double | phi, | ||
mrpt::math::CMatrixDouble & | outMatrix, | ||
bool | sumOverAllPhis = false |
||
) |
Evaluates the PDF within a rectangular grid (and a fixed orientation) and saves the result in a matrix (each row contains values for a fixed y-coordinate value).
Definition at line 485 of file CPosePDFSOG.cpp.
References ASSERT_, MRPT_END, MRPT_START, and mrpt::math::CMatrixDynamic< T >::setSize().
|
inline |
Access to individual beacons.
Definition at line 105 of file CPosePDFSOG.h.
|
inline |
Access to individual beacons.
Definition at line 111 of file CPosePDFSOG.h.
|
inlineinherited |
Returns a 3D representation of this PDF (it doesn't clear the current contents of out_obj, but append new OpenGL objects to that list)
Definition at line 113 of file CPosePDF.h.
References mrpt::opengl::posePDF2opengl().
|
inlineinherited |
Returns a 3D representation of this PDF.
Definition at line 124 of file CPosePDF.h.
References mrpt::opengl::posePDF2opengl().
|
inlinestatic |
Definition at line 36 of file CPosePDFSOG.h.
|
inlineinherited |
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix)
Definition at line 88 of file CProbabilityDensityFunction.h.
References mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getCovarianceDynAndMean().
|
inlineinherited |
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix)
Definition at line 98 of file CProbabilityDensityFunction.h.
References mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getCovarianceAndMean().
|
inlineinherited |
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix)
Definition at line 108 of file CProbabilityDensityFunction.h.
References mrpt::math::cov(), mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getCovarianceAndMean(), and mrpt::math::UNINITIALIZED_MATRIX.
|
inlinefinalvirtualinherited |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
Definition at line 54 of file CProbabilityDensityFunction.h.
References mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getCovarianceAndMean(), and mrpt::math::mean().
|
overridevirtual |
Returns an estimate of the pose covariance matrix (STATE_LENxSTATE_LEN cov matrix) and the mean, both at once.
Implements mrpt::math::CProbabilityDensityFunction< CPose2D, 3 >.
Definition at line 68 of file CPosePDFSOG.cpp.
References mrpt::math::cov(), mrpt::math::MatrixBase< Scalar, Derived >::matProductOf_AAt(), and mrpt::math::MatrixVectorBase< Scalar, Derived >::setZero().
|
inlineinherited |
Returns an estimate of the pose covariance matrix (STATE_LENxSTATE_LEN cov matrix) and the mean, both at once.
Definition at line 65 of file CProbabilityDensityFunction.h.
References mrpt::math::cov(), mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getCovarianceAndMean(), and mrpt::math::UNINITIALIZED_MATRIX.
|
inlineinherited |
Compute the entropy of the estimated covariance matrix.
Definition at line 167 of file CProbabilityDensityFunction.h.
References mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getCovariance().
|
inlinevirtualinherited |
Returns the information (inverse covariance) matrix (a STATE_LEN x STATE_LEN matrix) Unless reimplemented in derived classes, this method first reads the covariance, then invert it.
Definition at line 130 of file CProbabilityDensityFunction.h.
References mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getCovariance(), and mrpt::math::MatrixBase< Scalar, Derived >::inverse_LLt().
|
pure virtualinherited |
Returns the mean, or mathematical expectation of the probability density distribution (PDF).
|
override |
Definition at line 50 of file CPosePDFSOG.cpp.
References mrpt::poses::SE_average< 2 >::append(), and mrpt::poses::SE_average< 2 >::get_average().
|
inlineinherited |
Returns the mean, or mathematical expectation of the probability density distribution (PDF).
Definition at line 77 of file CProbabilityDensityFunction.h.
References mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getMean().
void CPosePDFSOG::getMostLikelyCovarianceAndMean | ( | mrpt::math::CMatrixDouble33 & | cov, |
CPose2D & | mean_point | ||
) | const |
For the most likely Gaussian mode in the SOG, returns the pose covariance matrix (3x3 cov matrix) and the mean.
Definition at line 645 of file CPosePDFSOG.cpp.
References mrpt::math::CMatrixDynamic< T >::asEigen(), mrpt::containers::begin(), mrpt::math::cov(), mrpt::containers::end(), and mrpt::math::MatrixBase< Scalar, Derived >::setIdentity().
|
overridevirtual |
Returns information about the class of an object in runtime.
Reimplemented from mrpt::poses::CPosePDF.
|
static |
|
inline |
Definition at line 69 of file CPosePDFSOG.h.
References m_modes.
|
overridevirtual |
Returns a new PDF such as: NEW_PDF = (0,0,0) - THIS_PDF.
Implements mrpt::poses::CPosePDF.
Definition at line 355 of file CPosePDFSOG.cpp.
References ASSERT_, CLASS_ID, mrpt::math::cov(), mrpt::poses::CPosePDF::GetRuntimeClass(), mrpt::math::mean(), and out.
|
inlinestaticinherited |
Definition at line 98 of file CPosePDF.h.
References mrpt::poses::CPosePDF::is_3D_val.
|
inlinestaticinherited |
Definition at line 103 of file CPosePDF.h.
References mrpt::poses::CPosePDF::is_PDF_val.
|
inlinevirtualinherited |
Returns whether the class instance holds the uncertainty in covariance or information form.
Reimplemented in mrpt::poses::CPosePDFGaussianInf.
Definition at line 123 of file CProbabilityDensityFunction.h.
|
staticinherited |
This static method computes the pose composition Jacobians, with these formulas:
Definition at line 32 of file CPosePDF.cpp.
References mrpt::poses::CPose2D::phi(), mrpt::math::MatrixBase< Scalar, Derived >::setIdentity(), mrpt::poses::CPoseOrPoint< DERIVEDCLASS, DIM >::x(), and mrpt::poses::CPoseOrPoint< DERIVEDCLASS, DIM >::y().
Referenced by mrpt::poses::CPosePDFGaussian::composePoint(), mrpt::poses::CPosePDF::jacobiansPoseComposition(), mrpt::poses::CPosePDFGaussian::operator+=(), and mrpt::poses::CPosePDFGaussianInf::operator+=().
|
staticinherited |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
Definition at line 22 of file CPosePDF.cpp.
References mrpt::poses::CPosePDF::jacobiansPoseComposition().
void CPosePDFSOG::mergeModes | ( | double | max_KLd = 0.5 , |
bool | verbose = false |
||
) |
Merge very close modes so the overall number of modes is reduced while preserving the total distribution.
This method uses the approach described in the paper:
max_KLd | The maximum KL-divergence to consider the merge of two nodes (and then stops the process). |
Definition at line 516 of file CPosePDFSOG.cpp.
References mrpt::math::CMatrixFixed< T, ROWS, COLS >::asEigen(), mrpt::math::CMatrixDynamic< T >::asEigen(), ASSERT_, mrpt::poses::CPosePDFSOG::TGaussianMode::cov, mrpt::math::cov(), mrpt::math::MatrixBase< Scalar, Derived >::det(), mrpt::poses::CPosePDFSOG::TGaussianMode::log_w, mrpt::math::MatrixBase< Scalar, Derived >::matProductOf_AAt(), mrpt::poses::CPosePDFSOG::TGaussianMode::mean, mrpt::math::mean(), MRPT_END, MRPT_START, mrpt::poses::CPose2D::phi(), verbose, mrpt::math::wrapToPiInPlace(), mrpt::poses::CPoseOrPoint< DERIVEDCLASS, DIM >::x(), and mrpt::poses::CPoseOrPoint< DERIVEDCLASS, DIM >::y().
void CPosePDFSOG::normalizeWeights | ( | ) |
Normalize the weights in m_modes such as the maximum log-weight is 0.
Definition at line 468 of file CPosePDFSOG.cpp.
References MRPT_END, and MRPT_START.
void CPosePDFSOG::operator+= | ( | const mrpt::poses::CPose2D & | Ap | ) |
Makes: thisPDF = thisPDF + Ap, where "+" is pose composition (both the mean, and the covariance matrix are updated).
Definition at line 379 of file CPosePDFSOG.cpp.
References mrpt::poses::CPose2D::phi().
|
inline |
Access to individual beacons.
Definition at line 92 of file CPosePDFSOG.h.
|
inline |
Access to individual beacons.
Definition at line 98 of file CPosePDFSOG.h.
|
inline |
Inserts a copy of the given mode into the SOG.
Definition at line 118 of file CPosePDFSOG.h.
References m_modes.
void CPosePDFSOG::resize | ( | const size_t | N | ) |
Resize the number of SOG modes.
Definition at line 44 of file CPosePDFSOG.cpp.
Referenced by copyFrom().
void CPosePDFSOG::rotateAllCovariances | ( | double | ang | ) |
Rotate all the covariance matrixes by replacing them by , where .
Definition at line 233 of file CPosePDFSOG.cpp.
References mrpt::math::multiply_HCHt().
|
overridevirtual |
Save the density to a text file, with the following format: There is one row per Gaussian "mode", and each row contains 10 elements:
Implements mrpt::math::CProbabilityDensityFunction< CPose2D, 3 >.
Definition at line 182 of file CPosePDFSOG.cpp.
References mrpt::system::os::fclose(), mrpt::system::os::fopen(), and mrpt::system::os::fprintf().
|
overrideprotectedvirtual |
Pure virtual method for reading (deserializing) from an abstract archive.
Users don't call this method directly. Instead, use stream >> object;
.
in | The input binary stream where the object data must read from. |
version | The version of the object stored in the stream: use this version number in your code to know how to read the incoming data. |
std::exception | On any I/O error |
Implements mrpt::serialization::CSerializable.
Definition at line 118 of file CPosePDFSOG.cpp.
References mrpt::math::CMatrixFixed< T, ROWS, COLS >::cast_double(), mrpt::math::deserializeSymmetricMatrixFrom(), MRPT_THROW_UNKNOWN_SERIALIZATION_VERSION, and resize().
|
inlineprotectedvirtualinherited |
Virtual method for reading (deserializing) from an abstract schema based archive.
Definition at line 74 of file CSerializable.h.
References mrpt::serialization::CSerializable::GetRuntimeClass(), and THROW_EXCEPTION.
|
overrideprotectedvirtual |
Must return the current versioning number of the object.
Start in zero for new classes, and increments each time there is a change in the stored format.
Implements mrpt::serialization::CSerializable.
Definition at line 106 of file CPosePDFSOG.cpp.
|
overrideprotectedvirtual |
Pure virtual method for writing (serializing) to an abstract archive.
Users don't call this method directly. Instead, use stream << object;
.
std::exception | On any I/O error |
Implements mrpt::serialization::CSerializable.
Definition at line 107 of file CPosePDFSOG.cpp.
References out, and mrpt::math::serializeSymmetricMatrixTo().
|
inlineprotectedvirtualinherited |
Virtual method for writing (serializing) to an abstract schema based archive.
Definition at line 64 of file CSerializable.h.
References mrpt::serialization::CSerializable::GetRuntimeClass(), and THROW_EXCEPTION.
|
inline |
Return the number of Gaussian modes.
Definition at line 85 of file CPosePDFSOG.h.
References m_modes.
|
inlinevirtualinherited |
Introduces a pure virtual method responsible for writing to a mxArray
Matlab object, typically a MATLAB struct
whose contents are documented in each derived class.
mxArray
(caller is responsible of memory freeing) or nullptr is class does not support conversion to MATLAB. Definition at line 90 of file CSerializable.h.
|
static |
Definition at line 36 of file CPosePDFSOG.h.
|
protected |
The list of SOG modes.
Definition at line 77 of file CPosePDFSOG.h.
Referenced by begin(), empty(), end(), erase(), get(), getSOGModes(), operator[](), push_back(), and size().
|
staticprotected |
Definition at line 36 of file CPosePDFSOG.h.
|
staticinherited |
The length of the variable, for example, 3 for a 3D point, 6 for a 3D pose (x y z yaw pitch roll).
Definition at line 32 of file CProbabilityDensityFunction.h.
Page generated by Doxygen 1.8.14 for MRPT 2.0.1 Git: 0fef1a6d7 Fri Apr 3 23:00:21 2020 +0200 at vie abr 3 23:20:28 CEST 2020 |