Skip to content

Commit

Permalink
feat(objects_of_interest_marker_interface): add objects of interest m…
Browse files Browse the repository at this point in the history
…arker interface (autowarefoundation#5564)

* feat(interest_objects_marker_interface): add interest objects marker interface

Signed-off-by: Fumiya Watanabe <[email protected]>

* feat(interest_objects_marker_interface): change marker type

Signed-off-by: Fumiya Watanabe <[email protected]>

* feat(interest_objects_marker_interface): change markers

Signed-off-by: Fumiya Watanabe <[email protected]>

* feat(interest_objects_marker_interface): fix lane change interface

Signed-off-by: Fumiya Watanabe <[email protected]>

* feat(interest_objects_marker_interface): fix interface

Signed-off-by: Fumiya Watanabe <[email protected]>

* refactor(interest_objects_marker_interface): fix interface

Signed-off-by: Fumiya Watanabe <[email protected]>

* refactor(interest_objects_marker_interface): refactor and add descriptions

Signed-off-by: Fumiya Watanabe <[email protected]>

* refactor(lane_change): refactor

Signed-off-by: Fumiya Watanabe <[email protected]>

* docs(interest_objects_visualization): add contents (under construction)

Signed-off-by: Fumiya Watanabe <[email protected]>

* chore(interest_objects_visualization): fix includes and package.xml

Signed-off-by: Fumiya Watanabe <[email protected]>

* fix(interest_objects_marker_interface): fix

Signed-off-by: Fumiya Watanabe <[email protected]>

* refactor(objects_of_interest_marker_interface): rename interface

Signed-off-by: Fumiya Watanabe <[email protected]>

---------

Signed-off-by: Fumiya Watanabe <[email protected]>
  • Loading branch information
rej55 committed Nov 29, 2023
1 parent 67d4c14 commit 97b59d9
Show file tree
Hide file tree
Showing 16 changed files with 576 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@
#include "behavior_path_planner/utils/lane_change/lane_change_module_data.hpp"
#include "behavior_path_planner/utils/lane_change/lane_change_path.hpp"
#include "behavior_path_planner/utils/path_shifter/path_shifter.hpp"
#include "objects_of_interest_marker_interface/objects_of_interest_marker_interface.hpp"

#include <rclcpp/rclcpp.hpp>

Expand All @@ -48,6 +49,8 @@ namespace behavior_path_planner
using autoware_auto_planning_msgs::msg::PathWithLaneId;
using geometry_msgs::msg::Pose;
using geometry_msgs::msg::Twist;
using objects_of_interest_marker_interface::ColorName;
using objects_of_interest_marker_interface::ObjectsOfInterestMarkerInterface;
using tier4_planning_msgs::msg::LaneChangeDebugMsg;
using tier4_planning_msgs::msg::LaneChangeDebugMsgArray;

Expand Down Expand Up @@ -107,6 +110,13 @@ class LaneChangeInterface : public SceneModuleInterface

void setObjectDebugVisualization() const;

void setObjectsOfInterestData(const bool is_approved);

void publishObjectsOfInterestData()
{
objects_of_interest_marker_interface_.publishMarkerArray();
}

void updateSteeringFactorPtr(const BehaviorModuleOutput & output);

void updateSteeringFactorPtr(
Expand All @@ -116,6 +126,7 @@ class LaneChangeInterface : public SceneModuleInterface
mutable LaneChangeDebugMsgArray lane_change_debug_msg_array_;

std::unique_ptr<PathWithLaneId> prev_approved_path_;
ObjectsOfInterestMarkerInterface objects_of_interest_marker_interface_;

void clearAbortApproval() { is_abort_path_approved_ = false; }

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -196,6 +196,7 @@ struct CollisionCheckDebug
std::vector<PoseWithVelocityAndPolygonStamped> obj_predicted_path; ///< object's predicted path.
Polygon2d extended_ego_polygon{}; ///< Ego vehicle's extended collision polygon.
Polygon2d extended_obj_polygon{}; ///< Detected object's extended collision polygon.
autoware_auto_perception_msgs::msg::Shape obj_shape{}; ///< object's shape.
};
using CollisionCheckDebugPair = std::pair<std::string, CollisionCheckDebug>;
using CollisionCheckDebugMap =
Expand Down
1 change: 1 addition & 0 deletions planning/behavior_path_planner/package.xml
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@
<depend>magic_enum</depend>
<depend>motion_utils</depend>
<depend>object_recognition_utils</depend>
<depend>objects_of_interest_marker_interface</depend>
<depend>planning_test_utils</depend>
<depend>rclcpp</depend>
<depend>rclcpp_components</depend>
Expand Down
1 change: 1 addition & 0 deletions planning/behavior_path_planner/src/marker_utils/utils.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ CollisionCheckDebugPair createObjectDebug(const ExtendedPredictedObject & obj)
CollisionCheckDebug debug;
debug.current_obj_pose = obj.initial_pose.pose;
debug.current_twist = obj.initial_twist.twist;
debug.obj_shape = obj.shape;
return {tier4_autoware_utils::toHexString(obj.uuid), debug};
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,8 @@ LaneChangeInterface::LaneChangeInterface(
: SceneModuleInterface{name, node, rtc_interface_ptr_map},
parameters_{std::move(parameters)},
module_type_{std::move(module_type)},
prev_approved_path_{std::make_unique<PathWithLaneId>()}
prev_approved_path_{std::make_unique<PathWithLaneId>()},
objects_of_interest_marker_interface_{&node, name}
{
steering_factor_interface_ptr_ = std::make_unique<SteeringFactorInterface>(&node, name);
}
Expand Down Expand Up @@ -224,6 +225,9 @@ BehaviorModuleOutput LaneChangeInterface::plan()

stop_pose_ = module_type_->getStopPose();

setObjectsOfInterestData(true);
publishObjectsOfInterestData();

updateSteeringFactorPtr(output);
clearWaitingApproval();

Expand All @@ -246,6 +250,8 @@ BehaviorModuleOutput LaneChangeInterface::planWaitingApproval()
getPreviousModuleOutput().reference_path, getPreviousModuleOutput().path);
module_type_->updateLaneChangeStatus();
setObjectDebugVisualization();
setObjectsOfInterestData(false);
publishObjectsOfInterestData();

// change turn signal when the vehicle reaches at the end of the path for waiting lane change
out.turn_signal_info = getCurrentTurnSignalInfo(*out.path, out.turn_signal_info);
Expand Down Expand Up @@ -330,6 +336,18 @@ void LaneChangeInterface::setObjectDebugVisualization() const
}
}

void LaneChangeInterface::setObjectsOfInterestData(const bool is_approved)
{
const auto debug_data =
is_approved ? module_type_->getAfterApprovalDebugData() : module_type_->getDebugData();
for (const auto & [uuid, data] : debug_data) {
const auto color = data.is_safe ? ColorName::GREEN : ColorName::RED;
objects_of_interest_marker_interface_.insertObjectData(
data.current_obj_pose, data.obj_shape, color);
}
return;
}

std::shared_ptr<LaneChangeDebugMsgArray> LaneChangeInterface::get_debug_msg_array() const
{
const auto debug_data = module_type_->getDebugData();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -274,6 +274,8 @@ bool checkCollision(
const auto interpolated_data = getInterpolatedPoseWithVelocityAndPolygonStamped(
predicted_ego_path, current_time, ego_vehicle_info);
if (!interpolated_data) {
debug.expected_obj_pose = obj_pose;
debug.extended_obj_polygon = obj_polygon;
continue;
}
const auto & ego_pose = interpolated_data->pose;
Expand Down
27 changes: 27 additions & 0 deletions planning/objects_of_interest_marker_interface/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
cmake_minimum_required(VERSION 3.5)
project(objects_of_interest_marker_interface)

### Compile options
if(NOT CMAKE_CXX_STANDARD)
set(CMAKE_CXX_STANDARD 17)
endif()
if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang")
add_compile_options(-Wall -Wextra -Wpedantic -Werror)
endif()

find_package(ament_cmake_auto REQUIRED)
ament_auto_find_build_dependencies()

ament_auto_add_library(objects_of_interest_marker_interface SHARED
src/coloring.cpp
src/objects_of_interest_marker_interface.cpp
src/marker_utils.cpp
)

# Test
if(BUILD_TESTING)
find_package(ament_lint_auto REQUIRED)
ament_lint_auto_find_test_dependencies()
endif()

ament_auto_package()
15 changes: 15 additions & 0 deletions planning/objects_of_interest_marker_interface/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
# Objects Of Interest Marker Interface

!!! warning

Under Construction

## Purpose

## Inner-workings / Algorithms

## Inputs / Outputs

## Assumptions / Known limits

## Future extensions / Unimplemented parts
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
// Copyright 2023 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 OBJECTS_OF_INTEREST_MARKER_INTERFACE__COLORING_HPP_
#define OBJECTS_OF_INTEREST_MARKER_INTERFACE__COLORING_HPP_
#include "objects_of_interest_marker_interface/marker_data.hpp"

#include <tier4_autoware_utils/ros/marker_helper.hpp>

#include <std_msgs/msg/color_rgba.hpp>

namespace objects_of_interest_marker_interface::coloring
{
std_msgs::msg::ColorRGBA getGreen(const float alpha);
std_msgs::msg::ColorRGBA getAmber(const float alpha);
std_msgs::msg::ColorRGBA getRed(const float alpha);
std_msgs::msg::ColorRGBA getGray(const float alpha);
} // namespace objects_of_interest_marker_interface::coloring

#endif // OBJECTS_OF_INTEREST_MARKER_INTERFACE__COLORING_HPP_
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
// Copyright 2023 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 OBJECTS_OF_INTEREST_MARKER_INTERFACE__MARKER_DATA_HPP_
#define OBJECTS_OF_INTEREST_MARKER_INTERFACE__MARKER_DATA_HPP_

#include <autoware_auto_perception_msgs/msg/predicted_object.hpp>
#include <geometry_msgs/msg/pose.hpp>
#include <std_msgs/msg/color_rgba.hpp>

namespace objects_of_interest_marker_interface
{
struct ObjectMarkerData
{
geometry_msgs::msg::Pose pose{};
autoware_auto_perception_msgs::msg::Shape shape{};
std_msgs::msg::ColorRGBA color;
};

enum class ColorName { GRAY, GREEN, AMBER, RED };
} // namespace objects_of_interest_marker_interface

#endif // OBJECTS_OF_INTEREST_MARKER_INTERFACE__MARKER_DATA_HPP_
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
// Copyright 2023 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 OBJECTS_OF_INTEREST_MARKER_INTERFACE__MARKER_UTILS_HPP_
#define OBJECTS_OF_INTEREST_MARKER_INTERFACE__MARKER_UTILS_HPP_
#include "objects_of_interest_marker_interface/marker_data.hpp"

#include <tier4_autoware_utils/geometry/boost_polygon_utils.hpp>
#include <tier4_autoware_utils/geometry/geometry.hpp>
#include <tier4_autoware_utils/math/constants.hpp>
#include <tier4_autoware_utils/math/trigonometry.hpp>
#include <tier4_autoware_utils/ros/marker_helper.hpp>

#include <autoware_auto_perception_msgs/msg/predicted_object.hpp>
#include <geometry_msgs/msg/pose.hpp>
#include <std_msgs/msg/color_rgba.hpp>
#include <visualization_msgs/msg/marker_array.hpp>

#include <string>

namespace objects_of_interest_marker_interface::marker_utils
{
/**
* @brief Create arrow marker from object marker data
* @param id Marker id
* @param data Object marker data
* @param name Module name
* @param height_offset Height offset of arrow marker
* @param arrow_length Length of arrow marker
*/
visualization_msgs::msg::Marker createArrowMarker(
const size_t id, const ObjectMarkerData & data, const std::string & name,
const double height_offset, const double arrow_length = 1.0);

/**
* @brief Create circle marker from object marker data
* @param id Marker id
* @param data Object marker data
* @param name Module name
* @param radius Radius of circle marker
* @param height_offset Height offset of circle marker
* @param line_width Line width of circle marker
*/
visualization_msgs::msg::Marker createCircleMarker(
const size_t id, const ObjectMarkerData & data, const std::string & name, const double radius,
const double height_offset, const double line_width = 0.1);

/**
* @brief Create target marker from object marker data
* @param id Marker id
* @param data Object marker data
* @param name Module name
* @param height_offset Height offset of target marker
* @param arrow_length Length of arrow marker
* @param line_width Line width of circle marker
*/
visualization_msgs::msg::MarkerArray createTargetMarker(
const size_t id, const ObjectMarkerData & data, const std::string & name,
const double height_offset, const double arrow_length = 1.0, const double line_width = 0.1);
} // namespace objects_of_interest_marker_interface::marker_utils

#endif // OBJECTS_OF_INTEREST_MARKER_INTERFACE__MARKER_UTILS_HPP_
Original file line number Diff line number Diff line change
@@ -0,0 +1,93 @@
// Copyright 2023 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 OBJECTS_OF_INTEREST_MARKER_INTERFACE__OBJECTS_OF_INTEREST_MARKER_INTERFACE_HPP_
#define OBJECTS_OF_INTEREST_MARKER_INTERFACE__OBJECTS_OF_INTEREST_MARKER_INTERFACE_HPP_
#include "objects_of_interest_marker_interface/coloring.hpp"
#include "objects_of_interest_marker_interface/marker_data.hpp"
#include "objects_of_interest_marker_interface/marker_utils.hpp"

#include <rclcpp/rclcpp.hpp>

#include <autoware_auto_perception_msgs/msg/predicted_object.hpp>
#include <geometry_msgs/msg/pose.hpp>
#include <std_msgs/msg/color_rgba.hpp>
#include <visualization_msgs/msg/marker_array.hpp>

#include <string>
#include <vector>

namespace objects_of_interest_marker_interface
{
class ObjectsOfInterestMarkerInterface
{
public:
/**
* @brief Constructor
* @param node Node that publishes marker
* @param name Module name
*/
ObjectsOfInterestMarkerInterface(rclcpp::Node * node, const std::string & name);

/**
* @brief Insert object data to visualize
* @param pose Object pose
* @param shape Object shape
* @param color_name Color name
*/
void insertObjectData(
const geometry_msgs::msg::Pose & pose, const autoware_auto_perception_msgs::msg::Shape & shape,
const ColorName & color_name);

/**
* @brief Insert object data to visualize with custom color data
* @param pose Object pose
* @param shape Object shape
* @param color Color data with alpha
*/
void insertObjectDataWithCustomColor(
const geometry_msgs::msg::Pose & pose, const autoware_auto_perception_msgs::msg::Shape & shape,
const std_msgs::msg::ColorRGBA & color);

/**
* @brief Publish interest objects marker
*/
void publishMarkerArray();

/**
* @brief Set height offset of markers
* @param offset Height offset of markers
*/
void setHeightOffset(const double offset);

/**
* @brief Get color data from color name
* @param color_name Color name
* @param alpha Alpha
*/
static std_msgs::msg::ColorRGBA getColor(const ColorName & color_name, const float alpha = 0.99f);

private:
rclcpp::Publisher<visualization_msgs::msg::MarkerArray>::SharedPtr pub_marker_;

double height_offset_{0.5};
std::vector<ObjectMarkerData> obj_marker_data_array_;

std::string name_;
std::string topic_namespace_ = "/planning/debug/objects_of_interest";
};

} // namespace objects_of_interest_marker_interface

#endif // OBJECTS_OF_INTEREST_MARKER_INTERFACE__OBJECTS_OF_INTEREST_MARKER_INTERFACE_HPP_
Loading

0 comments on commit 97b59d9

Please sign in to comment.