9 #ifndef CSENSORYFRAME_H 10 #define CSENSORYFRAME_H 76 void internal_buildAuxPointsMap(
const void *options = NULL )
const;
87 template <
class POINTSMAP>
89 return static_cast<POINTSMAP*
>(m_cachedMap.
pointer());
100 template <
class POINTSMAP>
102 internal_buildAuxPointsMap(options);
103 return static_cast<POINTSMAP*
>(m_cachedMap.
pointer());
145 return insertObservationsInto(theMap.
pointer(), robotPose);
179 template <
typename T>
183 size_t foundCount = 0;
186 if ( (*it)->GetRuntimeClass()->derivedFrom( class_ID ) )
187 if (foundCount++ == ith)
188 return typename T::SmartPtr(*it);
189 return typename T::SmartPtr();
255 inline size_t size()
const {
return m_observations.size(); }
258 inline bool empty()
const {
return m_observations.empty(); }
261 void eraseByIndex(
const size_t &idx);
269 void eraseByLabel(
const std::string &label);
282 template <
typename T>
285 return static_cast<T
>(getObservationByIndex(idx));
292 CObservationPtr getObservationBySensorLabel(
const std::string &label,
const size_t &idx = 0)
const;
300 template <
typename T>
303 return T(getObservationBySensorLabel(label,idx));
const POINTSMAP * buildAuxPointsMap(const void *options=NULL) const
Returns a cached points map representing this laser scan, building it upon the first call...
T getObservationByIndexAs(const size_t &idx) const
Returns the i'th observation in the list (0=first), and as a different smart pointer type: ...
EIGEN_STRONG_INLINE iterator end()
size_t size() const
Returns the number of observations in the list.
const_iterator end() const
Returns a iterator to the end of the list of observations: this is an example of usage: ...
The virtual base class which provides a unified interface for all persistent objects in MRPT...
const POINTSMAP * getAuxPointsMap() const
Returns the cached points map representation of the scan, if already build with buildAuxPointsMap(), or NULL otherwise.
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_iterator begin() const
Returns a iterator to the first observation: this is an example of usage:
const Scalar * const_iterator
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...
T::SmartPtr 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...
std::deque< CObservationPtr >::const_iterator const_iterator
You can use CSensoryFrame::begin to get a iterator to the first element.
Declares a virtual base class for all metric maps storage classes.
iterator end()
Returns a iterator to the end of the list of observations: 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::vector< T1 > & operator+=(std::vector< T1 > &a, const std::vector< T2 > &b)
a+=b (element-wise sum)
mrpt::slam::CMetricMapPtr m_cachedMap
A points map, build only under demand by the methods getAuxPointsMap() and buildAuxPointsMap().
iterator begin()
Returns a iterator to the first observation: this is an example of usage:
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...
bool empty() const
Returns true if there are no observations in the list.
Declares a class for storing a "sensory frame", a set of "observations" taken by the robot approximat...
A class used to store a 3D pose (a 3D translation + a rotation in 3D).
std::deque< CObservationPtr >::iterator iterator
You can use CSensoryFrame::begin to get a iterator to the first element.
A structure that holds runtime class type information.
bool insertObservationsInto(mrpt::slam::CMetricMapPtr &theMap, const CPose3D *robotPose=NULL) const
Insert all the observations in this SF into a metric map or any kind (see mrpt::slam::CMetricMap).
std::deque< CObservationPtr > m_observations
The set of observations taken at the same time instant.