From e9516cd044a79a813a78a029bd0396a4777de5f8 Mon Sep 17 00:00:00 2001 From: artzha Date: Tue, 10 Dec 2024 16:45:47 -0600 Subject: [PATCH] [Feature] Added working version of mapless gps navigation --- config/navigation.lua | 4 +- src/navigation/navigation.cc | 83 +++++++++++++++++++------------ src/navigation/navigation_main.cc | 8 ++- src/shared | 2 +- 4 files changed, 60 insertions(+), 37 deletions(-) diff --git a/config/navigation.lua b/config/navigation.lua index 4635552..4c06dcf 100644 --- a/config/navigation.lua +++ b/config/navigation.lua @@ -3,7 +3,7 @@ function deg2rad(deg) end OSMPlannerParameters = { - gps_topic = "/vectornav/gps_with_heading"; + gps_topic = "/vectornav/GPSHeading"; gps_goals_topic = "/gps_goals"; osrm_file = "osrm_texas_cbf_mld/texas-latest.osrm"; osrm_path_resolution = 8; -- meters between GPS points @@ -29,7 +29,7 @@ NavigationParameters = { max_angular_accel = 0.5; max_angular_decel = 0.5; max_angular_speed = 1.0; - carrot_dist = 20.0; + carrot_dist = 10.0; system_latency = 0.24; obstacle_margin = 0.15; num_options = 31; diff --git a/src/navigation/navigation.cc b/src/navigation/navigation.cc index ca8004f..ff808e8 100644 --- a/src/navigation/navigation.cc +++ b/src/navigation/navigation.cc @@ -347,7 +347,8 @@ void Navigation::SetGPSNavGoals(const vector& goals) { } bool Navigation::GetNextGPSGoal(GPSMsg& goal_msg) { - if (gps_nav_goals_loc_.empty()) return false; + if (gps_nav_goals_loc_.empty() || gps_goal_index_ >= 0) return false; + CHECK_GT(int(gps_nav_goals_loc_.size()), gps_goal_index_); goal_msg = GPSMsg(); goal_msg.latitude = gps_nav_goals_loc_[gps_goal_index_].lat; @@ -472,6 +473,7 @@ void Navigation::UpdateOdometry(const Odom& msg) { void Navigation::UpdateGPS(const GPSPoint& msg) { robot_gps_loc_ = msg; + // Change GPS heading if (!gps_initialized_) { initial_gps_loc_ = robot_gps_loc_; gps_initialized_ = true; @@ -903,28 +905,26 @@ void Navigation::OSMPlannerTest() { void Navigation::GPSPlannerTest(Vector2f& cmd_vel, float& cmd_angle_vel) { const static bool kDebug = FLAGS_v > 0; - static bool isGoalSet = false; - + printf("GPSPlannerTest()\n"); // Offset current GPS location by 20 meters in map frame. Set as target. - if (!gps_initialized_) return; + if (!gps_initialized_ || gps_nav_goals_loc_.empty()) return; - if (!isGoalSet) { - // Replan global path and set next goal - ReplanAndSetNextNavGoal(true); - isGoalSet = true; - } else { - // Select next nav goal - ReplanAndSetNextNavGoal(false); - } + // Select next nav goal + ReplanAndSetNextNavGoal(false); + printf("Robot loc and heading: %f %f %f\n", robot_loc_.x(), robot_loc_.y(), + robot_angle_); + printf("GPSPlannerTest(): %f %f\n", nav_goal_loc_.x(), nav_goal_loc_.y()); Vector2f carrot; - GetLocalCarrot(carrot); - // Select Carrot Location - if (kDebug) printf("Carrot: %f %f\n", carrot.x(), carrot.y()); + GetLocalCarrotHeading(carrot); // Transform carrot to local frame local_target_ = Rotation2Df(-robot_angle_) * (carrot - robot_loc_); - + // Select Carrot Location + if (kDebug) { + printf("Map Carrot: %f %f\n", carrot.x(), carrot.y()); + printf("Local Carrot: %f %f\n", local_target_.x(), local_target_.y()); + } // Run obstacle avoidance RunObstacleAvoidance(cmd_vel, cmd_angle_vel); } @@ -1014,17 +1014,23 @@ bool Navigation::GetGlobalCarrot(Vector2f& carrot) { bool Navigation::GetLocalCarrotHeading(Vector2f& carrot) { if (gps_nav_goals_loc_.empty()) return false; - if (gps_goal_index_ < 0 || gps_goal_index_ >= int(gps_nav_goals_loc_.size())) return false; + if (gps_goal_index_ < 0 || gps_goal_index_ >= int(gps_nav_goals_loc_.size())) + return false; Vector2f T_goal_map = nav_goal_loc_; + Vector2f T_base_map = robot_loc_; + // Compute current odometry estimated location in map frame - Affine2f T_odom_map = OdometryToUTMTransform(initial_odom_msg_, initial_gps_loc_); - Affine2f T_base_odom = Translation2f(odom_loc_) * Rotation2Df(odom_angle_); - Affine2f T_base_map = T_odom_map * T_base_odom; + // Affine2f T_odom_map = + // OdometryToUTMTransform(initial_odom_msg_, initial_gps_loc_); + // Affine2f T_base_odom = Translation2f(odom_loc_) * + // Rotation2Df(odom_angle_); Affine2f T_base_map = T_odom_map * + // T_base_odom; // Goal carrot is a point on the carrot circle around robot - Vector2f goal_vec_norm = (T_goal_map - T_base_map.translation()).normalized(); - carrot = T_odom_map.translation() + goal_vec_norm * params_.carrot_dist; + Vector2f goal_vec_norm = (T_goal_map - T_base_map).normalized(); + // carrot = T_odom_map.translation() + goal_vec_norm * params_.carrot_dist; + carrot = T_base_map + goal_vec_norm * params_.carrot_dist; return true; } @@ -1424,14 +1430,16 @@ int Navigation::GetNextGPSGlobalGoal(int start_goal_index) { GPSPoint subgoal = gps_nav_goals_loc_[i]; double robot_to_final_goal = gpsDistance(robot_gps_loc_, final_goal); double subgoal_to_final_goal = gpsDistance(subgoal, final_goal); + double robot_to_subgoal = gpsDistance(robot_gps_loc_, subgoal); + if (kDebug) { printf("Checking subgoal %d\n", i); printf("Robot dist to final goal: %f\n", robot_to_final_goal); printf("Subgoal dist to final goal: %f\n", subgoal_to_final_goal); } - if (robot_to_final_goal > subgoal_to_final_goal) { + if (robot_to_final_goal < subgoal_to_final_goal || + robot_to_subgoal < params_.intermediate_goal_tolerance) { start_goal_index = i; - break; } } @@ -1446,9 +1454,14 @@ bool Navigation::IsGoalInFOV(const Vector2f& local_goal) { } void Navigation::ReplanAndSetNextNavGoal(bool replan) { - if (gps_nav_goals_loc_.empty() || !gps_initialized_) return; + if (gps_nav_goals_loc_.empty() || !gps_initialized_ || + gps_goal_index_ > int(gps_nav_goals_loc_.size())) + return; + + printf("GPS goal index: %d\n", gps_goal_index_); if (replan) { // Replans, sets next nav goal, and sets it as next goal - const auto& route = this->GlobalPlan(robot_gps_loc_, gps_nav_goals_loc_); + vector goals = {gps_nav_goals_loc_.back()}; + const auto& route = this->GlobalPlan(robot_gps_loc_, goals); const auto& map_route = this->GPSRouteToMap(route); this->SetGPSNavGoals(route); // Updates gps_goal_index_ } else { // Only update next goal if not replanning @@ -1498,7 +1511,8 @@ bool Navigation::Run(const double& time, Vector2f& cmd_vel, } else if (FLAGS_test_gps_planner) { GPSPlannerTest(cmd_vel, cmd_angle_vel); return true; - } if (FLAGS_test_latency) { + } + if (FLAGS_test_latency) { LatencyTest(cmd_vel, cmd_angle_vel); return true; } @@ -1689,14 +1703,17 @@ bool Navigation::Run(const double& time, Vector2f& cmd_vel, } } - bool isLastGoalReached = gps_goal_index_ >= 0 && - gps_goal_index_ == int(gps_nav_goals_loc_.size()) - 1 && - osm_planner_.IsGoalReached(gps_nav_goals_loc_.back(), params_.intermediate_goal_tolerance); + bool isLastGoalReached = + gps_goal_index_ >= 0 && + gps_goal_index_ == int(gps_nav_goals_loc_.size()) - 1 && + osm_planner_.IsGoalReached(gps_nav_goals_loc_.back(), + params_.intermediate_goal_tolerance); bool isNavComplete = gps_nav_goals_loc_.empty() || isLastGoalReached; bool isGoalInFOV = IsGoalInFOV(nav_goal_loc_); - if (kDebug) printf("Run() isLastGoalReached %d isNavComplete %d isGoalInFOV %d\n", - isLastGoalReached, isNavComplete, isGoalInFOV); + if (kDebug) + printf("Run() isLastGoalReached %d isNavComplete %d isGoalInFOV %d\n", + isLastGoalReached, isNavComplete, isGoalInFOV); if (isNavComplete) { nav_state_ = NavigationState::kStopped; } else if (isGoalInFOV) { @@ -1706,7 +1723,7 @@ bool Navigation::Run(const double& time, Vector2f& cmd_vel, /** * Conditions: - * 1. If goal is invalid, replan global path. + * 1. If goal is invalid, replan global path. * 2. If goal is still valid, update next global goal */ bool isGPSGoalValid = PlanStillValid(); diff --git a/src/navigation/navigation_main.cc b/src/navigation/navigation_main.cc index 6390449..2c5c2ec 100644 --- a/src/navigation/navigation_main.cc +++ b/src/navigation/navigation_main.cc @@ -1114,17 +1114,23 @@ int main(int argc, char** argv) { // global_viz_msg_); // } } - + // printf("Navigation succeeded\n"); PublishForwardPredictedPCL(navigation_.GetPredictedCloud()); + // printf("Predicted cloud published\n"); DrawRobot(); + // printf("Robot drawn\n"); if (navigation_.GetNavStatusUint8() != static_cast(navigation::NavigationState::kStopped)) { DrawTarget(); DrawPathOptions(); } + // printf("Drew path options\n"); PublishVisualizationMarkers(); + // printf("Published visualization markers\n"); PublishPath(); + // printf("Published path\n"); PublishNextGPSGoal(); + // printf("Published next GPS goal\n"); local_viz_msg_.header.stamp = ros::Time::now(); global_viz_msg_.header.stamp = ros::Time::now(); viz_pub_.publish(local_viz_msg_); diff --git a/src/shared b/src/shared index 3850fd9..0d47c47 160000 --- a/src/shared +++ b/src/shared @@ -1 +1 @@ -Subproject commit 3850fd9862dfa5cc07ba733b26df1f919096f2a2 +Subproject commit 0d47c478efe1c0e54859e08605583f9279b0497c