47 const MoveBaseFlexConfig& config)
49 , planner_(planner_ptr)
53 , has_new_start_(false)
54 , has_new_goal_(false)
68 const TFPtr& tf_listener_ptr,
const MoveBaseFlexConfig& config)
92 template <
typename _Iter>
100 if (std::distance(_begin, _end) < 2)
104 for (_Iter next = _begin + 1; next != _end; ++_begin, ++next)
128 catch (std::exception& ex)
138 boost::lock_guard<boost::mutex> guard(
state_mtx_);
144 boost::lock_guard<boost::mutex> guard(
state_mtx_);
158 boost::lock_guard<boost::mutex> guard(
plan_mtx_);
171 boost::lock_guard<boost::mutex> guard(
plan_mtx_);
195 const geometry_msgs::PoseStamped &goal,
208 const geometry_msgs::PoseStamped &goal,
221 const geometry_msgs::Point&
s = start.pose.position;
222 const geometry_msgs::Point& g = goal.pose.position;
224 ROS_DEBUG_STREAM(
"Start planning from the start pose: (" << s.x <<
", " << s.y <<
", " << s.z <<
")" 225 <<
" to the goal pose: ("<< g.x <<
", " << g.y <<
", " << g.z <<
")");
238 ROS_WARN_STREAM(
"Cancel planning failed or is not supported by the plugin. " 239 <<
"Wait until the current planning finished!");
247 const geometry_msgs::PoseStamped &goal,
249 std::vector<geometry_msgs::PoseStamped> &plan,
251 std::string &message)
253 return planner_->makePlan(start, goal, tolerance, plan, cost, message);
261 geometry_msgs::PoseStamped current_start =
start_;
262 geometry_msgs::PoseStamped current_goal =
goal_;
273 std::vector<geometry_msgs::PoseStamped> plan;
282 ROS_INFO_STREAM(
"A new start pose is available. Planning with the new start pose!");
283 const geometry_msgs::Point&
s =
start_.pose.position;
284 ROS_INFO_STREAM(
"New planning start pose: (" << s.x <<
", " << s.y <<
", " << s.z <<
")");
289 current_goal =
goal_;
291 ROS_INFO_STREAM(
"A new goal pose is available. Planning with the new goal pose and the tolerance: " 292 << current_tolerance);
293 const geometry_msgs::Point& g =
goal_.pose.position;
294 ROS_INFO_STREAM(
"New goal pose: (" << g.x <<
", " << g.y <<
", " << g.z <<
")");
322 boost::lock_guard<boost::mutex> plan_mtx_guard(
plan_mtx_);
344 << (
cancel_ ?
"; planner canceled!" :
""));
359 catch (
const boost::thread_interrupted &ex)
367 ROS_ERROR_STREAM(
"Unknown error occurred: " << boost::current_exception_diagnostic_information());
ros::Time last_valid_plan_time_
the last time a valid plan has been computed.
boost::condition_variable condition_
condition variable to wake up control thread
geometry_msgs::PoseStamped goal_
the current goal pose used for planning
void setState(PlanningState state, bool signalling)
Sets the internal state, thread communication safe.
bool has_new_start_
true, if a new start pose has been set, until it is used.
int max_retries_
planning max retries
virtual uint32_t makePlan(const geometry_msgs::PoseStamped &start, const geometry_msgs::PoseStamped &goal, double tolerance, std::vector< geometry_msgs::PoseStamped > &plan, double &cost, std::string &message)
calls the planner plugin to make a plan from the start pose to the goal pose with the given tolerance...
geometry_msgs::PoseStamped start_
the current start pose used for planning
The planner has been stopped.
double tolerance_
optional goal tolerance, in meters
std::string name_
the plugin name; not the plugin type!
No plan has been found (MAX_RETRIES and PAT_EXCEEDED are 0).
PlanningState state_
current internal state
ros::Time getLastValidPlanTime() const
Returns the last time a valid plan was available.
boost::mutex configuration_mutex_
dynamic reconfigure mutex for a thread safe communication
The planner has been canceled.
virtual void run()
The main run method, a thread will execute this method. It contains the main planner execution loop...
bool planning_
main cycle variable of the execution loop
bool cancel_
flag for canceling controlling
double getCost() const
Gets computed costs.
bool isPatienceExceeded() const
Checks whether the patience was exceeded.
std::string message_
the last received plugin execution message
std::vector< geometry_msgs::PoseStamped > getPlan() const
Returns a new plan, if one is available.
bool param(const std::string ¶m_name, T ¶m_val, const T &default_val) const
double cost_
current global plan cost
Exceeded the maximum number of retries without a valid command.
Base class for running concurrent navigation tasks.
ros::Time last_call_start_time_
the last call start time, updated each cycle.
An internal error occurred.
uint32_t outcome_
the last received plugin execution outcome
boost::mutex state_mtx_
mutex to handle safe thread communication for the current state
void setNewStart(const geometry_msgs::PoseStamped &start)
Sets a new start pose for the planner execution.
virtual bool cancel()
Cancel the planner execution. This calls the cancel method of the planner plugin. This could be usefu...
Exceeded the patience time without a valid command.
void setNewGoal(const geometry_msgs::PoseStamped &goal, double tolerance)
Sets a new goal pose for the planner execution.
double frequency_
planning cycle frequency (used only when running full navigation; we store here for grouping paramete...
boost::mutex plan_mtx_
mutex to handle safe thread communication for the plan and plan-costs
#define ROS_WARN_STREAM(args)
PlanningState
Internal states.
#define ROS_DEBUG_STREAM(args)
PlanningState getState() const
Returns the current internal state.
std::string global_frame_
the global frame in which the planner needs to plan
boost::mutex goal_start_mtx_
mutex to handle safe thread communication for the goal and start pose.
double distance(const geometry_msgs::PoseStamped &pose1, const geometry_msgs::PoseStamped &pose2)
std::vector< geometry_msgs::PoseStamped > plan_
current global plan
#define ROS_INFO_STREAM(args)
AbstractPlannerExecution(const std::string &name, const mbf_abstract_core::AbstractPlanner::Ptr &planner_ptr, const MoveBaseFlexConfig &config)
Constructor.
double sumDistance(_Iter _begin, _Iter _end)
void setNewStartAndGoal(const geometry_msgs::PoseStamped &start, const geometry_msgs::PoseStamped &goal, double tolerance)
Sets a new star and goal pose for the planner execution.
bool has_new_goal_
true, if a new goal pose has been set, until it is used.
mbf_abstract_core::AbstractPlanner::Ptr planner_
the local planer to calculate the robot trajectory
boost::mutex planning_mtx_
mutex to handle safe thread communication for the planning_ flag.
virtual ~AbstractPlannerExecution()
Destructor.
void reconfigure(const MoveBaseFlexConfig &config)
Is called by the server thread to reconfigure the controller execution, if a user uses dynamic reconf...
#define ROS_ERROR_STREAM(args)
std::string robot_frame_
robot frame used for computing the current robot pose
const TFPtr tf_listener_ptr_
shared pointer to a common TransformListener
ros::Duration patience_
planning patience duration time