Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/selective aruco detect #5

Merged
merged 6 commits into from
May 27, 2022

Conversation

swaroophs
Copy link
Contributor

Hello!

This PR is adjacently related to this issue that I reported. However it does not directly fix that. While I was debugging the issue, I found that the aruco_detect node was also consuming CPU when the autodock algorithm was idle. Screenshot of htop shown below shows aruco_detect CPU consumption when IDLE:

aruco_consume_idle_before_fix

Ideally, we should not be detecting/looking for aruco markers until an AutoDock action itself is started. But it seems like on default config, the aruco_detect is always on and looking for these markers resulting in high CPU consumption. Looking into this further, the aruco_detect node DOES have a neat service called /enable_detections that lets us enable/disable detections. So without touching the source code for aruco_detect, we will be able to manage the state of these detections from the autodock node itself.

This PR primarily helps implement this with the following changes:

  1. Add service client and utility function to set detections
  2. Set aruco detections based on autodock state

Some screenshots below from interactive testing with Turtlebot sim:
Below, you can see that aruco_detect consumption has reduced when the autodock is idle:

aruco_consume_idle_after_fix

On startup itself, we disable detections so when the sim is launched with the rviz, we will NOT see any images from the /fiducial_images topic:

[INFO] [1652233347.443160, 0.000000]: Starting AutoDockServer Node
Enable detections response:  Disabled aruco detections.

autodock_init_no_image

Below, you can see that aruco_detect is back to normal consumption when autodock is in progress:

aruco_consume_running_afterfix

Now we start seeing images on the /fiducial_images topic:

Enable detections response:  Enabled aruco detections.
[INFO] [1652233573.711246, 104.431000]: Will attempt with 1 retry

When autodock fails:

[ERROR] [1652233576.152186, 106.457000]: Not detecting two side markers, exit state
[WARN] [1652233576.159298, 106.460000]: Failed to Dock attempt
[WARN] [1652233576.163408, 106.467000]: Attempting retry: 1/1
[INFO] [1652233576.180853, 106.479000]: State is not retry-able
[WARN] [1652233576.187205, 106.482000]: Not able to retry
Enable detections response:  Disabled aruco detections.
[WARN] [1652233576.213065, 106.503000]:  State: [IDLE] | Failed execute Dock Action

dock_called_image_but_Frozen

When autodock succeeds:

[WARN] [1652233696.103499, 210.448000]:  State: [ACTIVATE_CHARGER] | Docked, activate charger!
[ INFO] [1652233696.111709104, 210.458000000]: ObstacleObserver received autodock state: 6
[WARN] [1652233698.406090, 212.458000]:  State: [ACTIVATE_CHARGER] | Celebration!!
[ INFO] [1652233698.411430833, 212.462000000]: ObstacleObserver received autodock state: 6
[WARN] [1652233698.411304, 212.461000]:  State: [IDLE] | All Success!
[ INFO] [1652233698.422862282, 212.472000000]: ObstacleObserver received autodock state: 1
Enable detections response:  Disabled aruco detections

img_when_docking

Note that in rviz, once the docking action is complete, the image will look "frozen". That is because, we disable detections at the end of the action and aruco_detect will stop publishing to the /fiducial_images topic.

Points to ponder:

  1. Currently the behavior is the detections are off on startup and are selectively enabled/disabled based on the dock state. Should there be an option to not do this when some sort of debug flag is passed for ease of debugging which in essence will turn off this feature and go back to previous default behavior?
  2. There is now extra dependency on the /enable_detections service succeeding. In the event of failure of this service, we rely on the Autodock action's built-in retry mechanism to re-call the service instead of its own retry. I thought it was easier to keep track of the retries this way and conceptually consider that enabling/disabling detections is part of the docking algorithm itself.

Copy link
Contributor

@youliangtan youliangtan left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This feature is really helpful, greatly appreciate your contribution and help in testing this on your robots!! Able to toggle off the aruco_detect greatly reduce the CPU usage during idle. The 'debug mode" recommendation is great to have, so hopefully this can also be included in this pr.

autodock_core/scripts/autodock_core/autodock_server.py Outdated Show resolved Hide resolved
autodock_core/scripts/autodock_core/autodock_server.py Outdated Show resolved Hide resolved
swaroophs added 3 commits May 26, 2022 09:48
-------------------------------------------
Default true, when false:
1. selectively enable/disable aruco detections
2. turn off viz markers
@swaroophs
Copy link
Contributor Author

@youliangtan I have updated the PR with your recommendations. Try it with the following two launch variations:

Default behavior when debug_mode set to True:
roslaunch autodock_sim tb3_nav_dock_sim.launch

debug_mode set to False that can be used for deployments:
roslaunch autodock_sim tb3_nav_dock_sim.launch debug_mode:=False

Note: Even though it was not in the scope of our original conversation, I used parameter to turn "off" the timer used to publish debug viz markers to visualize in rviz. If for some reason you think we should not be doing this, let me know and I can remove the logic around it.

@youliangtan
Copy link
Contributor

I tested the debug_mode on simulation with the turtlebot. It works well! Thanks again for the contribution

@youliangtan youliangtan merged commit fb9fc5e into osrf:main May 27, 2022
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants