Skip to content

Commit

Permalink
feat(motion_utils): add planning factor interface (#9676)
Browse files Browse the repository at this point in the history
* feat(motion_utils): add planning factor interface

Signed-off-by: satoshi-ota <satoshi.ota928@gmail.com>

* fix: use extern template

Signed-off-by: satoshi-ota <satoshi.ota928@gmail.com>

* fix: define function in header

Signed-off-by: satoshi-ota <satoshi.ota928@gmail.com>

---------

Signed-off-by: satoshi-ota <satoshi.ota928@gmail.com>
  • Loading branch information
satoshi-ota authored Dec 19, 2024
1 parent 6ed5634 commit 067ee7a
Show file tree
Hide file tree
Showing 2 changed files with 287 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,240 @@
// Copyright 2024 TIER IV, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#ifndef AUTOWARE__MOTION_UTILS__FACTOR__PLANNING_FACTOR_INTERFACE_HPP_
#define AUTOWARE__MOTION_UTILS__FACTOR__PLANNING_FACTOR_INTERFACE_HPP_

#include <autoware/motion_utils/trajectory/trajectory.hpp>
#include <rclcpp/rclcpp.hpp>

#include <autoware_planning_msgs/msg/path_point.hpp>
#include <autoware_planning_msgs/msg/trajectory_point.hpp>
#include <geometry_msgs/msg/pose.hpp>
#include <tier4_planning_msgs/msg/control_point.hpp>
#include <tier4_planning_msgs/msg/path_point_with_lane_id.hpp>
#include <tier4_planning_msgs/msg/planning_factor.hpp>
#include <tier4_planning_msgs/msg/planning_factor_array.hpp>
#include <tier4_planning_msgs/msg/safety_factor_array.hpp>

#include <string>
#include <vector>

namespace autoware::motion_utils
{

using geometry_msgs::msg::Pose;
using tier4_planning_msgs::msg::ControlPoint;
using tier4_planning_msgs::msg::PlanningFactor;
using tier4_planning_msgs::msg::PlanningFactorArray;
using tier4_planning_msgs::msg::SafetyFactorArray;

class PlanningFactorInterface
{
public:
PlanningFactorInterface(rclcpp::Node * node, const std::string & name)
: name_{name},
pub_factors_{
node->create_publisher<PlanningFactorArray>("/planning/planning_factors/" + name, 1)},
clock_{node->get_clock()}
{
}

/**
* @brief factor setter for single control point.
*
* @param path points.
* @param ego current pose.
* @param control point pose. (e.g. stop or slow down point pose)
* @param behavior of this planning factor.
* @param safety factor.
* @param driving direction.
* @param target velocity of the control point.
* @param shift length of the control point.
* @param detail information.
*/
template <class PointType>
void add(
const std::vector<PointType> & points, const Pose & ego_pose, const Pose & control_point_pose,
const uint16_t behavior, const SafetyFactorArray & safety_factors,
const bool is_driving_forward = true, const double velocity = 0.0,
const double shift_length = 0.0, const std::string & detail = "")
{
const auto distance = static_cast<float>(autoware::motion_utils::calcSignedArcLength(
points, ego_pose.position, control_point_pose.position));
add(
distance, control_point_pose, behavior, safety_factors, is_driving_forward, velocity,
shift_length, detail);
}

/**
* @brief factor setter for two control points (section).
*
* @param path points.
* @param ego current pose.
* @param control section start pose. (e.g. lane change start point pose)
* @param control section end pose. (e.g. lane change end point pose)
* @param behavior of this planning factor.
* @param safety factor.
* @param driving direction.
* @param target velocity of the control point.
* @param shift length of the control point.
* @param detail information.
*/
template <class PointType>
void add(
const std::vector<PointType> & points, const Pose & ego_pose, const Pose & start_pose,
const Pose & end_pose, const uint16_t behavior, const SafetyFactorArray & safety_factors,
const bool is_driving_forward = true, const double velocity = 0.0,
const double shift_length = 0.0, const std::string & detail = "")
{
const auto start_distance = static_cast<float>(
autoware::motion_utils::calcSignedArcLength(points, ego_pose.position, start_pose.position));
const auto end_distance = static_cast<float>(
autoware::motion_utils::calcSignedArcLength(points, ego_pose.position, end_pose.position));
add(
start_distance, end_distance, start_pose, end_pose, behavior, safety_factors,
is_driving_forward, velocity, shift_length, detail);
}

/**
* @brief factor setter for single control point.
*
* @param distance to control point.
* @param control point pose. (e.g. stop point pose)
* @param behavior of this planning factor.
* @param safety factor.
* @param driving direction.
* @param target velocity of the control point.
* @param shift length of the control point.
* @param detail information.
*/
void add(
const double distance, const Pose & control_point_pose, const uint16_t behavior,
const SafetyFactorArray & safety_factors, const bool is_driving_forward = true,
const double velocity = 0.0, const double shift_length = 0.0, const std::string & detail = "")
{
const auto control_point = tier4_planning_msgs::build<ControlPoint>()
.pose(control_point_pose)
.velocity(velocity)
.shift_length(shift_length)
.distance(distance);

const auto factor = tier4_planning_msgs::build<PlanningFactor>()
.module(name_)
.is_driving_forward(is_driving_forward)
.control_points({control_point})
.behavior(behavior)
.detail(detail)
.safety_factors(safety_factors);

factors_.push_back(factor);
}

/**
* @brief factor setter for two control points (section).
*
* @param distance to control section start point.
* @param distance to control section end point.
* @param control section start pose. (e.g. lane change start point pose)
* @param control section end pose. (e.g. lane change end point pose)
* @param behavior of this planning factor.
* @param safety factor.
* @param driving direction.
* @param target velocity of the control point.
* @param shift length of the control point.
* @param detail information.
*/
void add(
const double start_distance, const double end_distance, const Pose & start_pose,
const Pose & end_pose, const uint16_t behavior, const SafetyFactorArray & safety_factors,
const bool is_driving_forward = true, const double velocity = 0.0,
const double shift_length = 0.0, const std::string & detail = "")
{
const auto control_start_point = tier4_planning_msgs::build<ControlPoint>()
.pose(start_pose)
.velocity(velocity)
.shift_length(shift_length)
.distance(start_distance);

const auto control_end_point = tier4_planning_msgs::build<ControlPoint>()
.pose(end_pose)
.velocity(velocity)
.shift_length(shift_length)
.distance(end_distance);

const auto factor = tier4_planning_msgs::build<PlanningFactor>()
.module(name_)
.is_driving_forward(is_driving_forward)
.control_points({control_start_point, control_end_point})
.behavior(behavior)
.detail(detail)
.safety_factors(safety_factors);

factors_.push_back(factor);
}

/**
* @brief publish planning factors.
*/
void publish()
{
PlanningFactorArray msg;
msg.header.frame_id = "map";
msg.header.stamp = clock_->now();
msg.factors = factors_;

pub_factors_->publish(msg);

factors_.clear();
}

private:
std::string name_;

rclcpp::Publisher<PlanningFactorArray>::SharedPtr pub_factors_;

rclcpp::Clock::SharedPtr clock_;

std::vector<PlanningFactor> factors_;
};

extern template void PlanningFactorInterface::add<tier4_planning_msgs::msg::PathPointWithLaneId>(
const std::vector<tier4_planning_msgs::msg::PathPointWithLaneId> &, const Pose &, const Pose &,
const uint16_t behavior, const SafetyFactorArray &, const bool, const double, const double,
const std::string &);
extern template void PlanningFactorInterface::add<autoware_planning_msgs::msg::PathPoint>(
const std::vector<autoware_planning_msgs::msg::PathPoint> &, const Pose &, const Pose &,
const uint16_t behavior, const SafetyFactorArray &, const bool, const double, const double,
const std::string &);
extern template void PlanningFactorInterface::add<autoware_planning_msgs::msg::TrajectoryPoint>(
const std::vector<autoware_planning_msgs::msg::TrajectoryPoint> &, const Pose &, const Pose &,
const uint16_t behavior, const SafetyFactorArray &, const bool, const double, const double,
const std::string &);

extern template void PlanningFactorInterface::add<tier4_planning_msgs::msg::PathPointWithLaneId>(
const std::vector<tier4_planning_msgs::msg::PathPointWithLaneId> &, const Pose &, const Pose &,
const Pose &, const uint16_t behavior, const SafetyFactorArray &, const bool, const double,
const double, const std::string &);
extern template void PlanningFactorInterface::add<autoware_planning_msgs::msg::PathPoint>(
const std::vector<autoware_planning_msgs::msg::PathPoint> &, const Pose &, const Pose &,
const Pose &, const uint16_t behavior, const SafetyFactorArray &, const bool, const double,
const double, const std::string &);
extern template void PlanningFactorInterface::add<autoware_planning_msgs::msg::TrajectoryPoint>(
const std::vector<autoware_planning_msgs::msg::TrajectoryPoint> &, const Pose &, const Pose &,
const Pose &, const uint16_t behavior, const SafetyFactorArray &, const bool, const double,
const double, const std::string &);

} // namespace autoware::motion_utils

#endif // AUTOWARE__MOTION_UTILS__FACTOR__PLANNING_FACTOR_INTERFACE_HPP_
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
// Copyright 2024 TIER IV, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.

#include <autoware/motion_utils/factor/planning_factor_interface.hpp>

#include <string>
#include <vector>

namespace autoware::motion_utils
{
template void PlanningFactorInterface::add<tier4_planning_msgs::msg::PathPointWithLaneId>(
const std::vector<tier4_planning_msgs::msg::PathPointWithLaneId> &, const Pose &, const Pose &,
const uint16_t behavior, const SafetyFactorArray &, const bool, const double, const double,
const std::string &);
template void PlanningFactorInterface::add<autoware_planning_msgs::msg::PathPoint>(
const std::vector<autoware_planning_msgs::msg::PathPoint> &, const Pose &, const Pose &,
const uint16_t behavior, const SafetyFactorArray &, const bool, const double, const double,
const std::string &);
template void PlanningFactorInterface::add<autoware_planning_msgs::msg::TrajectoryPoint>(
const std::vector<autoware_planning_msgs::msg::TrajectoryPoint> &, const Pose &, const Pose &,
const uint16_t behavior, const SafetyFactorArray &, const bool, const double, const double,
const std::string &);

template void PlanningFactorInterface::add<tier4_planning_msgs::msg::PathPointWithLaneId>(
const std::vector<tier4_planning_msgs::msg::PathPointWithLaneId> &, const Pose &, const Pose &,
const Pose &, const uint16_t behavior, const SafetyFactorArray &, const bool, const double,
const double, const std::string &);
template void PlanningFactorInterface::add<autoware_planning_msgs::msg::PathPoint>(
const std::vector<autoware_planning_msgs::msg::PathPoint> &, const Pose &, const Pose &,
const Pose &, const uint16_t behavior, const SafetyFactorArray &, const bool, const double,
const double, const std::string &);
template void PlanningFactorInterface::add<autoware_planning_msgs::msg::TrajectoryPoint>(
const std::vector<autoware_planning_msgs::msg::TrajectoryPoint> &, const Pose &, const Pose &,
const Pose &, const uint16_t behavior, const SafetyFactorArray &, const bool, const double,
const double, const std::string &);
} // namespace autoware::motion_utils

0 comments on commit 067ee7a

Please sign in to comment.