collvoid_simple_global_planner.cpp
Go to the documentation of this file.
00001 /*********************************************************************
00002 *
00003 * Software License Agreement (BSD License)
00004 *
00005 *  Copyright (c) 2008, Willow Garage, Inc.
00006 *  All rights reserved.
00007 *
00008 *  Redistribution and use in source and binary forms, with or without
00009 *  modification, are permitted provided that the following conditions
00010 *  are met:
00011 *
00012 *   * Redistributions of source code must retain the above copyright
00013 *     notice, this list of conditions and the following disclaimer.
00014 *   * Redistributions in binary form must reproduce the above
00015 *     copyright notice, this list of conditions and the following
00016 *     disclaimer in the documentation and/or other materials provided
00017 *     with the distribution.
00018 *   * Neither the name of Willow Garage, Inc. nor the names of its
00019 *     contributors may be used to endorse or promote products derived
00020 *     from this software without specific prior written permission.
00021 *
00022 *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00023 *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00024 *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00025 *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00026 *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00027 *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00028 *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00029 *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00030 *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00031 *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00032 *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00033 *  POSSIBILITY OF SUCH DAMAGE.
00034 *
00035 * Authors: Daniel Claes
00036 *********************************************************************/
00037 #include "collvoid_simple_global_planner/collvoid_simple_global_planner.h"
00038 #include <pluginlib/class_list_macros.h>
00039 
00040 
00041 //register this planner as a BaseGlobalPlanner plugin
00042 PLUGINLIB_DECLARE_CLASS(collvoid_simple_global_planner, CollvoidSimpleGlobalPlanner, collvoid_simple_global_planner::CollvoidSimpleGlobalPlanner, nav_core::BaseGlobalPlanner)
00043 
00044 namespace collvoid_simple_global_planner {
00045 
00046   CollvoidSimpleGlobalPlanner::CollvoidSimpleGlobalPlanner()
00047   {}
00048 
00049   CollvoidSimpleGlobalPlanner::CollvoidSimpleGlobalPlanner(std::string name, costmap_2d::Costmap2DROS* costmap_ros)
00050   {
00051     initialize(name, costmap_ros);
00052   }
00053   
00054   void CollvoidSimpleGlobalPlanner::initialize(std::string name, costmap_2d::Costmap2DROS* costmap_ros){
00055   }
00056 
00057   bool CollvoidSimpleGlobalPlanner::makePlan(const geometry_msgs::PoseStamped& start, 
00058       const geometry_msgs::PoseStamped& goal, std::vector<geometry_msgs::PoseStamped>& plan){
00059 
00060     ROS_DEBUG("Got a start: %.2f, %.2f, and a goal: %.2f, %.2f", start.pose.position.x, start.pose.position.y, goal.pose.position.x, goal.pose.position.y);
00061 
00062     plan.clear();
00063     plan.push_back(start);
00064     double x, y, dir_x, dir_y;
00065     dir_x = goal.pose.position.x - start.pose.position.x;
00066     dir_y = goal.pose.position.y - start.pose.position.y;
00067     double length = sqrt(dir_y * dir_y + dir_x * dir_x);
00068     dir_x /= length;
00069     dir_y /= length;
00070     x = start.pose.position.x + 0.1 * dir_x;
00071     y = start.pose.position.y + 0.1 * dir_y;
00072     ROS_DEBUG("dir: %.2f, %.2f, cur: %.2f, %.2f", dir_x, dir_y, x, y);
00073 
00074     while (fabs(x-goal.pose.position.x) > 0.2 || fabs(y-goal.pose.position.y) > 0.2) {
00075       geometry_msgs::PoseStamped point;
00076       point.header = goal.header;
00077       point.pose.position.x = x;
00078       point.pose.position.y = y;
00079       point.pose.orientation.w = 1;
00080       plan.push_back(point);
00081       x += 0.1 * dir_x;
00082       y += 0.1 * dir_y;
00083     }
00084     plan.push_back(goal);
00085 
00086     return true;
00087   }
00088 
00089 };
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Properties Friends


collvoid_simple_global_planner
Author(s): Daniel Claes
autogenerated on Sun Aug 25 2013 10:10:30