Carma-platform v4.2.0
CARMA Platform is built on robot operating system (ROS) and utilizes open source software (OSS) that enables Cooperative Driving Automation (CDA) features to allow Automated Driving Systems to interact and cooperate with infrastructure and other vehicles through communication.
light_controlled_intersection_tactical_plugin_node.cpp
Go to the documentation of this file.
1/*
2 * Copyright (C) 2022 LEIDOS.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License"); you may not
5 * use this file except in compliance with the License. You may obtain a copy of
6 * the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13 * License for the specific language governing permissions and limitations under
14 * the License.
15 */
17
19{
20 namespace std_ph = std::placeholders;
21
23 : carma_guidance_plugins::TacticalPlugin(options)
24 {
25 // Create initial config
26 config_ = Config();
27
28 // Declare parameters
29 config_.centerline_sampling_spacing = declare_parameter<double>("centerline_sampling_spacing", config_.centerline_sampling_spacing);
30 config_.trajectory_time_length = declare_parameter<double>("trajectory_time_length", config_.trajectory_time_length);
31 config_.default_downsample_ratio = declare_parameter<int>("default_downsample_ratio", config_.default_downsample_ratio);
32 config_.turn_downsample_ratio = declare_parameter<int>("turn_downsample_ratio", config_.turn_downsample_ratio);
33 config_.curve_resample_step_size = declare_parameter<double>("curve_resample_step_size", config_.curve_resample_step_size);
34 config_.curvature_moving_average_window_size = declare_parameter<int>("curvature_moving_average_window_size", config_.curvature_moving_average_window_size);
35 config_.speed_moving_average_window_size = declare_parameter<int>("speed_moving_average_window_size", config_.speed_moving_average_window_size);
36 config_.back_distance = declare_parameter<double>("back_distance", config_.back_distance);
37 config_.buffer_ending_downtrack = declare_parameter<double>("buffer_ending_downtrack", config_.buffer_ending_downtrack);
38 config_.vehicle_decel_limit_multiplier = declare_parameter<double>("vehicle_decel_limit_multiplier", config_.vehicle_decel_limit_multiplier);
39 config_.vehicle_accel_limit_multiplier = declare_parameter<double>("vehicle_accel_limit_multiplier", config_.vehicle_accel_limit_multiplier);
40 config_.lat_accel_multiplier = declare_parameter<double>("lat_accel_multiplier", config_.lat_accel_multiplier);
41 config_.stop_line_buffer = declare_parameter<double>("stop_line_buffer", config_.stop_line_buffer);
42 config_.minimum_speed = declare_parameter<double>("minimum_speed", config_.minimum_speed);
43 config_.algorithm_evaluation_distance = declare_parameter<double>("algorithm_evaluation_distance", config_.algorithm_evaluation_distance);
44 config_.algorithm_evaluation_period = declare_parameter<double>("algorithm_evaluation_period", config_.algorithm_evaluation_period);
45
46 config_.lateral_accel_limit = declare_parameter<double>("vehicle_lateral_accel_limit", config_.lateral_accel_limit);
47 config_.vehicle_accel_limit = declare_parameter<double>("vehicle_acceleration_limit", config_.vehicle_accel_limit);
48 config_.vehicle_decel_limit = declare_parameter<double>("vehicle_deceleration_limit", config_.vehicle_decel_limit);
49 config_.tactical_plugin_service_call_timeout = declare_parameter<int>("tactical_plugin_service_call_timeout", config_.tactical_plugin_service_call_timeout);
50 config_.enable_object_avoidance = declare_parameter<bool>("enable_object_avoidance", config_.enable_object_avoidance);
51
52 }
53
54 rcl_interfaces::msg::SetParametersResult LightControlledIntersectionTransitPluginNode::parameter_update_callback(const std::vector<rclcpp::Parameter> &parameters)
55 {
56 auto error = update_params<double>(
57 {{"centerline_sampling_spacing", config_.centerline_sampling_spacing},
58 {"trajectory_time_length", config_.trajectory_time_length},
59 {"curve_resample_step_size", config_.curve_resample_step_size},
60 {"back_distance", config_.back_distance},
61 {"buffer_ending_downtrack", config_.buffer_ending_downtrack},
62 {"vehicle_decel_limit_multiplier", config_.vehicle_decel_limit_multiplier},
63 {"vehicle_accel_limit_multiplier", config_.vehicle_accel_limit_multiplier},
64 {"lat_accel_multiplier", config_.lat_accel_multiplier},
65 {"stop_line_buffer", config_.stop_line_buffer},
66 {"minimum_speed", config_.minimum_speed},
67 {"algorithm_evaluation_distance", config_.algorithm_evaluation_distance},
68 {"algorithm_evaluation_period", config_.algorithm_evaluation_period}}, parameters); // Global acceleration limits not allowed to dynamically update
69 auto error_2 = update_params<int>(
70 {{"default_downsample_ratio", config_.default_downsample_ratio},
71 {"turn_downsample_ratio", config_.turn_downsample_ratio},
72 {"curvature_moving_average_window_size", config_.curvature_moving_average_window_size},
73 {"speed_moving_average_window_size", config_.speed_moving_average_window_size}}, parameters);
74
75 if (worker_)
76 {
77 worker_->setConfig(config_);
78 }
79
80 rcl_interfaces::msg::SetParametersResult result;
81
82 result.successful = !error && !error_2;
83
84 return result;
85 }
86
88 {
89 RCLCPP_INFO_STREAM(rclcpp::get_logger("light_controlled_intersection_tactical_plugin"), "LightControlledIntersectionTransitPluginNode trying to configure");
90
91 // Reset config
92 config_ = Config();
93
94 // Load parameters
95 get_parameter<double>("centerline_sampling_spacing", config_.centerline_sampling_spacing);
96 get_parameter<double>("trajectory_time_length", config_.trajectory_time_length);
97 get_parameter<int>("default_downsample_ratio", config_.default_downsample_ratio);
98 get_parameter<int>("turn_downsample_ratio", config_.turn_downsample_ratio);
99 get_parameter<double>("curve_resample_step_size", config_.curve_resample_step_size);
100 get_parameter<int>("curvature_moving_average_window_size", config_.curvature_moving_average_window_size);
101 get_parameter<int>("speed_moving_average_window_size", config_.speed_moving_average_window_size);
102 get_parameter<double>("back_distance", config_.back_distance);
103 get_parameter<double>("buffer_ending_downtrack", config_.buffer_ending_downtrack);
104 get_parameter<double>("vehicle_decel_limit_multiplier", config_.vehicle_decel_limit_multiplier);
105 get_parameter<double>("vehicle_accel_limit_multiplier", config_.vehicle_accel_limit_multiplier);
106 get_parameter<double>("lat_accel_multiplier", config_.lat_accel_multiplier);
107 get_parameter<double>("stop_line_buffer", config_.stop_line_buffer);
108 get_parameter<double>("minimum_speed", config_.minimum_speed);
109 get_parameter<double>("algorithm_evaluation_distance", config_.algorithm_evaluation_distance);
110 get_parameter<double>("algorithm_evaluation_period", config_.algorithm_evaluation_period);
111 get_parameter<double>("vehicle_lateral_accel_limit", config_.lateral_accel_limit);
112 get_parameter<double>("vehicle_acceleration_limit", config_.vehicle_accel_limit);
113 get_parameter<double>("vehicle_deceleration_limit", config_.vehicle_decel_limit);
114 get_parameter<int>("tactical_plugin_service_call_timeout", config_.tactical_plugin_service_call_timeout);
115 get_parameter<bool>("enable_object_avoidance", config_.enable_object_avoidance);
116
117 // Use the configured multipliers to update the accel limits
121
122 // Register runtime parameter update callback
123 add_on_set_parameters_callback(std::bind(&LightControlledIntersectionTransitPluginNode::parameter_update_callback, this, std_ph::_1));
124
125 RCLCPP_INFO_STREAM(rclcpp::get_logger("light_controlled_intersection_tactical_plugin"), "Loaded params: " << config_);
126
127 // Initialize worker object
128 worker_ = std::make_shared<LightControlledIntersectionTacticalPlugin>(get_world_model(), config_, get_plugin_name(), shared_from_this());
129
130 yield_client_ = create_client<carma_planning_msgs::srv::PlanTrajectory>("yield_plugin/plan_trajectory");
131 worker_->set_yield_client(yield_client_);
132 RCLCPP_INFO(rclcpp::get_logger("light_controlled_intersection_tactical_plugin"), "Yield Client Set");
133
134 // Return success if everything initialized successfully
135 return CallbackReturn::SUCCESS;
136 }
137
139 return true;
140 }
141
143 return "v4.0"; // Version ID matches the value set in this package's package.xml
144 }
145
147 std::shared_ptr<rmw_request_id_t>,
148 carma_planning_msgs::srv::PlanTrajectory::Request::SharedPtr req,
149 carma_planning_msgs::srv::PlanTrajectory::Response::SharedPtr resp)
150 {
151 worker_->planTrajectoryCB(req, resp);
152 }
153
154} // light_controlled_intersection_tactical_plugin
155
156#include "rclcpp_components/register_node_macro.hpp"
157
158// Register the component with class_loader
std::string get_plugin_name() const
Return the name of this plugin.
virtual carma_wm::WorldModelConstPtr get_world_model() final
Method to return the default world model provided as a convience by this base class If this method or...
LightControlledIntersectionTransitPluginNode(const rclcpp::NodeOptions &)
LightControlledIntersectionTransitPluginNode constructor.
rcl_interfaces::msg::SetParametersResult parameter_update_callback(const std::vector< rclcpp::Parameter > &parameters)
Callback for dynamic parameter updates.
bool get_availability() override
Get the availability status of this plugin based on the current operating environment....
void plan_trajectory_callback(std::shared_ptr< rmw_request_id_t >, carma_planning_msgs::srv::PlanTrajectory::Request::SharedPtr req, carma_planning_msgs::srv::PlanTrajectory::Response::SharedPtr resp) override
Extending class provided callback which should return a planned trajectory based on the provided traj...
carma_ros2_utils::CallbackReturn on_configure_plugin() override
This method should be used to load parameters and will be called on the configure state transition.
Stuct containing the algorithm configuration values for light_controlled_intersection_tactical_plugin...