From 8704ccb8bd09bd74c680fd3d1f580549fd4a71ac Mon Sep 17 00:00:00 2001 From: Tomas Baca Date: Wed, 14 Feb 2024 11:38:35 +0100 Subject: [PATCH] fixed trajectory tracking for vel and pos modality --- src/mpc_tracker/mpc_tracker.cpp | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/src/mpc_tracker/mpc_tracker.cpp b/src/mpc_tracker/mpc_tracker.cpp index 662367e..2a2b1ec 100644 --- a/src/mpc_tracker/mpc_tracker.cpp +++ b/src/mpc_tracker/mpc_tracker.cpp @@ -312,6 +312,7 @@ class MpcTracker : public mrs_uav_managers::Tracker { ros::Timer timer_mpc_iteration_; std::atomic mpc_synchronous_ = false; + ros::TimerEvent synchronous_timer_event_; std::atomic mpc_timer_running_ = false; void timerMPC(const ros::TimerEvent& event); @@ -1001,11 +1002,20 @@ std::optional MpcTracker::update(const mrs_msgs::UavSt return {tracker_cmd}; } - ros::TimerEvent event; - if (mpc_synchronous_) { + ROS_DEBUG_THROTTLE(1.0, "[MpcTracker]: running in SYNCHRONOUS mode"); - timerMPC(event); + + if (synchronous_timer_event_.last_real.toSec() > 0) { + synchronous_timer_event_.last_real = synchronous_timer_event_.current_real; + } else { + synchronous_timer_event_.last_real = ros::Time::now(); + } + + synchronous_timer_event_.current_real = ros::Time::now(); + + timerMPC(synchronous_timer_event_); + } else { ROS_DEBUG_THROTTLE(1.0, "[MpcTracker]: running in ASYNCHRONOUS mode"); }