Main MRPT website > C++ reference
MRPT logo
CPointPDF.h
Go to the documentation of this file.
1 /* +---------------------------------------------------------------------------+
2  | The Mobile Robot Programming Toolkit (MRPT) C++ library |
3  | |
4  | http://www.mrpt.org/ |
5  | |
6  | Copyright (C) 2005-2012 University of Malaga |
7  | |
8  | This software was written by the Machine Perception and Intelligent |
9  | Robotics Lab, University of Malaga (Spain). |
10  | Contact: Jose-Luis Blanco <jlblanco@ctima.uma.es> |
11  | |
12  | This file is part of the MRPT project. |
13  | |
14  | MRPT is free software: you can redistribute it and/or modify |
15  | it under the terms of the GNU General Public License as published by |
16  | the Free Software Foundation, either version 3 of the License, or |
17  | (at your option) any later version. |
18  | |
19  | MRPT is distributed in the hope that it will be useful, |
20  | but WITHOUT ANY WARRANTY; without even the implied warranty of |
21  | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
22  | GNU General Public License for more details. |
23  | |
24  | You should have received a copy of the GNU General Public License |
25  | along with MRPT. If not, see <http://www.gnu.org/licenses/>. |
26  | |
27  +---------------------------------------------------------------------------+ */
28 #ifndef CPointPDF_H
29 #define CPointPDF_H
30 
33 #include <mrpt/poses/CPoint3D.h>
34 #include <mrpt/poses/CPosePDF.h>
35 
36 namespace mrpt
37 {
38 namespace poses
39 {
40  using namespace mrpt::math;
41 
42 
43 
45 
46  /** Declares a class that represents a Probability Distribution
47  * function (PDF) of a 3D point (x,y,z).
48  * This class is just the base class for unifying many diferent
49  * ways this PDF can be implemented.
50  *
51  * For convenience, a pose composition is also defined for any
52  * PDF derived class, changeCoordinatesReference, in the form of a method rather than an operator.
53  *
54  * For a similar class for 6D poses (a 3D point with attitude), see CPose3DPDF
55  *
56  * See also the tutorial on <a href="http://www.mrpt.org/Probability_Density_Distributions_Over_Spatial_Representations">probabilistic spatial representations in the MRPT</a>.
57  *
58  * \sa CPoint3D
59  * \ingroup poses_pdf_grp
60  */
61  class BASE_IMPEXP CPointPDF : public mrpt::utils::CSerializable, public mrpt::utils::CProbabilityDensityFunction<CPoint3D,3>
62  {
64 
65  public:
66  /** Copy operator, translating if necesary (for example, between particles and gaussian representations)
67  */
68  virtual void copyFrom(const CPointPDF &o) = 0;
69 
70 
71  /** Bayesian fusion of two point distributions (product of two distributions->new distribution), then save the result in this object (WARNING: See implementing classes to see classes that can and cannot be mixtured!)
72  * \param p1 The first distribution to fuse
73  * \param p2 The second distribution to fuse
74  * \param minMahalanobisDistToDrop If set to different of 0, the result of very separate Gaussian modes (that will result in negligible components) in SOGs will be dropped to reduce the number of modes in the output.
75  */
76  virtual void bayesianFusion( const CPointPDF &p1, const CPointPDF &p2, const double &minMahalanobisDistToDrop = 0) = 0 ;
77 
78  enum { is_3D_val = 1 };
79  static inline bool is_3D() { return is_3D_val!=0; }
80  enum { is_PDF_val = 1 };
81  static inline bool is_PDF() { return is_PDF_val!=0; }
82 
83  /** 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)
84  * \note Needs the mrpt-opengl library, and using mrpt::opengl::CSetOfObjectsPtr as template argument.
85  */
86  template <class OPENGL_SETOFOBJECTSPTR>
87  inline void getAs3DObject(OPENGL_SETOFOBJECTSPTR &out_obj) const {
88  typedef typename OPENGL_SETOFOBJECTSPTR::value_type SETOFOBJECTS;
89  out_obj->insertCollection( *SETOFOBJECTS::posePDF2opengl(*this) );
90  }
91 
92  /** Returns a 3D representation of this PDF.
93  * \note Needs the mrpt-opengl library, and using mrpt::opengl::CSetOfObjectsPtr as template argument.
94  */
95  template <class OPENGL_SETOFOBJECTSPTR,class OPENGL_SETOFOBJECTS>
96  inline OPENGL_SETOFOBJECTSPTR getAs3DObject() const {
97  typedef typename OPENGL_SETOFOBJECTSPTR::value_type SETOFOBJECTS;
98  return SETOFOBJECTS::posePDF2opengl(*this);
99  }
100 
101  }; // End of class def.
102 
103 
104  } // End of namespace
105 } // End of namespace
106 
107 #endif



Page generated by Doxygen 1.8.3 for MRPT 0.9.6 SVN: at Fri Feb 15 22:05:02 EST 2013