Skip to content

Commit

Permalink
Add support to repeat broadcasting commands (IMRCLab#109)
Browse files Browse the repository at this point in the history
Fixes issue IMRCLab#105
  • Loading branch information
whoenig authored Nov 14, 2022
1 parent 7c46d69 commit b043205
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 22 deletions.
3 changes: 3 additions & 0 deletions crazyflie/config/crazyflies.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -101,3 +101,6 @@ all:
extQuatStdDev: 0.5e-1
# kalman:
# resetEstimation: 1
broadcasts:
num_repeats: 15 # number of times broadcast commands are repeated
delay_between_repeats_ms: 1 # delay in milliseconds between individual repeats
68 changes: 46 additions & 22 deletions crazyflie/src/crazyflie_server.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -475,6 +475,13 @@ class CrazyflieServer : public rclcpp::Node
service_land_ = this->create_service<Land>("all/land", std::bind(&CrazyflieServer::land, this, _1, _2));
service_go_to_ = this->create_service<GoTo>("all/go_to", std::bind(&CrazyflieServer::go_to, this, _1, _2));

// declare global commands
this->declare_parameter("all/broadcasts/num_repeats", 15);
this->declare_parameter("all/broadcasts/delay_between_repeats_ms", 1);

broadcasts_num_repeats_ = this->get_parameter("all/broadcasts/num_repeats").get_parameter_value().get<int>();
broadcasts_delay_between_repeats_ms_ = this->get_parameter("all/broadcasts/delay_between_repeats_ms").get_parameter_value().get<int>();

// load crazyflies from params
auto node_parameters_iface = this->get_node_parameters_interface();
const std::map<std::string, rclcpp::ParameterValue> &parameter_overrides =
Expand Down Expand Up @@ -514,10 +521,13 @@ class CrazyflieServer : public rclcpp::Node
std::shared_ptr<Empty::Response> response)
{
RCLCPP_INFO(logger_, "emergency()");
for (auto &bc : broadcaster_)
for (int i = 0; i < broadcasts_num_repeats_; ++i)
{
auto &cfbc = bc.second;
cfbc->emergencyStop();
for (auto &bc : broadcaster_) {
auto &cfbc = bc.second;
cfbc->emergencyStop();
}
std::this_thread::sleep_for(std::chrono::milliseconds(broadcasts_delay_between_repeats_ms_));
}
}

Expand All @@ -529,13 +539,15 @@ class CrazyflieServer : public rclcpp::Node
request->timescale,
request->reversed,
request->group_mask);
for (auto &bc : broadcaster_)
{
auto &cfbc = bc.second;
cfbc->startTrajectory(request->trajectory_id,
request->timescale,
request->reversed,
request->group_mask);
for (int i = 0; i < broadcasts_num_repeats_; ++i) {
for (auto &bc : broadcaster_) {
auto &cfbc = bc.second;
cfbc->startTrajectory(request->trajectory_id,
request->timescale,
request->reversed,
request->group_mask);
}
std::this_thread::sleep_for(std::chrono::milliseconds(broadcasts_delay_between_repeats_ms_));
}
}

Expand All @@ -546,9 +558,12 @@ class CrazyflieServer : public rclcpp::Node
request->height,
rclcpp::Duration(request->duration).seconds(),
request->group_mask);
for (auto& bc : broadcaster_) {
auto& cfbc = bc.second;
cfbc->takeoff(request->height, rclcpp::Duration(request->duration).seconds(), request->group_mask);
for (int i = 0; i < broadcasts_num_repeats_; ++i) {
for (auto& bc : broadcaster_) {
auto& cfbc = bc.second;
cfbc->takeoff(request->height, rclcpp::Duration(request->duration).seconds(), request->group_mask);
}
std::this_thread::sleep_for(std::chrono::milliseconds(broadcasts_delay_between_repeats_ms_));
}
}

Expand All @@ -559,9 +574,12 @@ class CrazyflieServer : public rclcpp::Node
request->height,
rclcpp::Duration(request->duration).seconds(),
request->group_mask);
for (auto& bc : broadcaster_) {
auto& cfbc = bc.second;
cfbc->land(request->height, rclcpp::Duration(request->duration).seconds(), request->group_mask);
for (int i = 0; i < broadcasts_num_repeats_; ++i) {
for (auto& bc : broadcaster_) {
auto& cfbc = bc.second;
cfbc->land(request->height, rclcpp::Duration(request->duration).seconds(), request->group_mask);
}
std::this_thread::sleep_for(std::chrono::milliseconds(broadcasts_delay_between_repeats_ms_));
}
}

Expand All @@ -572,12 +590,14 @@ class CrazyflieServer : public rclcpp::Node
request->goal.x, request->goal.y, request->goal.z, request->yaw,
rclcpp::Duration(request->duration).seconds(),
request->group_mask);
for (auto &bc : broadcaster_)
{
auto &cfbc = bc.second;
cfbc->goTo(request->goal.x, request->goal.y, request->goal.z, request->yaw,
rclcpp::Duration(request->duration).seconds(),
request->group_mask);
for (int i = 0; i < broadcasts_num_repeats_; ++i) {
for (auto &bc : broadcaster_) {
auto &cfbc = bc.second;
cfbc->goTo(request->goal.x, request->goal.y, request->goal.z, request->yaw,
rclcpp::Duration(request->duration).seconds(),
request->group_mask);
}
std::this_thread::sleep_for(std::chrono::milliseconds(broadcasts_delay_between_repeats_ms_));
}
}

Expand Down Expand Up @@ -640,6 +660,10 @@ class CrazyflieServer : public rclcpp::Node

// maps CF name -> CF id
std::map<std::string, uint8_t> name_to_id_;

// global params
int broadcasts_num_repeats_;
int broadcasts_delay_between_repeats_ms_;
};

int main(int argc, char *argv[])
Expand Down

0 comments on commit b043205

Please sign in to comment.