Skip to content

Commit

Permalink
fix(system_error_monitor): hold emergency when timeout happens (autow…
Browse files Browse the repository at this point in the history
…arefoundation#2634) (#240)

* fix(system_error_monitor): hold emergency when timeout

* fix: initialize other fault
  • Loading branch information
h-ohta authored Jan 13, 2023
1 parent a816652 commit cba06ae
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 16 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -141,6 +141,7 @@ class AutowareErrorMonitor : public rclcpp::Node
autoware_auto_system_msgs::msg::HazardStatus * hazard_status) const;
autoware_auto_system_msgs::msg::HazardStatus judgeHazardStatus() const;
void updateHazardStatus();
void updateTimeoutHazardStatus();
bool canAutoRecovery() const;
bool isEmergencyHoldingRequired() const;
};
Expand Down
49 changes: 33 additions & 16 deletions system/system_error_monitor/src/system_error_monitor_core.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -182,20 +182,6 @@ std::set<std::string> getErrorModules(
return error_modules;
}

autoware_auto_system_msgs::msg::HazardStatus createTimeoutHazardStatus()
{
autoware_auto_system_msgs::msg::HazardStatus hazard_status;
hazard_status.level = autoware_auto_system_msgs::msg::HazardStatus::SINGLE_POINT_FAULT;
hazard_status.emergency = true;
hazard_status.emergency_holding = false;
diagnostic_msgs::msg::DiagnosticStatus diag;
diag.name = "system_error_monitor/input_data_timeout";
diag.hardware_id = "system_error_monitor";
diag.level = diagnostic_msgs::msg::DiagnosticStatus::ERROR;
hazard_status.diag_single_point_fault.push_back(diag);
return hazard_status;
}

int isInNoFaultCondition(
const autoware_auto_system_msgs::msg::AutowareState & autoware_state,
const tier4_control_msgs::msg::GateMode & current_gate_mode)
Expand Down Expand Up @@ -459,13 +445,15 @@ void AutowareErrorMonitor::onTimer()
RCLCPP_WARN_THROTTLE(
get_logger(), *get_clock(), std::chrono::milliseconds(1000).count(),
"input data is timeout");
publishHazardStatus(createTimeoutHazardStatus());
updateTimeoutHazardStatus();
publishHazardStatus(hazard_status_);
}
return;
}

if (isDataHeartbeatTimeout()) {
publishHazardStatus(createTimeoutHazardStatus());
updateTimeoutHazardStatus();
publishHazardStatus(hazard_status_);
return;
}

Expand Down Expand Up @@ -610,6 +598,35 @@ void AutowareErrorMonitor::updateHazardStatus()
}
}

void AutowareErrorMonitor::updateTimeoutHazardStatus()
{
const bool prev_emergency_status = hazard_status_.emergency;

hazard_status_.level = autoware_auto_system_msgs::msg::HazardStatus::SINGLE_POINT_FAULT;
hazard_status_.emergency = true;

if (hazard_status_.emergency != prev_emergency_status) {
emergency_state_switch_time_ = this->now();
}

hazard_status_.diag_no_fault = std::vector<diagnostic_msgs::msg::DiagnosticStatus>();
hazard_status_.diag_safe_fault = std::vector<diagnostic_msgs::msg::DiagnosticStatus>();
hazard_status_.diag_latent_fault = std::vector<diagnostic_msgs::msg::DiagnosticStatus>();

diagnostic_msgs::msg::DiagnosticStatus diag;
diag.name = "system_error_monitor/input_data_timeout";
diag.hardware_id = "system_error_monitor";
diag.level = diagnostic_msgs::msg::DiagnosticStatus::ERROR;
hazard_status_.diag_single_point_fault =
std::vector<diagnostic_msgs::msg::DiagnosticStatus>{diag};

// Update emergency_holding condition
if (params_.use_emergency_hold) {
const auto emergency_duration = (this->now() - emergency_state_switch_time_).seconds();
hazard_status_.emergency_holding = emergency_duration > params_.hazard_recovery_timeout;
}
}

bool AutowareErrorMonitor::canAutoRecovery() const
{
const auto error_modules = getErrorModules(hazard_status_, params_.emergency_hazard_level);
Expand Down

0 comments on commit cba06ae

Please sign in to comment.