Skip to content

Commit

Permalink
feat(autonomous_emergency_braking): enable aeb with only one req path (
Browse files Browse the repository at this point in the history
…#8569)

* make it so AEB works with only one req path type (imu or MPC)

Signed-off-by: Daniel Sanchez <danielsanchezaran@gmail.com>

* fix missing mpc path return

Signed-off-by: Daniel Sanchez <danielsanchezaran@gmail.com>

* add check

Signed-off-by: Daniel Sanchez <danielsanchezaran@gmail.com>

* modify no path msg

Signed-off-by: Daniel Sanchez <danielsanchezaran@gmail.com>

---------

Signed-off-by: Daniel Sanchez <danielsanchezaran@gmail.com>
  • Loading branch information
danielsanchezaran authored Aug 23, 2024
1 parent 53f7d82 commit d75f875
Showing 1 changed file with 19 additions and 10 deletions.
29 changes: 19 additions & 10 deletions control/autoware_autonomous_emergency_braking/src/node.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -348,21 +348,30 @@ bool AEB::fetchLatestData()
return missing("object detection method (pointcloud or predicted objects)");
}

const auto imu_ptr = sub_imu_.takeData();
if (use_imu_path_) {
const bool has_imu_path = std::invoke([&]() {
if (!use_imu_path_) return false;
const auto imu_ptr = sub_imu_.takeData();
if (!imu_ptr) {
return missing("imu message");
}
// imu_ptr is valid
onImu(imu_ptr);
}
if (use_imu_path_ && !angular_velocity_ptr_) {
return missing("imu");
}
return (!angular_velocity_ptr_) ? missing("imu") : true;
});

predicted_traj_ptr_ = sub_predicted_traj_.takeData();
if (use_predicted_trajectory_ && !predicted_traj_ptr_) {
return missing("control predicted trajectory");
const bool has_predicted_path = std::invoke([&]() {
if (!use_predicted_trajectory_) {
return false;
}
predicted_traj_ptr_ = sub_predicted_traj_.takeData();
return (!predicted_traj_ptr_) ? missing("control predicted trajectory") : true;
});

if (!has_imu_path && !has_predicted_path) {
RCLCPP_INFO_SKIPFIRST_THROTTLE(
get_logger(), *get_clock(), 5000,
"[AEB] At least one path (IMU or predicted trajectory) is required for operation");
return false;
}

autoware_state_ = sub_autoware_state_.takeData();
Expand Down Expand Up @@ -482,7 +491,7 @@ bool AEB::checkCollision(MarkerArray & debug_markers)

// step3. make function to check collision with ego path created with sensor data
const auto has_collision_ego = [&](pcl::PointCloud<pcl::PointXYZ>::Ptr filtered_objects) -> bool {
if (!use_imu_path_) return false;
if (!use_imu_path_ || !angular_velocity_ptr_) return false;
const double current_w = angular_velocity_ptr_->z;
constexpr colorTuple debug_color = {0.0 / 256.0, 148.0 / 256.0, 205.0 / 256.0, 0.999};
const std::string ns = "ego";
Expand Down

0 comments on commit d75f875

Please sign in to comment.