9 #ifndef CSENSORYFRAME_H 10 #define CSENSORYFRAME_H 74 void internal_buildAuxPointsMap(
const void *options = NULL )
const;
85 template <
class POINTSMAP>
87 return static_cast<POINTSMAP*
>(m_cachedMap.pointer());
98 template <
class POINTSMAP>
100 internal_buildAuxPointsMap(options);
101 return static_cast<POINTSMAP*
>(m_cachedMap.pointer());
143 return insertObservationsInto(theMap.pointer(), robotPose);
164 void push_back(
const CObservationPtr &obs);
168 void insert(
const CObservationPtr &obs);
177 template <
typename T>
181 size_t foundCount = 0;
184 if ( (*it)->GetRuntimeClass()->derivedFrom( class_ID ) )
185 if (foundCount++ == ith)
186 return typename T::Ptr(*it);
187 return typename T::Ptr();
253 inline size_t size()
const {
return m_observations.size(); }
256 inline bool empty()
const {
return m_observations.empty(); }
259 void eraseByIndex(
const size_t &idx);
272 CObservationPtr getObservationByIndex(
const size_t &idx )
const;
280 template <
typename T>
283 return static_cast<T
>(getObservationByIndex(idx));
290 CObservationPtr getObservationBySensorLabel(
const std::string &label,
const size_t &idx = 0)
const;
298 template <
typename T>
301 return T(getObservationBySensorLabel(label,idx));
std::deque< CObservationPtr > m_observations
The set of observations taken at the same time instant.
The virtual base class which provides a unified interface for all persistent objects in MRPT...
EIGEN_STRONG_INLINE iterator begin()
EIGEN_STRONG_INLINE void push_back(Scalar val)
Insert an element at the end of the container (for 1D vectors/arrays)
const Scalar * const_iterator
void clear()
Clear the contents of this container.
std::deque< CObservationPtr >::const_iterator const_iterator
You can use CSensoryFrame::begin to get a iterator to the first element.
const_iterator begin() const
Returns a constant iterator to the first observation: this is an example of usage: ...
#define DEFINE_SERIALIZABLE_PRE_CUSTOM_BASE_LINKAGE(class_name, base_name, _LINKAGE_)
This declaration must be inserted in all CSerializable classes definition, before the class declarati...
std::deque< CObservationPtr >::iterator iterator
You can use CSensoryFrame::begin to get a iterator to the first element.
std::vector< T1 > & operator+=(std::vector< T1 > &a, const std::vector< T2 > &b)
a+=b (element-wise sum)
T getObservationBySensorLabelAs(const std::string &label, const size_t &idx=0) const
Returns the i'th observation in the list with the given "sensorLabel" (0=first), and as a different s...
Declares a class for storing a "sensory frame", a set of "observations" taken by the robot approximat...
T getObservationByIndexAs(const size_t &idx) const
Returns the i'th observation in the list (0=first), and as a different smart pointer type: ...
GLsizei const GLchar ** string
const POINTSMAP * buildAuxPointsMap(const void *options=NULL) const
Returns a cached points map representing this laser scan, building it upon the first call...
This is the global namespace for all Mobile Robot Programming Toolkit (MRPT) libraries.
#define DEFINE_SERIALIZABLE(class_name)
This declaration must be inserted in all CSerializable classes definition, within the class declarati...
Declares a virtual base class for all metric maps storage classes.
A class used to store a 3D pose (a 3D translation + a rotation in 3D).
const POINTSMAP * getAuxPointsMap() const
Returns the cached points map representation of the scan, if already build with buildAuxPointsMap(), or NULL otherwise.
iterator begin()
Returns a iterator to the first observation: this is an example of usage:
mrpt::maps::CMetricMapPtr m_cachedMap
A points map, build only under demand by the methods getAuxPointsMap() and buildAuxPointsMap().
A structure that holds runtime class type information.
const_iterator end() const
Returns a constant iterator to the end of the list of observations: this is an example of usage: ...
T::Ptr getObservationByClass(const size_t &ith=0) const
Returns the i'th observation of a given class (or of a descendant class), or NULL if there is no such...
iterator end()
Returns a iterator to the end of the list of observations: this is an example of usage: ...
#define DEFINE_SERIALIZABLE_POST_CUSTOM_BASE_LINKAGE(class_name, base_name, _LINKAGE_)
size_t size() const
Returns the number of observations in the list.
bool insertObservationsInto(mrpt::maps::CMetricMapPtr &theMap, const mrpt::poses::CPose3D *robotPose=NULL) const
Insert all the observations in this SF into a metric map or any kind (see mrpt::maps::CMetricMap).
bool empty() const
Returns true if there are no observations in the list.