00001 /* 00002 * Copyright 2013 Armin Hornung, University of Freiburg 00003 * 00004 * Redistribution and use in source and binary forms, with or without 00005 * modification, are permitted provided that the following conditions are met: 00006 * 00007 * * Redistributions of source code must retain the above copyright 00008 * notice, this list of conditions and the following disclaimer. 00009 * * Redistributions in binary form must reproduce the above copyright 00010 * notice, this list of conditions and the following disclaimer in the 00011 * documentation and/or other materials provided with the distribution. 00012 * * Neither the name of the University of Freiburg nor the names of its 00013 * contributors may be used to endorse or promote products derived from 00014 * this software without specific prior written permission. 00015 * 00016 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00017 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00018 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00019 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE 00020 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00021 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00022 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00023 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00024 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00025 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00026 * POSSIBILITY OF SUCH DAMAGE. 00027 */ 00028 00029 #ifndef HUMANOID_PLANNER_2D_SBPL_2D_PLANNER_ 00030 #define HUMANOID_PLANNER_2D_SBPL_2D_PLANNER_ 00031 00032 #include <ros/ros.h> 00033 #include <geometry_msgs/PoseStamped.h> 00034 #include <geometry_msgs/PoseWithCovarianceStamped.h> 00035 #include <sbpl/headers.h> 00036 #include <visualization_msgs/Marker.h> 00037 #include <nav_msgs/Path.h> 00038 #include <gridmap_2d/GridMap2D.h> 00039 00040 00041 class SBPLPlanner2D { 00042 public: 00043 SBPLPlanner2D(); 00044 virtual ~SBPLPlanner2D(); 00046 void goalCallback(const geometry_msgs::PoseStampedConstPtr& goal); 00048 void startCallback(const geometry_msgs::PoseWithCovarianceStampedConstPtr& start); 00050 void mapCallback(const nav_msgs::OccupancyGridConstPtr& occupancy_map); 00052 bool updateMap(gridmap_2d::GridMap2DPtr map); 00053 00054 gridmap_2d::GridMap2DPtr getMap() const { return map_;}; 00055 00064 bool plan(const geometry_msgs::Pose& start, const geometry_msgs::Pose& goal); 00065 00072 bool plan(double startX, double startY, double goalX, double goalY); 00073 00075 inline double getPathCosts() const{return path_costs_;}; 00076 00077 inline const nav_msgs::Path& getPath() const{return path_;}; 00078 inline double getRobotRadius() const{return robot_radius_;}; 00079 00080 protected: 00081 bool plan(); 00082 void setPlanner(); 00083 ros::NodeHandle nh_; 00084 ros::Subscriber goal_sub_, start_sub_, map_sub_; 00085 ros::Publisher path_pub_; 00086 boost::shared_ptr<SBPLPlanner> planner_; 00087 boost::shared_ptr<EnvironmentNAV2D> planner_environment_; 00088 gridmap_2d::GridMap2DPtr map_; 00089 00090 std::string planner_type_; 00091 double allocated_time_; 00092 double initial_epsilon_; 00093 bool search_until_first_solution_; 00094 bool forward_search_; 00095 double robot_radius_; 00096 00097 bool start_received_, goal_received_; 00098 geometry_msgs::Pose start_pose_, goal_pose_; 00099 nav_msgs::Path path_; 00100 double path_costs_; 00101 00102 static const unsigned char OBSTACLE_COST = 20; 00103 00104 }; 00105 00106 #endif