You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
This log file records what I met. After the first goal arrived, the robot received a second goal(different from the first, 180 degrees inverse), then move_base returned "goal arrived" immediately, while the robot didn't move at all.
And I think I've found the reason.
The planThread is making plan for the first goal(planner_frequency > 0), but the executeCycle() has reached goal and returned. Then the second goal arrives and executeCb() enters loop again, waiting for new_global_plan available to set plan to local planner. Now makePlan() returns, setting new_global_plan true, but the global plan is for the first goal. So the plan for the first goal is passed to local planner. Since the robot is already there, local planner returns "goal reached" immediately.
To simulate the delay in makePlan(), I add 15 seconds sleep before makePlan(), and I can easily repeat this phenomenon.
Here is my solution.
After makePlan() returns with a planner_plan, the planThread should check if a new planner_goal is available. If that's the case, the planner_plan should be abandoned, and planThread should go back to make plan for the new planner_goal.
I think this is reasonable, because as soon as a new goal arrives, the plan for the old goal should not be used.
The text was updated successfully, but these errors were encountered:
This log file records what I met. After the first goal arrived, the robot received a second goal(different from the first, 180 degrees inverse), then move_base returned "goal arrived" immediately, while the robot didn't move at all.
data:image/s3,"s3://crabby-images/ef880/ef88097267968dd4cf337ad6057bd0cb119656f6" alt="捕获"
And I think I've found the reason.
data:image/s3,"s3://crabby-images/96395/96395368b61a46807247e5afcbafc39e99c5570a" alt="move_base"
The planThread is making plan for the first goal(planner_frequency > 0), but the executeCycle() has reached goal and returned. Then the second goal arrives and executeCb() enters loop again, waiting for new_global_plan available to set plan to local planner. Now makePlan() returns, setting new_global_plan true, but the global plan is for the first goal. So the plan for the first goal is passed to local planner. Since the robot is already there, local planner returns "goal reached" immediately.
To simulate the delay in makePlan(), I add 15 seconds sleep before makePlan(), and I can easily repeat this phenomenon.
Here is my solution.
After makePlan() returns with a planner_plan, the planThread should check if a new planner_goal is available. If that's the case, the planner_plan should be abandoned, and planThread should go back to make plan for the new planner_goal.
I think this is reasonable, because as soon as a new goal arrives, the plan for the old goal should not be used.
The text was updated successfully, but these errors were encountered: