User Tools

Site Tools


teaching:se-kiba:perception-assignment

This is an old revision of the document!


Homework: ROS packages for perception

The aim is to create ros packages and set up a small pipeline for finding objects on top of a table and offer a service for returning the position and the volume of these. For the sake of simplicity we assume that these objects are clearly separated, meaning that they are spread around the table in an orderly manner, neiter touching nor occluding each other.

Getting started

Please install the system according to the instructions here: https://ai.uni-bremen.de/wiki/software/ros/installation

Before you start workin on the assignment, make sure to have completed the 'beginner level' tutorials from http://www.ros.org/wiki/ROS/Tutorials and you understand how to subscribe to a topic and create a new service and message types.

First steps

We have created a git repository for the code you will develop at:

https://github.com/ai-seminar/group-perception

Add this to your ROS workspace:

rosws set group_perception --git https://github.com/ai-seminar/group-perception.git
rosws update
source ~/.bashrc

Create the three ROS packages and as a first step commit and push the empty packages to the repository.

Package Descriptions

1. perception_pkg

This package is the core of the pipeline. You need to implement three main parts here. First a subscriber to the topic where point clouds are being advertised, Then a processing module, where you work on the point cloud that you read in from the topic, and lastly the same node needs to offer a service for returning results.

Subscribe to the topic

As shown in the tutorial. Example code is here

Processing the cloud

Point Clouds should be processed as they are read in, and the a buffer of the results should be kept in memory at all time. The purpose of the algorithm is to segment out objects lying on a table and separate each object in a separate cluster. After having done so, you are required to calculate the centroid of each cluster as well as the volume of it (all values in PCL are represented in meters.), and put these in a buffer. You will also need to advertise a service which, upon request, will always return the latest results.

Notes on segmentation:

  • Start from the code presented in the tutorial (Perception Tutorial)
  • You are allowed to filter the cloud on the z axis only between 0 and 1.5 meters
  • during plane fitting using RANSAC, make sure you find the correct plane.
  • in order to find the objects on the table create a Convex Hull and use a Prism in order to find the point above this hull.(more on this here)
  • use Euclidean clustering with a distance threshold of 3 cm-s to find the point cluster of each object

Service for advertising the result

Results should be returned in the message type described in the next section. Upon service call the latest results need be returned. Results are in the form of a list containing (c_centroid, c_volume) pairs, beginning with the largest in a descending order.

2. perception_group_msgs

This package should contain all the message and service type definitions used by the perception_ and perception_client_ packages. You should define a new message type. This is the type that the service, offered by the perception package, will be returning. Call your new message type PerceivedObject. It needs to contain a unique ID, a center point, and the volume of the object. Remember to place the defined message in the msg folder of the current ros pkg, and uncomment the necessary lines in the cmake file, so the necessary files get generated upon rosmake. Note:Center pose needs to be a Point, which is defined in the geometry_msgs package.

You will also need to define a new service in this same package. This service, call it GetClusters, will be able to send a request in the form of a string to the package providing it and its response is going to be a list of PerceivedObject-s

3. perception_client_pkg

teaching/se-kiba/perception-assignment.1367417662.txt.gz · Last modified: (external edit)

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki