MapRepresentationInterface.h
Go to the documentation of this file.
1 //=================================================================================================
2 // Copyright (c) 2011, Stefan Kohlbrecher, TU Darmstadt
3 // All rights reserved.
4 
5 // Redistribution and use in source and binary forms, with or without
6 // modification, are permitted provided that the following conditions are met:
7 // * Redistributions of source code must retain the above copyright
8 // notice, this list of conditions and the following disclaimer.
9 // * Redistributions in binary form must reproduce the above copyright
10 // notice, this list of conditions and the following disclaimer in the
11 // documentation and/or other materials provided with the distribution.
12 // * Neither the name of the Simulation, Systems Optimization and Robotics
13 // group, TU Darmstadt nor the names of its contributors may be used to
14 // endorse or promote products derived from this software without
15 // specific prior written permission.
16 
17 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
18 // ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19 // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
20 // DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY
21 // DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
22 // (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23 // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24 // ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
26 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 //=================================================================================================
28 
29 #ifndef _hectormaprepresentationinterface_h__
30 #define _hectormaprepresentationinterface_h__
31 
32 class GridMap;
33 class ConcreteOccGridMapUtil;
34 class DataContainer;
35 
36 namespace hectorslam{
37 
39 {
40 public:
41 
43 
44  virtual void reset() = 0;
45 
46  virtual float getScaleToMap() const = 0;
47 
48  virtual int getMapLevels() const = 0;
49  virtual const GridMap& getGridMap(int mapLevel = 0) const = 0;
50 
51  virtual void addMapMutex(int i, MapLockerInterface* mapMutex) = 0;
52  virtual MapLockerInterface* getMapMutex(int i) = 0;
53 
54  virtual void onMapUpdated() = 0;
55 
56  virtual Eigen::Vector3f matchData(const Eigen::Vector3f& beginEstimateWorld, const DataContainer& dataContainer, Eigen::Matrix3f& covMatrix) = 0;
57 
58  virtual void updateByScan(const DataContainer& dataContainer, const Eigen::Vector3f& robotPoseWorld) = 0;
59 
60  virtual void setUpdateFactorFree(float free_factor) = 0;
61  virtual void setUpdateFactorOccupied(float occupied_factor) = 0;
62 };
63 
64 }
65 
66 #endif
virtual void setUpdateFactorFree(float free_factor)=0
DataPointContainer< Eigen::Vector2f > DataContainer
virtual Eigen::Vector3f matchData(const Eigen::Vector3f &beginEstimateWorld, const DataContainer &dataContainer, Eigen::Matrix3f &covMatrix)=0
virtual void addMapMutex(int i, MapLockerInterface *mapMutex)=0
virtual float getScaleToMap() const =0
virtual const GridMap & getGridMap(int mapLevel=0) const =0
virtual void updateByScan(const DataContainer &dataContainer, const Eigen::Vector3f &robotPoseWorld)=0
virtual MapLockerInterface * getMapMutex(int i)=0
virtual void setUpdateFactorOccupied(float occupied_factor)=0
OccGridMapBase< LogOddsCell, GridMapLogOddsFunctions > GridMap
Definition: GridMap.h:39
virtual int getMapLevels() const =0


hector_mapping
Author(s): Stefan Kohlbrecher
autogenerated on Sun Nov 3 2019 03:18:33