Declares a class that represents a Probability Density function (PDF) of a 3D(6D) pose .
This class implements that PDF as the following multi-modal Gaussian distribution:
Where the number of modes N is the size of CPose3DPDFSOG::m_modes. Angles are always in radians.
See mrpt::poses::CPose3DPDF for more details.
Definition at line 34 of file CPose3DPDFSOG.h.
#include <mrpt/poses/CPose3DPDFSOG.h>
Classes | |
struct | TGaussianMode |
The struct for each mode: More... | |
Public Types | |
using | TModesList = std::vector< TGaussianMode, mrpt::aligned_allocator_cpp11< TGaussianMode > > |
using | const_iterator = TModesList::const_iterator |
using | iterator = TModesList::iterator |
enum | { is_3D_val = 1 } |
enum | { is_PDF_val = 1 } |
using | type_value = CPose3D |
The type of the state the PDF represents. More... | |
using | self_t = CProbabilityDensityFunction< CPose3D, STATE_LEN > |
Public Member Functions | |
void * | operator new (size_t size) |
void * | operator new[] (size_t size) |
void | operator delete (void *ptr) noexcept |
void | operator delete[] (void *ptr) noexcept |
void | operator delete (void *memory, void *ptr) noexcept |
void * | operator new (size_t size, const std::nothrow_t &) noexcept |
void | operator delete (void *ptr, const std::nothrow_t &) noexcept |
CPose3DPDFSOG (size_t nModes=1) | |
Default constructor. More... | |
void | clear () |
Clear all the gaussian modes. More... | |
void | resize (const size_t N) |
Set the number of SOG modes. More... | |
size_t | size () const |
Return the number of Gaussian modes. More... | |
bool | empty () const |
Return whether there is any Gaussian mode. More... | |
iterator | begin () |
iterator | end () |
const_iterator | begin () const |
const_iterator | end () const |
void | getMean (CPose3D &mean_pose) const override |
Returns an estimate of the pose, (the mean, or mathematical expectation of the PDF), computed as a weighted average over all m_particles. More... | |
void | getCovarianceAndMean (mrpt::math::CMatrixDouble66 &cov, CPose3D &mean_point) const override |
Returns an estimate of the pose covariance matrix (6x6 cov matrix) and the mean, both at once. More... | |
void | normalizeWeights () |
Normalize the weights in m_modes such as the maximum log-weight is 0. More... | |
void | getMostLikelyMode (CPose3DPDFGaussian &outVal) const |
Return the Gaussian mode with the highest likelihood (or an empty Gaussian if there are no modes in this SOG) More... | |
void | copyFrom (const CPose3DPDF &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 | bayesianFusion (const CPose3DPDF &p1, const CPose3DPDF &p2) override |
Bayesian fusion of two pose distributions, then save the result in this object (WARNING: Currently p1 must be a mrpt::poses::CPose3DPDFSOG object and p2 a mrpt::poses::CPose3DPDFSOG object) More... | |
void | drawSingleSample (CPose3D &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 1x6 vectors, where each row contains a (x,y,z,yaw,pitch,roll) datum. More... | |
void | inverse (CPose3DPDF &o) const override |
Returns a new PDF such as: NEW_PDF = (0,0,0) - THIS_PDF. More... | |
void | appendFrom (const CPose3DPDFSOG &o) |
Append the Gaussian modes from "o" to the current set of modes of "this" density. 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 (CPose3D &mean_point) const=0 |
Returns the mean, or mathematical expectation of the probability density distribution (PDF). More... | |
virtual void | getCovarianceAndMean (mrpt::math::CMatrixFixedNumeric< double, STATE_LEN, STATE_LEN > &cov, CPose3D &mean_point) const=0 |
Returns an estimate of the pose covariance matrix (STATE_LENxSTATE_LEN cov matrix) and the mean, both at once. More... | |
void | getCovarianceDynAndMean (mrpt::math::CMatrixDouble &cov, CPose3D &mean_point) const |
Returns an estimate of the pose covariance matrix (STATE_LENxSTATE_LEN cov matrix) and the mean, both at once. More... | |
CPose3D | 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 (mrpt::math::CMatrixFixedNumeric< double, STATE_LEN, STATE_LEN > &cov) const |
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix) More... | |
mrpt::math::CMatrixFixedNumeric< double, STATE_LEN, STATE_LEN > | 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 (mrpt::math::CMatrixFixedNumeric< double, STATE_LEN, STATE_LEN > &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 (CPose3D &outPart) const=0 |
Draws a single sample from the distribution. More... | |
double | getCovarianceEntropy () const |
Compute the entropy of the estimated covariance matrix. More... | |
Static Public Member Functions | |
static void * | operator new (size_t size, void *ptr) |
static CPose3DPDF * | createFrom2D (const CPosePDF &o) |
This is a static transformation method from 2D poses to 3D PDFs, preserving the representation type (particles->particles, Gaussians->Gaussians,etc) More... | |
static void | jacobiansPoseComposition (const CPose3D &x, const CPose3D &u, mrpt::math::CMatrixDouble66 &df_dx, mrpt::math::CMatrixDouble66 &df_du) |
This static method computes the pose composition Jacobians. More... | |
static bool | is_3D () |
static bool | is_PDF () |
Static Public Attributes | |
static const 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 | assureSymmetry () |
Assures 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... | |
Protected Attributes | |
TModesList | m_modes |
Access directly to this array for modify the modes as desired. More... | |
RTTI stuff | |
using | Ptr = std::shared_ptr< CPose3DPDFSOG > |
using | ConstPtr = std::shared_ptr< const CPose3DPDFSOG > |
using | UniquePtr = std::unique_ptr< CPose3DPDFSOG > |
using | ConstUniquePtr = std::unique_ptr< const CPose3DPDFSOG > |
static mrpt::rtti::CLASSINIT | _init_CPose3DPDFSOG |
static const mrpt::rtti::TRuntimeClassId | runtimeClassId |
static constexpr const char * | className = "CPose3DPDFSOG" |
static const mrpt::rtti::TRuntimeClassId * | _GetBaseClass () |
static constexpr auto | getClassName () |
static const mrpt::rtti::TRuntimeClassId & | GetRuntimeClassIdStatic () |
static mrpt::rtti::CObject * | CreateObject () |
template<typename... Args> | |
static Ptr | Create (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::CPose3DPDFSOG::const_iterator = TModesList::const_iterator |
Definition at line 54 of file CPose3DPDFSOG.h.
using mrpt::poses::CPose3DPDFSOG::ConstPtr = std::shared_ptr<const CPose3DPDFSOG > |
Definition at line 36 of file CPose3DPDFSOG.h.
using mrpt::poses::CPose3DPDFSOG::ConstUniquePtr = std::unique_ptr<const CPose3DPDFSOG > |
Definition at line 36 of file CPose3DPDFSOG.h.
using mrpt::poses::CPose3DPDFSOG::iterator = TModesList::iterator |
Definition at line 55 of file CPose3DPDFSOG.h.
using mrpt::poses::CPose3DPDFSOG::Ptr = std::shared_ptr< CPose3DPDFSOG > |
A type for the associated smart pointer
Definition at line 36 of file CPose3DPDFSOG.h.
|
inherited |
Definition at line 36 of file CProbabilityDensityFunction.h.
using mrpt::poses::CPose3DPDFSOG::TModesList = std::vector<TGaussianMode, mrpt::aligned_allocator_cpp11<TGaussianMode> > |
Definition at line 53 of file CPose3DPDFSOG.h.
|
inherited |
The type of the state the PDF represents.
Definition at line 35 of file CProbabilityDensityFunction.h.
using mrpt::poses::CPose3DPDFSOG::UniquePtr = std::unique_ptr< CPose3DPDFSOG > |
Definition at line 36 of file CPose3DPDFSOG.h.
|
inherited |
Enumerator | |
---|---|
is_3D_val |
Definition at line 104 of file CPose3DPDF.h.
|
inherited |
Enumerator | |
---|---|
is_PDF_val |
Definition at line 109 of file CPose3DPDF.h.
CPose3DPDFSOG::CPose3DPDFSOG | ( | size_t | nModes = 1 | ) |
Default constructor.
nModes | The initial size of CPose3DPDFSOG::m_modes |
Definition at line 29 of file CPose3DPDFSOG.cpp.
|
staticprotected |
void CPose3DPDFSOG::appendFrom | ( | const CPose3DPDFSOG & | o | ) |
Append the Gaussian modes from "o" to the current set of modes of "this" density.
Definition at line 364 of file CPose3DPDFSOG.cpp.
References ASSERT_, m_modes, MRPT_END, and MRPT_START.
|
protected |
Assures the symmetry of the covariance matrix (eventually certain operations in the math-coprocessor lead to non-symmetric matrixes!)
Definition at line 282 of file CPose3DPDFSOG.cpp.
References MRPT_END, MRPT_START, and val.
|
overridevirtual |
Bayesian fusion of two pose distributions, then save the result in this object (WARNING: Currently p1 must be a mrpt::poses::CPose3DPDFSOG object and p2 a mrpt::poses::CPose3DPDFSOG object)
Implements mrpt::poses::CPose3DPDF.
Definition at line 201 of file CPose3DPDFSOG.cpp.
References ASSERT_, CLASS_ID, mrpt::poses::CPose3DPDF::GetRuntimeClass(), MRPT_END, MRPT_START, and THROW_EXCEPTION.
|
inline |
Definition at line 83 of file CPose3DPDFSOG.h.
References m_modes.
Referenced by mrpt::poses::CPose3DPDF::createFrom2D().
|
inline |
Definition at line 85 of file CPose3DPDFSOG.h.
References m_modes.
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::CPose3DPDF.
Definition at line 192 of file CPose3DPDFSOG.cpp.
References val.
void CPose3DPDFSOG::clear | ( | ) |
Clear all the gaussian modes.
Definition at line 33 of file CPose3DPDFSOG.cpp.
Referenced by mrpt::hmtslam::CHMTSLAM::TBI_main_method().
|
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::CPose3DPDF.
Definition at line 149 of file CPose3DPDFSOG.cpp.
References CLASS_ID, mrpt::math::CProbabilityDensityFunction< TDATA, STATE_LEN >::getCovarianceAndMean(), mrpt::poses::CPose3DPDF::GetRuntimeClass(), MRPT_END, MRPT_START, and val.
|
inlinestatic |
Definition at line 36 of file CPose3DPDFSOG.h.
|
staticinherited |
This is a static transformation method from 2D poses to 3D PDFs, preserving the representation type (particles->particles, Gaussians->Gaussians,etc)
Definition at line 34 of file CPose3DPDF.cpp.
References begin(), CLASS_ID, mrpt::poses::CPose3DPDFGaussian::cov, mrpt::poses::CPose3DPDFGaussianInf::cov_inv, mrpt::bayes::CParticleFilterData< T, STORAGE >::m_particles, mrpt::poses::CPose3DPDFGaussianInf::mean, mrpt::poses::CPose3DPDFGaussian::mean, MRPT_END, MRPT_START, and THROW_EXCEPTION.
Referenced by mrpt::graphslam::deciders::CLoopCloserERD< GRAPH_T >::updateMapPartitions().
|
static |
|
inlinestatic |
Definition at line 36 of file CPose3DPDFSOG.h.
|
overridevirtual |
Draws a number of samples from the distribution, and saves as a list of 1x6 vectors, where each row contains a (x,y,z,yaw,pitch,roll) datum.
Reimplemented from mrpt::math::CProbabilityDensityFunction< CPose3D, 6 >.
Definition at line 328 of file CPose3DPDFSOG.cpp.
References MRPT_UNUSED_PARAM, and THROW_EXCEPTION.
Draws a single sample from the distribution.
Definition at line 319 of file CPose3DPDFSOG.cpp.
References MRPT_UNUSED_PARAM, and THROW_EXCEPTION.
|
pure virtualinherited |
Draws a single sample from the distribution.
|
inlineinherited |
Returns a copy of the object, indepently of its class, as a smart pointer (the newly created object will exist as long as any copy of this smart pointer).
Definition at line 169 of file CObject.h.
References mrpt::rtti::CObject::clone().
Referenced by mrpt::obs::CRawlog::addActions(), and mrpt::obs::CRawlog::addObservations().
|
inline |
Return whether there is any Gaussian mode.
Definition at line 82 of file CPose3DPDFSOG.h.
References m_modes.
|
inline |
Definition at line 84 of file CPose3DPDFSOG.h.
References m_modes.
|
inline |
Definition at line 86 of file CPose3DPDFSOG.h.
References m_modes.
|
inlineinherited |
Returns a 3D representation of this PDF.
Definition at line 136 of file CPose3DPDF.h.
References mrpt::opengl::posePDF2opengl().
|
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 125 of file CPose3DPDF.h.
References mrpt::opengl::posePDF2opengl().
|
inlinestaticconstexpr |
Definition at line 36 of file CPose3DPDFSOG.h.
|
inlineinherited |
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix)
Definition at line 103 of file CProbabilityDensityFunction.h.
|
inlineinherited |
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix)
Definition at line 80 of file CProbabilityDensityFunction.h.
|
inlineinherited |
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix)
Definition at line 90 of file CProbabilityDensityFunction.h.
|
override |
Returns an estimate of the pose covariance matrix (6x6 cov matrix) and the mean, both at once.
Definition at line 65 of file CPose3DPDFSOG.cpp.
|
pure virtualinherited |
Returns an estimate of the pose covariance matrix (STATE_LENxSTATE_LEN cov matrix) and the mean, both at once.
|
inlineinherited |
Returns an estimate of the pose covariance matrix (STATE_LENxSTATE_LEN cov matrix) and the mean, both at once.
Definition at line 56 of file CProbabilityDensityFunction.h.
|
inlineinherited |
Compute the entropy of the estimated covariance matrix.
Definition at line 170 of file CProbabilityDensityFunction.h.
|
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 126 of file CProbabilityDensityFunction.h.
|
pure virtualinherited |
Returns the mean, or mathematical expectation of the probability density distribution (PDF).
Returns an estimate of the pose, (the mean, or mathematical expectation of the PDF), computed as a weighted average over all m_particles.
Definition at line 43 of file CPose3DPDFSOG.cpp.
References mrpt::poses::SE_average< 3 >::append(), mrpt::poses::SE_average< 3 >::get_average(), and val.
|
inlineinherited |
Returns the mean, or mathematical expectation of the probability density distribution (PDF).
Definition at line 69 of file CProbabilityDensityFunction.h.
void CPose3DPDFSOG::getMostLikelyMode | ( | CPose3DPDFGaussian & | outVal | ) | const |
Return the Gaussian mode with the highest likelihood (or an empty Gaussian if there are no modes in this SOG)
Definition at line 382 of file CPose3DPDFSOG.cpp.
References empty().
|
overridevirtual |
Returns information about the class of an object in runtime.
Reimplemented from mrpt::poses::CPose3DPDF.
|
static |
|
overridevirtual |
Returns a new PDF such as: NEW_PDF = (0,0,0) - THIS_PDF.
Implements mrpt::poses::CPose3DPDF.
Definition at line 339 of file CPose3DPDFSOG.cpp.
References ASSERT_, CLASS_ID, mrpt::poses::CPose3DPDF::GetRuntimeClass(), m_modes, MRPT_END, MRPT_START, resize(), and val.
|
inlinestaticinherited |
Definition at line 108 of file CPose3DPDF.h.
References mrpt::poses::CPose3DPDF::is_3D_val.
|
inlinestaticinherited |
Definition at line 113 of file CPose3DPDF.h.
References mrpt::poses::CPose3DPDF::is_PDF_val.
|
inlinevirtualinherited |
Returns whether the class instance holds the uncertainty in covariance or information form.
Definition at line 119 of file CProbabilityDensityFunction.h.
|
staticinherited |
This static method computes the pose composition Jacobians.
See this techical report: http:///www.mrpt.org/6D_poses:equivalences_compositions_and_uncertainty
Direct equations (for the covariances) in yaw-pitch-roll are too complex. Make a way around them and consider instead this path:
Definition at line 141 of file CPose3DPDF.cpp.
References mrpt::math::CQuaternion< T >::crossProduct(), mrpt::poses::CPose3D::getAsQuaternion(), mrpt::poses::CPose3DQuatPDF::jacobiansPoseComposition(), mrpt::math::CQuaternion< T >::normalizationJacobian(), mrpt::obs::gnss::pitch, mrpt::poses::CPose3DQuat::quat(), mrpt::obs::gnss::roll, mrpt::math::CQuaternion< T >::rpy_and_jacobian(), mrpt::math::UNINITIALIZED_MATRIX, and mrpt::math::UNINITIALIZED_QUATERNION.
Referenced by mrpt::poses::CPose3DPDFGaussian::changeCoordinatesReference(), mrpt::poses::CPose3DPDFGaussianInf::operator+=(), mrpt::poses::CPose3DPDFGaussian::operator+=(), and Pose3DPDFGaussTests::testCompositionJacobian().
void CPose3DPDFSOG::normalizeWeights | ( | ) |
Normalize the weights in m_modes such as the maximum log-weight is 0.
Definition at line 300 of file CPose3DPDFSOG.cpp.
References MRPT_END, and MRPT_START.
Definition at line 36 of file CPose3DPDFSOG.h.
Definition at line 36 of file CPose3DPDFSOG.h.
|
inlinenoexcept |
Definition at line 36 of file CPose3DPDFSOG.h.
Definition at line 36 of file CPose3DPDFSOG.h.
|
inline |
Definition at line 36 of file CPose3DPDFSOG.h.
|
inlinenoexcept |
Definition at line 36 of file CPose3DPDFSOG.h.
Definition at line 36 of file CPose3DPDFSOG.h.
|
inline |
Definition at line 36 of file CPose3DPDFSOG.h.
void CPose3DPDFSOG::resize | ( | const size_t | N | ) |
Set the number of SOG modes.
Definition at line 37 of file CPose3DPDFSOG.cpp.
Referenced by inverse().
|
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< CPose3D, 6 >.
Definition at line 174 of file CPose3DPDFSOG.cpp.
References mrpt::system::os::fclose(), mrpt::system::os::fopen(), mrpt::system::os::fprintf(), and val.
|
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 111 of file CPose3DPDFSOG.cpp.
References MRPT_THROW_UNKNOWN_SERIALIZATION_VERSION, THROW_EXCEPTION, and val.
|
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 99 of file CPose3DPDFSOG.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 100 of file CPose3DPDFSOG.cpp.
References val.
|
inline |
Return the number of Gaussian modes.
Definition at line 80 of file CPose3DPDFSOG.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 70 of file CSerializable.h.
|
staticprotected |
Definition at line 36 of file CPose3DPDFSOG.h.
|
staticconstexpr |
Definition at line 36 of file CPose3DPDFSOG.h.
|
protected |
Access directly to this array for modify the modes as desired.
Note that no weight can be zero!! We must use pointers to satisfy the mem-alignment of the matrixes
Definition at line 67 of file CPose3DPDFSOG.h.
Referenced by appendFrom(), begin(), empty(), end(), inverse(), and size().
|
staticprotected |
Definition at line 36 of file CPose3DPDFSOG.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 33 of file CProbabilityDensityFunction.h.
Page generated by Doxygen 1.8.17 for MRPT 1.9.9 Git: ad3a9d8ae Tue May 1 23:10:22 2018 -0700 at miƩ 12 jul 2023 10:03:34 CEST |