Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035 #include <mir_dwb_critics/path_angle.h>
00036 #include <pluginlib/class_list_macros.h>
00037 #include <nav_2d_utils/path_ops.h>
00038 #include <nav_grid/coordinate_conversion.h>
00039 #include <vector>
00040
00041 namespace mir_dwb_critics {
00042
00043 bool PathAngleCritic::prepare(const geometry_msgs::Pose2D &pose, const nav_2d_msgs::Twist2D &vel,
00044 const geometry_msgs::Pose2D &goal, const nav_2d_msgs::Path2D &global_plan) {
00045 const nav_core2::Costmap &costmap = *costmap_;
00046 const nav_grid::NavGridInfo &info = costmap.getInfo();
00047 nav_2d_msgs::Path2D adjusted_global_plan = nav_2d_utils::adjustPlanResolution(global_plan, info.resolution);
00048
00049 if (global_plan.poses.empty()) {
00050 ROS_ERROR_NAMED("PathAngleCritic", "The global plan was empty.");
00051 return false;
00052 }
00053
00054
00055 double distance_min = std::numeric_limits<double>::infinity();
00056 bool started_path = false;
00057 for (unsigned int i = 0; i < adjusted_global_plan.poses.size(); i++) {
00058 double g_x = adjusted_global_plan.poses[i].x;
00059 double g_y = adjusted_global_plan.poses[i].y;
00060 unsigned int map_x, map_y;
00061 if (worldToGridBounded(info, g_x, g_y, map_x, map_y) && costmap(map_x, map_y) != costmap.NO_INFORMATION) {
00062 double distance = nav_2d_utils::poseDistance(adjusted_global_plan.poses[i], pose);
00063 if (distance_min > distance) {
00064
00065 desired_angle_ = adjusted_global_plan.poses[i].theta;
00066 distance_min = distance;
00067 started_path = true;
00068 } else {
00069
00070 break;
00071 }
00072 } else if (started_path) {
00073
00074 break;
00075 }
00076
00077 }
00078
00079 if (!started_path) {
00080 ROS_ERROR_NAMED("PathAngleCritic", "None of the points of the global plan were in the local costmap.");
00081 return false;
00082 }
00083 return true;
00084 }
00085
00086 double PathAngleCritic::scoreTrajectory(const dwb_msgs::Trajectory2D &traj) {
00087 double diff = fabs(remainder(traj.poses.back().theta - desired_angle_, 2 * M_PI));
00088 return diff * diff;
00089 }
00090
00091 }
00092
00093 PLUGINLIB_EXPORT_CLASS(mir_dwb_critics::PathAngleCritic, dwb_local_planner::TrajectoryCritic)