Skip to content

Commit

Permalink
fix(scenario_selector): timing of handling route (#1546)
Browse files Browse the repository at this point in the history
* fix(scenario_selector): timing of handling route

Signed-off-by: Shumpei Wakabayashi <shumpei.wakabayashi@tier4.jp>

* feat: add isDataReady

Signed-off-by: Shumpei Wakabayashi <shumpei.wakabayashi@tier4.jp>
  • Loading branch information
shmpwk authored Aug 10, 2022
1 parent 564dbb3 commit e4e5b48
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 4 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,7 @@ class ScenarioSelectorNode : public rclcpp::Node
void onOdom(const nav_msgs::msg::Odometry::ConstSharedPtr msg);
void onParkingState(const std_msgs::msg::Bool::ConstSharedPtr msg);

bool isDataReady();
void onTimer();
void onLaneDrivingTrajectory(
const autoware_auto_planning_msgs::msg::Trajectory::ConstSharedPtr msg);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -219,8 +219,6 @@ void ScenarioSelectorNode::onMap(
void ScenarioSelectorNode::onRoute(
const autoware_auto_planning_msgs::msg::HADMapRoute::ConstSharedPtr msg)
{
route_handler_->setRoute(*msg);
if (!route_handler_->isHandlerReady()) return;
route_ = msg;
current_scenario_ = tier4_planning_msgs::msg::Scenario::EMPTY;
}
Expand Down Expand Up @@ -252,12 +250,44 @@ void ScenarioSelectorNode::onParkingState(const std_msgs::msg::Bool::ConstShared
is_parking_completed_ = msg->data;
}

bool ScenarioSelectorNode::isDataReady()
{
if (!current_pose_) {
RCLCPP_INFO_THROTTLE(this->get_logger(), *this->get_clock(), 5000, "Waiting for current pose.");
return false;
}

if (!lanelet_map_ptr_) {
RCLCPP_INFO_THROTTLE(this->get_logger(), *this->get_clock(), 5000, "Waiting for lanelet map.");
return false;
}

if (!route_) {
RCLCPP_INFO_THROTTLE(this->get_logger(), *this->get_clock(), 5000, "Waiting for route.");
return false;
}

if (!twist_) {
RCLCPP_INFO_THROTTLE(this->get_logger(), *this->get_clock(), 5000, "Waiting for twist.");
return false;
}

// Check route handler is ready
route_handler_->setRoute(*route_);
if (!route_handler_->isHandlerReady()) {
RCLCPP_WARN_THROTTLE(
this->get_logger(), *this->get_clock(), 5000, "Waiting for route handler.");
return false;
}

return true;
}

void ScenarioSelectorNode::onTimer()
{
current_pose_ = getCurrentPose(tf_buffer_, this->get_logger());

// Check all inputs are ready
if (!current_pose_ || !lanelet_map_ptr_ || !route_ || !twist_) {
if (!isDataReady()) {
return;
}

Expand Down

0 comments on commit e4e5b48

Please sign in to comment.