Skip to content

Commit

Permalink
Modified dummy infrastructure for multiple commands
Browse files Browse the repository at this point in the history
Signed-off-by: Yohei MISHINA <[email protected]>
  • Loading branch information
YoheiMishina authored and Haruki-Ohga committed Oct 24, 2024
1 parent 80c97f8 commit 03e9b3b
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 26 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
ros__parameters:
update_rate_hz: 10.0
use_first_command: false
use_instrument_id: false
use_command_state: true
instrument_id: '0'
approval: true
is_finalized: true
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ class DummyInfrastructureNode : public rclcpp::Node
{
double update_rate_hz{};
bool use_first_command{};
bool use_instrument_id{};
bool use_command_state{};
std::string instrument_id{};
bool approval{};
bool is_finalized{};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -47,29 +47,37 @@ bool update_param(
return true;
}

boost::optional<InfrastructureCommand> findCommand(
boost::optional<InfrastructureCommandArray> findCommand(
const InfrastructureCommandArray & command_array, const std::string & instrument_id,
const bool use_first_command, const bool use_instrument_id)
const bool use_first_command, const bool use_command_state)
{
InfrastructureCommandArray array;
bool found_flag = false;
if (use_first_command && !command_array.commands.empty()) {
return command_array.commands.front();
array.commands.push_back(command_array.commands.front());
return array;
}

if (use_instrument_id) {
if (use_command_state) {
for (const auto & command : command_array.commands) {
if (command.id == instrument_id) {
return command;
if (command.state >= 1) {
array.commands.push_back(command);
found_flag = true;
}
}
}

for (const auto & command : command_array.commands) {
if (command.state >= 1) {
return command;
if (command.id == instrument_id) {
array.commands.push_back(command);
found_flag = true;
}
}

return {};
if (found_flag) {
return array;
} else {
return {};
}
}
} // namespace

Expand All @@ -83,7 +91,7 @@ DummyInfrastructureNode::DummyInfrastructureNode(const rclcpp::NodeOptions & nod
// Parameter
node_param_.update_rate_hz = declare_parameter<double>("update_rate_hz", 10.0);
node_param_.use_first_command = declare_parameter<bool>("use_first_command", true);
node_param_.use_instrument_id = declare_parameter<bool>("use_instrument_id", false);
node_param_.use_command_state = declare_parameter<bool>("use_command_state", false);
node_param_.instrument_id = declare_parameter<std::string>("instrument_id", "");
node_param_.approval = declare_parameter<bool>("approval", false);
node_param_.is_finalized = declare_parameter<bool>("is_finalized", false);
Expand Down Expand Up @@ -121,7 +129,7 @@ rcl_interfaces::msg::SetParametersResult DummyInfrastructureNode::onSetParam(
// Update params
update_param(params, "update_rate_hz", p.update_rate_hz);
update_param(params, "use_first_command", p.use_first_command);
update_param(params, "use_instrument_id", p.use_instrument_id);
update_param(params, "use_command_state", p.use_command_state);
update_param(params, "instrument_id", p.instrument_id);
update_param(params, "approval", p.approval);
update_param(params, "is_finalized", p.is_finalized);
Expand Down Expand Up @@ -154,21 +162,33 @@ void DummyInfrastructureNode::onTimer()
if (!isDataReady()) {
return;
}
VirtualTrafficLightStateArray state_array;
state_array.stamp = get_clock()->now();

const auto command = findCommand(
const auto found_command_array = findCommand(
*command_array_, node_param_.instrument_id, node_param_.use_first_command,
node_param_.use_instrument_id);

VirtualTrafficLightState state;
state.stamp = get_clock()->now();
state.id = command ? command->id : node_param_.instrument_id;
state.type = command ? command->type : "dummy_infrastructure";
state.approval = command ? node_param_.approval : false;
state.is_finalized = node_param_.is_finalized;
node_param_.use_command_state);

if (!found_command_array) {
VirtualTrafficLightState state;
state.stamp = get_clock()->now();
state.id = node_param_.instrument_id;
state.type = "dummy_infrastructure";
state.approval = false;
state.is_finalized = node_param_.is_finalized;
state_array.states.push_back(state);
} else {
for (auto command : found_command_array->commands) {
VirtualTrafficLightState state;
state.stamp = get_clock()->now();
state.id = command.id;
state.type = command.type;
state.approval = node_param_.approval;
state.is_finalized = node_param_.is_finalized;
state_array.states.push_back(state);
}
}

VirtualTrafficLightStateArray state_array;
state_array.stamp = get_clock()->now();
state_array.states.push_back(state);
pub_state_array_->publish(state_array);
}

Expand Down

0 comments on commit 03e9b3b

Please sign in to comment.