Main MRPT website > C++ reference for MRPT 1.9.9
List of all members | Public Types | Public Member Functions | Static Public Member Functions | Public Attributes | Protected Member Functions | Protected Attributes | Friends
mrpt::hmtslam::CHMHMapNode Class Reference

Detailed Description

A class for representing a node in a hierarchical, multi-hypothesis map.

The node itself will be considered only if some given hypothesisID matchs its own ID.

Note
Create objects by invoking the class factory "::Create"
See also
CHierarchicalMHMap,CHMHMapArc

Definition at line 36 of file CHMHMapNode.h.

#include <mrpt/hmtslam/CHMHMapNode.h>

Inheritance diagram for mrpt::hmtslam::CHMHMapNode:
Inheritance graph

Public Types

using TNodeID = mrpt::graphs::TNodeID
 The type of the IDs of nodes. More...
 

Public Member Functions

voidoperator new (size_t size)
 
voidoperator new[] (size_t size)
 
void operator delete (void *ptr) noexcept
 
void operator delete[] (void *ptr) noexcept
 
void operator delete (void *memory, void *ptr) noexcept
 
voidoperator new (size_t size, const std::nothrow_t &) noexcept
 
void operator delete (void *ptr, const std::nothrow_t &) noexcept
 
 CHMHMapNode (CHierarchicalMHMap *parent=nullptr, const THypothesisIDSet &hyps=THypothesisIDSet())
 Constructor. More...
 
virtual ~CHMHMapNode ()
 Destructor. More...
 
TNodeID getID () const
 Reads the ID of the node (read-only property) More...
 
unsigned int getLevelInTheHierarchy ()
 Returns the level of this node in the hierarchy of arcs "arcType_Belongs", where level=0 is the ground level, 1=its parents, etc. More...
 
unsigned int getRelatedArcsCount ()
 Returns the number of arcs starting from/ending into this node. More...
 
void getArcs (TArcList &out) const
 Returns a list with the arcs from/to this node. More...
 
void getArcs (TArcList &out, const THypothesisID &hyp_id) const
 Returns a list with the arcs from/to this node existing in a given hypothesis ID. More...
 
void getArcs (TArcList &out, const char *arcType, const THypothesisID &hyp_id) const
 Returns a list with the arcs from/to this node existing in a given hypothesis ID and of a given type. More...
 
bool isNeighbor (const TNodeID &otherArea, const THypothesisID &hyp_id) const
 Check whether an arc exists towards the given area. More...
 
virtual mxArraywriteToMatlab () 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...
 

Static Public Member Functions

static voidoperator new (size_t size, void *ptr)
 

Public Attributes

THypothesisIDSet m_hypotheses
 The hypothesis IDs under which this node exists. More...
 
CMHPropertiesValuesList m_annotations
 The annotations of the node, see the general description of the class for possible properties and values. More...
 
std::string m_nodeType
 The type of the node, the possibilities are: More...
 
std::string m_label
 The label of the node, only for display it to the user. More...
 

Protected Member Functions

void onArcDestruction (CHMHMapArc *arc)
 Event handler for arc destruction: It should be only called for arcs from/to this node, altought other case must be handled without effects. More...
 
void onArcAddition (const std::shared_ptr< CHMHMapArc > &arc)
 Event handler for arc addition: It should be only called for arcs from/to this node, although other cases have no effects. 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

TNodeID m_ID
 An unique identifier for the node: it is randomly generated at construction or read from stream when loaded. More...
 
TArcList m_arcs
 The list of all arcs from/to this node: More...
 
mrpt::safe_ptr< CHierarchicalMHMapm_parent
 The hierarchical graph in which this object is into. More...
 

Friends

class CHierarchicalMHMap
 
class CHierarchicalMHMapPartition
 
class CHMHMapArc
 

RTTI stuff


using Ptr = std::shared_ptr< CHMHMapNode >
 
using ConstPtr = std::shared_ptr< const CHMHMapNode >
 
using UniquePtr = std::unique_ptr< CHMHMapNode >
 
using ConstUniquePtr = std::unique_ptr< const CHMHMapNode >
 
static mrpt::rtti::CLASSINIT _init_CHMHMapNode
 
static const mrpt::rtti::TRuntimeClassId runtimeClassId
 
static constexpr const char * className = "CHMHMapNode"
 
static const mrpt::rtti::TRuntimeClassId_GetBaseClass ()
 
static constexpr auto getClassName ()
 
static const mrpt::rtti::TRuntimeClassIdGetRuntimeClassIdStatic ()
 
static mrpt::rtti::CObjectCreateObject ()
 
template<typename... Args>
static Ptr Create (Args &&... args)
 
template<typename... Args>
static UniquePtr CreateUnique (Args &&... args)
 
virtual const mrpt::rtti::TRuntimeClassIdGetRuntimeClass () const override
 Returns information about the class of an object in runtime. More...
 
virtual mrpt::rtti::CObjectclone () const override
 Returns a deep copy (clone) of the object, indepently of its class. More...
 

Member Typedef Documentation

◆ ConstPtr

using mrpt::hmtslam::CHMHMapNode::ConstPtr = std::shared_ptr<const CHMHMapNode >

Definition at line 42 of file CHMHMapNode.h.

◆ ConstUniquePtr

Definition at line 42 of file CHMHMapNode.h.

◆ Ptr

using mrpt::hmtslam::CHMHMapNode::Ptr = std::shared_ptr< CHMHMapNode >

A type for the associated smart pointer

Definition at line 42 of file CHMHMapNode.h.

◆ TNodeID

The type of the IDs of nodes.

Definition at line 47 of file CHMHMapNode.h.

◆ UniquePtr

Definition at line 42 of file CHMHMapNode.h.

Constructor & Destructor Documentation

◆ CHMHMapNode()

CHMHMapNode::CHMHMapNode ( CHierarchicalMHMap parent = nullptr,
const THypothesisIDSet hyps = THypothesisIDSet() 
)

Constructor.

Definition at line 23 of file CHMHMapNode.cpp.

◆ ~CHMHMapNode()

CHMHMapNode::~CHMHMapNode ( )
virtual

Destructor.

Definition at line 55 of file CHMHMapNode.cpp.

Member Function Documentation

◆ _GetBaseClass()

static const mrpt::rtti::TRuntimeClassId* mrpt::hmtslam::CHMHMapNode::_GetBaseClass ( )
staticprotected

◆ clone()

virtual mrpt::rtti::CObject* mrpt::hmtslam::CHMHMapNode::clone ( ) const
overridevirtual

Returns a deep copy (clone) of the object, indepently of its class.

Implements mrpt::rtti::CObject.

◆ Create()

template<typename... Args>
static Ptr mrpt::hmtslam::CHMHMapNode::Create ( Args &&...  args)
inlinestatic

Definition at line 42 of file CHMHMapNode.h.

◆ CreateObject()

static mrpt::rtti::CObject* mrpt::hmtslam::CHMHMapNode::CreateObject ( )
static

◆ CreateUnique()

template<typename... Args>
static UniquePtr mrpt::hmtslam::CHMHMapNode::CreateUnique ( Args &&...  args)
inlinestatic

Definition at line 42 of file CHMHMapNode.h.

◆ duplicateGetSmartPtr()

mrpt::rtti::CObject::Ptr CObject::duplicateGetSmartPtr ( ) const
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().

◆ getArcs() [1/3]

void mrpt::hmtslam::CHMHMapNode::getArcs ( TArcList out) const
inline

Returns a list with the arcs from/to this node.

Definition at line 123 of file CHMHMapNode.h.

References m_arcs.

◆ getArcs() [2/3]

void CHMHMapNode::getArcs ( TArcList out,
const char *  arcType,
const THypothesisID hyp_id 
) const

Returns a list with the arcs from/to this node existing in a given hypothesis ID and of a given type.

Definition at line 179 of file CHMHMapNode.cpp.

◆ getArcs() [3/3]

void CHMHMapNode::getArcs ( TArcList out,
const THypothesisID hyp_id 
) const

Returns a list with the arcs from/to this node existing in a given hypothesis ID.

Definition at line 169 of file CHMHMapNode.cpp.

◆ getClassName()

static constexpr auto mrpt::hmtslam::CHMHMapNode::getClassName ( )
inlinestaticconstexpr

Definition at line 42 of file CHMHMapNode.h.

◆ getID()

CHMHMapNode::TNodeID CHMHMapNode::getID ( ) const

Reads the ID of the node (read-only property)

Definition at line 133 of file CHMHMapNode.cpp.

Referenced by mrpt::hmtslam::CHierarchicalMHMap::onNodeDestruction(), and mrpt::hmtslam::CHMHMapArc::onNodeDestruction().

◆ getLevelInTheHierarchy()

unsigned int CHMHMapNode::getLevelInTheHierarchy ( )

Returns the level of this node in the hierarchy of arcs "arcType_Belongs", where level=0 is the ground level, 1=its parents, etc.

Definition at line 137 of file CHMHMapNode.cpp.

◆ getRelatedArcsCount()

unsigned int CHMHMapNode::getRelatedArcsCount ( )

Returns the number of arcs starting from/ending into this node.

Definition at line 161 of file CHMHMapNode.cpp.

◆ GetRuntimeClass()

virtual const mrpt::rtti::TRuntimeClassId* mrpt::hmtslam::CHMHMapNode::GetRuntimeClass ( ) const
overridevirtual

Returns information about the class of an object in runtime.

Reimplemented from mrpt::serialization::CSerializable.

◆ GetRuntimeClassIdStatic()

static const mrpt::rtti::TRuntimeClassId& mrpt::hmtslam::CHMHMapNode::GetRuntimeClassIdStatic ( )
static

◆ isNeighbor()

bool CHMHMapNode::isNeighbor ( const TNodeID otherArea,
const THypothesisID hyp_id 
) const

Check whether an arc exists towards the given area.

Definition at line 191 of file CHMHMapNode.cpp.

◆ onArcAddition()

void CHMHMapNode::onArcAddition ( const std::shared_ptr< CHMHMapArc > &  arc)
protected

Event handler for arc addition: It should be only called for arcs from/to this node, although other cases have no effects.

Definition at line 116 of file CHMHMapNode.cpp.

References MRPT_END, and MRPT_START.

◆ onArcDestruction()

void CHMHMapNode::onArcDestruction ( CHMHMapArc arc)
protected

Event handler for arc destruction: It should be only called for arcs from/to this node, altought other case must be handled without effects.

Note
At *addition we use a smart pointer to assure all the implied guys use the same smrt. pnt., but at destructors the objects don't know anything but "this", thus the usage of plain pointers.

Definition at line 95 of file CHMHMapNode.cpp.

References mrpt::hmtslam::CHMHMapArc::m_nodeFrom, mrpt::hmtslam::CHMHMapArc::m_nodeTo, MRPT_END, and MRPT_START.

◆ operator delete() [1/3]

void mrpt::hmtslam::CHMHMapNode::operator delete ( void memory,
void ptr 
)
inlinenoexcept

Definition at line 42 of file CHMHMapNode.h.

◆ operator delete() [2/3]

void mrpt::hmtslam::CHMHMapNode::operator delete ( void ptr)
inlinenoexcept

Definition at line 42 of file CHMHMapNode.h.

◆ operator delete() [3/3]

void mrpt::hmtslam::CHMHMapNode::operator delete ( void ptr,
const std::nothrow_t &   
)
inlinenoexcept

Definition at line 42 of file CHMHMapNode.h.

◆ operator delete[]()

void mrpt::hmtslam::CHMHMapNode::operator delete[] ( void ptr)
inlinenoexcept

Definition at line 42 of file CHMHMapNode.h.

◆ operator new() [1/3]

void* mrpt::hmtslam::CHMHMapNode::operator new ( size_t  size)
inline

Definition at line 42 of file CHMHMapNode.h.

◆ operator new() [2/3]

void* mrpt::hmtslam::CHMHMapNode::operator new ( size_t  size,
const std::nothrow_t &   
)
inlinenoexcept

Definition at line 42 of file CHMHMapNode.h.

◆ operator new() [3/3]

static void* mrpt::hmtslam::CHMHMapNode::operator new ( size_t  size,
void ptr 
)
inlinestatic

Definition at line 42 of file CHMHMapNode.h.

◆ operator new[]()

void* mrpt::hmtslam::CHMHMapNode::operator new[] ( size_t  size)
inline

Definition at line 42 of file CHMHMapNode.h.

◆ serializeFrom()

void CHMHMapNode::serializeFrom ( mrpt::serialization::CArchive in,
uint8_t  serial_version 
)
overrideprotectedvirtual

Pure virtual method for reading (deserializing) from an abstract archive.

Users don't call this method directly. Instead, use stream >> object;.

Parameters
inThe input binary stream where the object data must read from.
versionThe version of the object stored in the stream: use this version number in your code to know how to read the incoming data.
Exceptions
std::exceptionOn any I/O error

Implements mrpt::serialization::CSerializable.

Definition at line 74 of file CHMHMapNode.cpp.

References MRPT_THROW_UNKNOWN_SERIALIZATION_VERSION.

◆ serializeGetVersion()

uint8_t CHMHMapNode::serializeGetVersion ( ) const
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 65 of file CHMHMapNode.cpp.

◆ serializeTo()

void CHMHMapNode::serializeTo ( mrpt::serialization::CArchive out) const
overrideprotectedvirtual

Pure virtual method for writing (serializing) to an abstract archive.

Users don't call this method directly. Instead, use stream << object;.

Exceptions
std::exceptionOn any I/O error

Implements mrpt::serialization::CSerializable.

Definition at line 66 of file CHMHMapNode.cpp.

◆ writeToMatlab()

virtual mxArray* mrpt::serialization::CSerializable::writeToMatlab ( ) const
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.

Returns
A new 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.

Friends And Related Function Documentation

◆ CHierarchicalMHMap

friend class CHierarchicalMHMap
friend

Definition at line 38 of file CHMHMapNode.h.

◆ CHierarchicalMHMapPartition

friend class CHierarchicalMHMapPartition
friend

Definition at line 39 of file CHMHMapNode.h.

◆ CHMHMapArc

friend class CHMHMapArc
friend

Definition at line 40 of file CHMHMapNode.h.

Member Data Documentation

◆ _init_CHMHMapNode

mrpt::rtti::CLASSINIT mrpt::hmtslam::CHMHMapNode::_init_CHMHMapNode
staticprotected

Definition at line 42 of file CHMHMapNode.h.

◆ className

constexpr const char* mrpt::hmtslam::CHMHMapNode::className = "CHMHMapNode"
staticconstexpr

Definition at line 42 of file CHMHMapNode.h.

◆ m_annotations

CMHPropertiesValuesList mrpt::hmtslam::CHMHMapNode::m_annotations

The annotations of the node, see the general description of the class for possible properties and values.

Definition at line 94 of file CHMHMapNode.h.

◆ m_arcs

TArcList mrpt::hmtslam::CHMHMapNode::m_arcs
protected

The list of all arcs from/to this node:

Definition at line 61 of file CHMHMapNode.h.

Referenced by getArcs().

◆ m_hypotheses

THypothesisIDSet mrpt::hmtslam::CHMHMapNode::m_hypotheses

The hypothesis IDs under which this node exists.

Definition at line 51 of file CHMHMapNode.h.

◆ m_ID

TNodeID mrpt::hmtslam::CHMHMapNode::m_ID
protected

An unique identifier for the node: it is randomly generated at construction or read from stream when loaded.

Definition at line 57 of file CHMHMapNode.h.

◆ m_label

std::string mrpt::hmtslam::CHMHMapNode::m_label

The label of the node, only for display it to the user.

Definition at line 110 of file CHMHMapNode.h.

◆ m_nodeType

std::string mrpt::hmtslam::CHMHMapNode::m_nodeType

The type of the node, the possibilities are:

  • Place
  • Area
  • TopologicalMap
  • Object

Definition at line 102 of file CHMHMapNode.h.

◆ m_parent

mrpt::safe_ptr<CHierarchicalMHMap> mrpt::hmtslam::CHMHMapNode::m_parent
protected

The hierarchical graph in which this object is into.

Definition at line 78 of file CHMHMapNode.h.

◆ runtimeClassId

const mrpt::rtti::TRuntimeClassId mrpt::hmtslam::CHMHMapNode::runtimeClassId
staticprotected

Definition at line 42 of file CHMHMapNode.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