From 9ce56ba5b0a87ac072096c15e439e80c847b6de8 Mon Sep 17 00:00:00 2001 From: Autumn60 Date: Thu, 6 Jun 2024 17:15:08 +0900 Subject: [PATCH 1/3] refactor mrm_emergency_stop_operator Signed-off-by: Autumn60 --- .../mrm_emergency_stop_operator_core.hpp | 12 +++-- .../mrm_emergency_stop_operator_core.cpp | 49 +++++++------------ 2 files changed, 25 insertions(+), 36 deletions(-) diff --git a/system/mrm_emergency_stop_operator/include/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.hpp b/system/mrm_emergency_stop_operator/include/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.hpp index d7995a51ac8fb..3cd91d62aba94 100644 --- a/system/mrm_emergency_stop_operator/include/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.hpp +++ b/system/mrm_emergency_stop_operator/include/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.hpp @@ -20,6 +20,8 @@ #include // Autoware +#include + #include #include #include @@ -54,10 +56,11 @@ class MrmEmergencyStopOperator : public rclcpp::Node rcl_interfaces::msg::SetParametersResult onParameter( const std::vector & parameters); - // Subscriber - rclcpp::Subscription::SharedPtr sub_control_cmd_; + // Subscriber without callback + tier4_autoware_utils::InterProcessPollingSubscriber sub_control_cmd_{ + this, "~/input/control/control_cmd"}; - void onControlCommand(Control::ConstSharedPtr msg); + Control subscribeControlCommand(); // Server rclcpp::Service::SharedPtr service_operation_; @@ -80,10 +83,9 @@ class MrmEmergencyStopOperator : public rclcpp::Node // States MrmBehaviorStatus status_; Control prev_control_cmd_; - bool is_prev_control_cmd_subscribed_; // Algorithm - Control calcTargetAcceleration(const Control & prev_control_cmd) const; + Control compensateControlCommand(const Control & prev_control_cmd) const; }; } // namespace mrm_emergency_stop_operator diff --git a/system/mrm_emergency_stop_operator/src/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.cpp b/system/mrm_emergency_stop_operator/src/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.cpp index 589a2fd14d990..1dead64c568e1 100644 --- a/system/mrm_emergency_stop_operator/src/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.cpp +++ b/system/mrm_emergency_stop_operator/src/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.cpp @@ -27,11 +27,6 @@ MrmEmergencyStopOperator::MrmEmergencyStopOperator(const rclcpp::NodeOptions & n params_.target_acceleration = declare_parameter("target_acceleration", -2.5); params_.target_jerk = declare_parameter("target_jerk", -1.5); - // Subscriber - sub_control_cmd_ = create_subscription( - "~/input/control/control_cmd", 1, - std::bind(&MrmEmergencyStopOperator::onControlCommand, this, std::placeholders::_1)); - // Server service_operation_ = create_service( "~/input/mrm/emergency_stop/operate", std::bind( @@ -49,7 +44,6 @@ MrmEmergencyStopOperator::MrmEmergencyStopOperator(const rclcpp::NodeOptions & n // Initialize status_.state = MrmBehaviorStatus::AVAILABLE; - is_prev_control_cmd_subscribed_ = false; // Parameter Callback set_param_res_ = add_on_set_parameters_callback( @@ -69,12 +63,19 @@ rcl_interfaces::msg::SetParametersResult MrmEmergencyStopOperator::onParameter( return result; } -void MrmEmergencyStopOperator::onControlCommand(Control::ConstSharedPtr msg) +Control MrmEmergencyStopOperator::subscribeControlCommand() { - if (status_.state != MrmBehaviorStatus::OPERATING) { - prev_control_cmd_ = *msg; - is_prev_control_cmd_subscribed_ = true; + auto control_cmd = sub_control_cmd_.takeData(); + if (control_cmd == nullptr) { + auto stop_cmd = Control(); + stop_cmd.stamp = this->now(); + stop_cmd.longitudinal.stamp = this->now(); + stop_cmd.longitudinal.velocity = 0.0; + stop_cmd.longitudinal.acceleration = 0.0; + stop_cmd.longitudinal.jerk = 0.0; + return stop_cmd; } + return *control_cmd; } void MrmEmergencyStopOperator::operateEmergencyStop( @@ -103,32 +104,19 @@ void MrmEmergencyStopOperator::publishControlCommand(const Control & command) co void MrmEmergencyStopOperator::onTimer() { - if (status_.state == MrmBehaviorStatus::OPERATING) { - auto control_cmd = calcTargetAcceleration(prev_control_cmd_); - publishControlCommand(control_cmd); - prev_control_cmd_ = control_cmd; - } else { - publishControlCommand(prev_control_cmd_); - } + auto control_cmd = status_.state == MrmBehaviorStatus::OPERATING + ? compensateControlCommand(prev_control_cmd_) + : subscribeControlCommand(); + publishControlCommand(control_cmd); + prev_control_cmd_ = control_cmd; + publishStatus(); } -Control MrmEmergencyStopOperator::calcTargetAcceleration(const Control & prev_control_cmd) const +Control MrmEmergencyStopOperator::compensateControlCommand(const Control & prev_control_cmd) const { auto control_cmd = Control(); - if (!is_prev_control_cmd_subscribed_) { - control_cmd.stamp = this->now(); - control_cmd.longitudinal.stamp = this->now(); - control_cmd.longitudinal.velocity = 0.0; - control_cmd.longitudinal.acceleration = static_cast(params_.target_acceleration); - control_cmd.longitudinal.jerk = 0.0; - control_cmd.lateral.stamp = this->now(); - control_cmd.lateral.steering_tire_angle = 0.0; - control_cmd.lateral.steering_tire_rotation_rate = 0.0; - return control_cmd; - } - control_cmd = prev_control_cmd; const auto dt = (this->now() - prev_control_cmd.stamp).seconds(); @@ -147,7 +135,6 @@ Control MrmEmergencyStopOperator::calcTargetAcceleration(const Control & prev_co return control_cmd; } - } // namespace mrm_emergency_stop_operator #include From 6d96bb9a10a22a80ea39d7acf71e27613784b22e Mon Sep 17 00:00:00 2001 From: Autumn60 Date: Thu, 6 Jun 2024 17:22:13 +0900 Subject: [PATCH 2/3] remove redundant initialization Signed-off-by: Autumn60 --- .../mrm_emergency_stop_operator_core.cpp | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/system/mrm_emergency_stop_operator/src/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.cpp b/system/mrm_emergency_stop_operator/src/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.cpp index 1dead64c568e1..7914428900a61 100644 --- a/system/mrm_emergency_stop_operator/src/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.cpp +++ b/system/mrm_emergency_stop_operator/src/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.cpp @@ -115,9 +115,7 @@ void MrmEmergencyStopOperator::onTimer() Control MrmEmergencyStopOperator::compensateControlCommand(const Control & prev_control_cmd) const { - auto control_cmd = Control(); - - control_cmd = prev_control_cmd; + auto control_cmd = prev_control_cmd; const auto dt = (this->now() - prev_control_cmd.stamp).seconds(); control_cmd.stamp = this->now(); From 2b257e27fe3b6c3ad7a917cb5ec2d4630677db69 Mon Sep 17 00:00:00 2001 From: Autumn60 Date: Thu, 20 Jun 2024 13:44:18 +0900 Subject: [PATCH 3/3] fix include path and namespace Signed-off-by: Autumn60 --- .../mrm_emergency_stop_operator_core.hpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/system/mrm_emergency_stop_operator/include/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.hpp b/system/mrm_emergency_stop_operator/include/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.hpp index 3cd91d62aba94..a19b611b233aa 100644 --- a/system/mrm_emergency_stop_operator/include/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.hpp +++ b/system/mrm_emergency_stop_operator/include/mrm_emergency_stop_operator/mrm_emergency_stop_operator_core.hpp @@ -20,7 +20,7 @@ #include // Autoware -#include +#include #include #include @@ -57,7 +57,7 @@ class MrmEmergencyStopOperator : public rclcpp::Node const std::vector & parameters); // Subscriber without callback - tier4_autoware_utils::InterProcessPollingSubscriber sub_control_cmd_{ + autoware::universe_utils::InterProcessPollingSubscriber sub_control_cmd_{ this, "~/input/control/control_cmd"}; Control subscribeControlCommand();