hot_map_heuristic.h
Go to the documentation of this file.
1 //=================================================================================================
2 // Copyright (c) 2018, Alexander Stumpf, 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 VIGIR_FOOTSTEP_PLANNING_HOT_MAP_HEURISTIC_H__
30 #define VIGIR_FOOTSTEP_PLANNING_HOT_MAP_HEURISTIC_H__
31 
32 #include <ros/ros.h>
33 #include <boost/thread/mutex.hpp>
34 
35 #include <nav_msgs/OccupancyGrid.h>
36 
37 #include <vigir_footstep_planning_lib/math.h>
38 
39 #include <vigir_footstep_planning_plugins/plugins/heuristic_plugin.h>
40 
41 
42 
44 {
46  : public HeuristicPlugin
47 {
48 struct StateKey
49 {
50  StateKey(const State& s, double cell_size, double angle_bin_size)
51  : x(state_2_cell(s.getX(), cell_size))
52  , y(state_2_cell(s.getY(), cell_size))
53  , yaw(angle_state_2_cell(s.getYaw(), angle_bin_size))
54  {
55  }
56 
57  bool operator<(const StateKey& key) const
58  {
59  if (x < key.x) return true;
60  if (x > key.x) return false;
61  if (y < key.y) return true;
62  if (y > key.y) return false;
63  if (yaw < key.yaw) return true;
64  if (yaw > key.yaw) return false;
65  return false;
66  }
67 
68  int x;
69  int y;
70  int yaw;
71 };
72 
73 public:
75 
76  bool loadParams(const vigir_generic_params::ParameterSet& params = vigir_generic_params::ParameterSet()) override;
77 
78  bool initialize(const vigir_generic_params::ParameterSet& params = vigir_generic_params::ParameterSet()) override;
79 
80  void reset();
81 
82  double getHeuristicValue(const State& from, const State& to, const State& start, const State& goal) const override;
83 
84  // typedefs
85  typedef std::map<StateKey, unsigned int> HotMap;
86 
87 protected:
88  void publishHotMap(const ros::TimerEvent& publish_timer) const;
89 
90  // publisher
92 
94 
95  // mutex
96  mutable boost::shared_mutex hot_map_shared_mutex_;
97 
98  mutable HotMap hot_map_;
99  mutable unsigned int total_hit_counter_;
100 
101  double cell_size_;
103 };
104 }
105 
106 #endif
bool initialize(const vigir_generic_params::ParameterSet &params=vigir_generic_params::ParameterSet()) override
void publishHotMap(const ros::TimerEvent &publish_timer) const
double getHeuristicValue(const State &from, const State &to, const State &start, const State &goal) const override
bool loadParams(const vigir_generic_params::ParameterSet &params=vigir_generic_params::ParameterSet()) override
StateKey(const State &s, double cell_size, double angle_bin_size)
std::map< StateKey, unsigned int > HotMap


vigir_footstep_planning_default_plugins
Author(s): Alexander Stumpf
autogenerated on Sun Nov 17 2019 03:30:01