Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(planning_evaluator): add modified goal deviation #3053

Merged
merged 6 commits into from
Mar 14, 2023
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ namespace metrics
{
using autoware_auto_planning_msgs::msg::Trajectory;
using autoware_auto_planning_msgs::msg::TrajectoryPoint;
using geometry_msgs::msg::Pose;

/**
* @brief calculate lateral deviation of the given trajectory from the reference trajectory
Expand All @@ -51,6 +52,30 @@ Stat<double> calcYawDeviation(const Trajectory & ref, const Trajectory & traj);
*/
Stat<double> calcVelocityDeviation(const Trajectory & ref, const Trajectory & traj);

/**
* @brief calculate longitudinal deviation of the given ego pose from the modified goal pose
* @param [in] base_pose base pose
* @param [in] target_pose target pose
* @return calculated statistics
*/
Stat<double> calcPoseLongitudinalDeviation(const Pose & base_pose, const Pose & target_pose);

/**
* @brief calculate lateral deviation of the given ego pose from the modified goal pose
* @param [in] base_pose base pose
* @param [in] target_pose target pose
* @return calculated statistics
*/
Stat<double> calcPoseLateralDeviation(const Pose & base_pose, const Pose & target_pose);

/**
* @brief calculate yaw deviation of the given ego pose from the modified goal pose
* @param [in] base_pose base pose
* @param [in] target_pose target pose
* @return calculated statistics
*/
Stat<double> calcPoseYawDeviation(const Pose & base_pose, const Pose & target_pose);

} // namespace metrics
} // namespace planning_diagnostics

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,9 @@ enum class Metric {
stability_frechet,
obstacle_distance,
obstacle_ttc,
modified_goal_longitudinal_deviation,
modified_goal_lateral_deviation,
modified_goal_yaw_deviation,
SIZE,
};

Expand All @@ -63,7 +66,10 @@ static const std::unordered_map<std::string, Metric> str_to_metric = {
{"stability_frechet", Metric::stability_frechet},
{"obstacle_distance", Metric::obstacle_distance},
{"obstacle_ttc", Metric::obstacle_ttc},
};
{"modified_goal_longitudinal_deviation", Metric::modified_goal_longitudinal_deviation},
{"modified_goal_lateral_deviation", Metric::modified_goal_lateral_deviation},
{"modified_goal_yaw_deviation", Metric::modified_goal_yaw_deviation}};

static const std::unordered_map<Metric, std::string> metric_to_str = {
{Metric::curvature, "curvature"},
{Metric::point_interval, "point_interval"},
Expand All @@ -79,7 +85,10 @@ static const std::unordered_map<Metric, std::string> metric_to_str = {
{Metric::stability, "stability"},
{Metric::stability_frechet, "stability_frechet"},
{Metric::obstacle_distance, "obstacle_distance"},
{Metric::obstacle_ttc, "obstacle_ttc"}};
{Metric::obstacle_ttc, "obstacle_ttc"},
{Metric::modified_goal_longitudinal_deviation, "modified_goal_longitudinal_deviation"},
{Metric::modified_goal_lateral_deviation, "modified_goal_lateral_deviation"},
{Metric::modified_goal_yaw_deviation, "modified_goal_yaw_deviation"}};

// Metrics descriptions
static const std::unordered_map<Metric, std::string> metric_descriptions = {
Expand All @@ -97,7 +106,10 @@ static const std::unordered_map<Metric, std::string> metric_descriptions = {
{Metric::stability, "Stability[m]"},
{Metric::stability_frechet, "StabilityFrechet[m]"},
{Metric::obstacle_distance, "Obstacle_distance[m]"},
{Metric::obstacle_ttc, "Obstacle_time_to_collision[s]"}};
{Metric::obstacle_ttc, "Obstacle_time_to_collision[s]"},
{Metric::modified_goal_longitudinal_deviation, "Modified_goal_longitudinal_deviation[m]"},
{Metric::modified_goal_lateral_deviation, "Modified_goal_lateral_deviation[m]"},
{Metric::modified_goal_yaw_deviation, "Modified_goal_yaw_deviation[rad]"}};

namespace details
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,21 +14,25 @@

#ifndef PLANNING_EVALUATOR__METRICS_CALCULATOR_HPP_
#define PLANNING_EVALUATOR__METRICS_CALCULATOR_HPP_

#include "planning_evaluator/metrics/metric.hpp"
#include "planning_evaluator/parameters.hpp"
#include "planning_evaluator/stat.hpp"

#include "autoware_auto_perception_msgs/msg/predicted_objects.hpp"
#include "autoware_auto_planning_msgs/msg/trajectory.hpp"
#include "autoware_auto_planning_msgs/msg/trajectory_point.hpp"
#include "autoware_planning_msgs/msg/pose_with_uuid_stamped.hpp"
#include "geometry_msgs/msg/pose.hpp"

#include <optional>

namespace planning_diagnostics
{
using autoware_auto_perception_msgs::msg::PredictedObjects;
using autoware_auto_planning_msgs::msg::Trajectory;
using autoware_auto_planning_msgs::msg::TrajectoryPoint;
using autoware_planning_msgs::msg::PoseWithUuidStamped;
using geometry_msgs::msg::Pose;

class MetricsCalculator
{
Expand All @@ -42,7 +46,9 @@ class MetricsCalculator
* @param [in] metric Metric enum value
* @return string describing the requested metric
*/
Stat<double> calculate(const Metric metric, const Trajectory & traj) const;
std::optional<Stat<double>> calculate(const Metric metric, const Trajectory & traj) const;
std::optional<Stat<double>> calculate(
const Metric metric, const Pose & base_pose, const Pose & target_pose) const;

/**
* @brief set the reference trajectory used to calculate the deviation metrics
Expand All @@ -68,6 +74,12 @@ class MetricsCalculator
*/
void setEgoPose(const geometry_msgs::msg::Pose & pose);

/**
* @brief get the ego pose
* @return ego pose
*/
Pose getEgoPose();

private:
/**
* @brief trim a trajectory from the current ego pose to some fixed time or distance
Expand All @@ -86,6 +98,7 @@ class MetricsCalculator
Trajectory previous_trajectory_lookahead_;
PredictedObjects dynamic_objects_;
geometry_msgs::msg::Pose ego_pose_;
PoseWithUuidStamped modified_goal_;
}; // class MetricsCalculator

} // namespace planning_diagnostics
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,9 @@
#include "autoware_auto_perception_msgs/msg/predicted_objects.hpp"
#include "autoware_auto_planning_msgs/msg/trajectory.hpp"
#include "autoware_auto_planning_msgs/msg/trajectory_point.hpp"
#include "autoware_planning_msgs/msg/pose_with_uuid_stamped.hpp"
#include "diagnostic_msgs/msg/diagnostic_array.hpp"
#include "nav_msgs/msg/odometry.hpp"

#include <array>
#include <deque>
Expand All @@ -37,8 +39,10 @@ namespace planning_diagnostics
using autoware_auto_perception_msgs::msg::PredictedObjects;
using autoware_auto_planning_msgs::msg::Trajectory;
using autoware_auto_planning_msgs::msg::TrajectoryPoint;
using autoware_planning_msgs::msg::PoseWithUuidStamped;
using diagnostic_msgs::msg::DiagnosticArray;
using diagnostic_msgs::msg::DiagnosticStatus;
using nav_msgs::msg::Odometry;

/**
* @brief Node for planning evaluation
Expand All @@ -49,6 +53,12 @@ class PlanningEvaluatorNode : public rclcpp::Node
explicit PlanningEvaluatorNode(const rclcpp::NodeOptions & node_options);
~PlanningEvaluatorNode();

/**
* @brief callback on receiving an odometry
* @param [in] odometry_msg received odometry message
*/
void onOdometry(const Odometry::ConstSharedPtr odometry_msg);

/**
* @brief callback on receiving a trajectory
* @param [in] traj_msg received trajectory message
Expand All @@ -68,9 +78,10 @@ class PlanningEvaluatorNode : public rclcpp::Node
void onObjects(const PredictedObjects::ConstSharedPtr objects_msg);

/**
* @brief update the ego pose stored in the MetricsCalculator
* @brief callback on receiving a modified goal
* @param [in] modified_goal_msg received modified goal message
*/
void updateCalculatorEgoPose(const std::string & target_frame);
void onModifiedGoal(const PoseWithUuidStamped::ConstSharedPtr modified_goal_msg);

/**
* @brief publish the given metric statistic
Expand All @@ -80,11 +91,15 @@ class PlanningEvaluatorNode : public rclcpp::Node

private:
static bool isFinite(const TrajectoryPoint & p);
void publishModifiedGoalDeviationMetrics();

// ROS
rclcpp::Subscription<Trajectory>::SharedPtr traj_sub_;
rclcpp::Subscription<Trajectory>::SharedPtr ref_sub_;
rclcpp::Subscription<PredictedObjects>::SharedPtr objects_sub_;
rclcpp::Subscription<PoseWithUuidStamped>::SharedPtr modified_goal_sub_;
rclcpp::Subscription<Odometry>::SharedPtr odom_sub_;

rclcpp::Publisher<DiagnosticArray>::SharedPtr metrics_pub_;
std::shared_ptr<tf2_ros::TransformListener> transform_listener_{nullptr};
std::unique_ptr<tf2_ros::Buffer> tf_buffer_;
Expand All @@ -99,6 +114,9 @@ class PlanningEvaluatorNode : public rclcpp::Node
std::vector<Metric> metrics_;
std::deque<rclcpp::Time> stamps_;
std::array<std::deque<Stat<double>>, static_cast<size_t>(Metric::SIZE)> metric_stats_;

Odometry::ConstSharedPtr ego_state_ptr_;
PoseWithUuidStamped::ConstSharedPtr modified_goal_ptr_;
};
} // namespace planning_diagnostics

Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,19 @@
<launch>
<arg name="input/odometry" default="/localization/kinematic_state"/>
<arg name="input/trajectory" default="/planning/scenario_planning/trajectory"/>
<arg name="input/reference_trajectory" default="/planning/scenario_planning/lane_driving/motion_planning/obstacle_avoidance_planner/trajectory"/>
<arg name="input/objects" default="/perception/object_recognition/objects"/>
<arg name="input/modified_goal" default="/planning/scenario_planning/modified_goal"/>

<!-- planning evaluator -->
<group>
<node name="planning_evaluator" exec="planning_evaluator" pkg="planning_evaluator">
<param from="$(find-pkg-share planning_evaluator)/param/planning_evaluator.defaults.yaml"/>
<remap from="~/input/odometry" to="$(var input/odometry)"/>
<remap from="~/input/trajectory" to="$(var input/trajectory)"/>
<remap from="~/input/reference_trajectory" to="$(var input/reference_trajectory)"/>
<remap from="~/input/objects" to="$(var input/objects)"/>
<remap from="~/input/modified_goal" to="$(var input/modified_goal)"/>
<remap from="~/metrics" to="/diagnostic/planning_evaluator/metrics"/>
</node>
</group>
Expand Down
1 change: 1 addition & 0 deletions evaluator/planning_evaluator/package.xml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@

<depend>autoware_auto_perception_msgs</depend>
<depend>autoware_auto_planning_msgs</depend>
<depend>autoware_planning_msgs</depend>
<depend>diagnostic_msgs</depend>
<depend>eigen</depend>
<depend>geometry_msgs</depend>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,9 @@
- stability_frechet
- obstacle_distance
- obstacle_ttc
- modified_goal_longitudinal_deviation
- modified_goal_lateral_deviation
- modified_goal_yaw_deviation

trajectory:
min_point_dist_m: 0.1 # [m] minimum distance between two successive points to use for angle calculation
Expand Down
21 changes: 21 additions & 0 deletions evaluator/planning_evaluator/src/metrics/deviation_metrics.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -77,5 +77,26 @@ Stat<double> calcVelocityDeviation(const Trajectory & ref, const Trajectory & tr
return stat;
}

Stat<double> calcPoseLongitudinalDeviation(const Pose & base_pose, const Pose & target_pose)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

const Pose & target_pose
can be replaced with
const Point & target_point?
if direction of target_pose is not used.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

thanks, fixed in 31c8b82

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(and 4ac91a0)

{
Stat<double> stat;
stat.add(
std::abs(tier4_autoware_utils::calcLongitudinalDeviation(base_pose, target_pose.position)));
return stat;
}

Stat<double> calcPoseLateralDeviation(const Pose & base_pose, const Pose & target_pose)
{
Stat<double> stat;
stat.add(std::abs(tier4_autoware_utils::calcLateralDeviation(base_pose, target_pose.position)));
return stat;
}

Stat<double> calcPoseYawDeviation(const Pose & base_pose, const Pose & target_pose)
{
Stat<double> stat;
stat.add(std::abs(tier4_autoware_utils::calcYawDeviation(base_pose, target_pose)));
return stat;
}
} // namespace metrics
} // namespace planning_diagnostics
27 changes: 22 additions & 5 deletions evaluator/planning_evaluator/src/metrics_calculator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,10 @@

namespace planning_diagnostics
{
Stat<double> MetricsCalculator::calculate(const Metric metric, const Trajectory & traj) const
std::optional<Stat<double>> MetricsCalculator::calculate(
const Metric metric, const Trajectory & traj) const
{
// Functions to calculate metrics
// Functions to calculate trajectory metrics
switch (metric) {
case Metric::curvature:
return metrics::calcTrajectoryCurvature(traj);
Expand Down Expand Up @@ -70,9 +71,23 @@ Stat<double> MetricsCalculator::calculate(const Metric metric, const Trajectory
case Metric::obstacle_ttc:
return metrics::calcTimeToCollision(dynamic_objects_, traj, parameters.obstacle.dist_thr_m);
default:
throw std::runtime_error(
"[MetricsCalculator][calculate()] unknown Metric " +
std::to_string(static_cast<int>(metric)));
return {};
}
}

std::optional<Stat<double>> MetricsCalculator::calculate(
const Metric metric, const Pose & base_pose, const Pose & target_pose) const
{
// Functions to calculate pose metrics
switch (metric) {
case Metric::modified_goal_longitudinal_deviation:
return metrics::calcPoseLongitudinalDeviation(base_pose, target_pose);
case Metric::modified_goal_lateral_deviation:
return metrics::calcPoseLateralDeviation(base_pose, target_pose);
case Metric::modified_goal_yaw_deviation:
return metrics::calcPoseYawDeviation(base_pose, target_pose);
default:
return {};
}
}

Expand All @@ -93,6 +108,8 @@ void MetricsCalculator::setPredictedObjects(const PredictedObjects & objects)

void MetricsCalculator::setEgoPose(const geometry_msgs::msg::Pose & pose) { ego_pose_ = pose; }

Pose MetricsCalculator::getEgoPose() { return ego_pose_; }

Trajectory MetricsCalculator::getLookaheadTrajectory(
const Trajectory & traj, const double max_dist_m, const double max_time_s) const
{
Expand Down
4 changes: 3 additions & 1 deletion evaluator/planning_evaluator/src/motion_evaluator_node.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,9 @@ MotionEvaluatorNode::~MotionEvaluatorNode()
f << std::endl;
for (Metric metric : metrics_) {
const auto & stat = metrics_calculator_.calculate(metric, accumulated_trajectory_);
f /* << std::setw(3 * column_width) */ << stat << " ";
if (stat) {
f /* << std::setw(3 * column_width) */ << *stat << " ";
}
}
f.close();
}
Expand Down
Loading