Skip to content

Latest commit

 

History

History
71 lines (48 loc) · 2.23 KB

README.md

File metadata and controls

71 lines (48 loc) · 2.23 KB

mb_pose_estimation

An experimental ROS package for model-based pose estimation and tracking with localized robots. See this video for an example:

https://www.youtube.com/watch?v=32SIoHGDzTE

Installation

Create a catkin workspace from the following .rosinstall file:

- git: {local-name: src/lima, uri: 'git@github.com:marioprats/lima.git'}
- git: {local-name: src/mb_pose_estimation, uri: 'git@github.com:marioprats/mb_pose_estimation.git'}

You will need to install ViSP, which is available as a debian package (e.g. ros-groovy-visp). Running rosdep will install the dependencies for you.

How to use

First create a description of the object to track inside the data/ folder the mb_pose_estimation package, e.g. tv.cao and tv.init.

V1
4
0 0 0
0.995 0 0
0.995 0.62 0
0.0 0.62 0
0
0
1
4 0 1 2 3
0

  • tv.init. Contains the list of vertices the user has to click to train the model:
4
0 0 0
0.995 0 0
0.995 0.62 0
0.0 0.62 0

Then place the robot looking towards the object and let it 'learn' the visual appearance. Assuming the robot is localized in the /map frame (replace the topic names by suitable ones):

rosrun mb_pose_estimation training_node --id tv --camera /head_camera/rgb/image_rect --camera-info /head_camera/rgb/camera_info --world-frame /map

Click on the image on top of the vertices described in the .init file (in the same order), and, if the initial estimation looks good for you, click on the image with the mouse left button. After this, the robot will store a set of descriptors that will help estimating the pose in the future.

Once your model has been trained, start the pose estimation service:

rosrun mb_pose_estimation pose_estimation_service --camera /head_camera/rgb/image_rect --camera-info /head_camera/rgb/camera_info --debug --world-frame map

Your can now request the pose of an object from different robot locations (assuming the object appears in the image) trhough a call to the /pose_estimation service. There is a client example:

rosrun mb_pose_estimation pose_estimation_client --id tv