51 cout <<
"Initial PDF: mean: " << pdf.
getMeanVal() << endl;
54 #if MRPT_HAS_WXWIDGETS 64 scene.
insert(CGridPlaneXY::Create(-5, 5, -5, 5, 0, 1));
69 #if MRPT_HAS_WXWIDGETS 72 win_before.unlockAccess3DScene();
73 win_before.setCameraZoom(5);
74 win_before.setCameraPointingToPoint(1, 0, 0);
75 win_before.forceRepaint();
81 cout <<
" # modes after: " << pdf.
size() << endl;
83 cout <<
"Final PDF: mean: " << pdf.
getMeanVal() << endl;
91 scene.
insert(CGridPlaneXY::Create(-5, 5, -5, 5, 0, 1));
96 #if MRPT_HAS_WXWIDGETS 99 win_after.unlockAccess3DScene();
100 win_after.setCameraZoom(5);
101 win_after.setCameraPointingToPoint(1, 0, 0);
102 win_after.forceRepaint();
106 #if MRPT_HAS_WXWIDGETS 107 cout <<
"Push any key to exit..." << endl;
123 catch (
const std::exception& e)
130 printf(
"Untyped exception!");
void clear()
Clear the list of modes.
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 distribut...
The struct for each mode:
int getch() noexcept
An OS-independent version of getch, which waits until a key is pushed.
Declares a class that represents a Probability Density function (PDF) of a 2D pose ...
void getCovariance(mrpt::math::CMatrixDouble &cov) const
Returns the estimate of the covariance matrix (STATE_LEN x STATE_LEN covariance matrix) ...
void push_back(const TGaussianMode &m)
Inserts a copy of the given mode into the SOG.
CArchiveStreamBase< STREAM > archiveFrom(STREAM &s)
Helper function to create a templatized wrapper CArchive object for a: MRPT's CStream, std::istream, std::ostream, std::stringstream.
mrpt::math::CMatrixDouble33 cov
type_value getMeanVal() const
Returns the mean, or mathematical expectation of the probability density distribution (PDF)...
Classes for 2D/3D geometry representation, both of single values and probability density distribution...
return_t square(const num_t x)
Inline function for the square of a number.
This is the global namespace for all Mobile Robot Programming Toolkit (MRPT) libraries.
A class used to store a 2D pose, including the 2D coordinate point and a heading (phi) angle...
The namespace for 3D scene representation and rendering.
This class allows the user to create, load, save, and render 3D scenes using OpenGL primitives...
std::string exception_to_str(const std::exception &e)
Builds a nice textual representation of a nested exception, which if generated using MRPT macros (THR...
void getAs3DObject(OPENGL_SETOFOBJECTSPTR &out_obj) const
Returns a 3D representation of this PDF (it doesn't clear the current contents of out_obj...
Classes for creating GUI windows for 2D and 3D visualization.
size_t size() const
Return the number of Gaussian modes.
Saves data to a file and transparently compress the data using the given compression level...
void insert(const CRenderizable::Ptr &newObject, const std::string &viewportName=std::string("main"))
Insert a new object into the scene, in the given viewport (by default, into the "main" viewport)...
double log_w
The log-weight.
A graphical user interface (GUI) for efficiently rendering 3D scenes in real-time.