teaching:se-kiba:perception-assignment
                Differences
This shows you the differences between two versions of the page.
| Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
| teaching:se-kiba:perception-assignment [2013/04/29 15:46] – [Package Descriptions] balintbe | teaching:se-kiba:perception-assignment [2016/05/19 09:19] (current) – external edit 127.0.0.1 | ||
|---|---|---|---|
| Line 1: | Line 1: | ||
| ====== Homework: ROS packages for perception ====== | ====== 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 | + | The aim is to create ros packages and set up a small pipeline for finding objects on top of a table offering | 
| {{ : | {{ : | ||
| Line 21: | Line 21: | ||
| Create the three ROS packages and as a first step commit and push the empty packages to the repository. | Create the three ROS packages and as a first step commit and push the empty packages to the repository. | ||
| + | Download the bag file from this [[https:// | ||
| ====== Package Descriptions ====== | ====== Package Descriptions ====== | ||
| ===== 1. perception_pkg ===== | ===== 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, | + | 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, | 
| ====Subscribe to the topic==== | ====Subscribe to the topic==== | ||
| Line 33: | Line 34: | ||
| ====Processing the cloud==== | ====Processing the cloud==== | ||
| + | Point Clouds should be processed as they are read in, and a buffer of the results should be kept in memory at all time. The processing part of the package 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 (note that all values in PCL are represented in meters.), and store these in a buffer. You will need to advertise a service, which, upon request, will always return the latest results. | ||
| + | |||
| + | Notes on processing the input clouds: | ||
| + | * Start from the code presented in the tutorial ([[teaching: | ||
| + | * 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 ExtractPolygonalPrism in order to find the points above the plane.(more on this [[http:// | ||
| + | * use Euclidean clustering with a distance threshold of 3 cm-s to find the point cluster of each object [[http:// | ||
| ====Service for advertising the result==== | ====Service for advertising the result==== | ||
| - | Results should be returned in the message type described in the next section. | + | 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 // | 
| ===== 2. perception_group_msgs ===== | ===== 2. perception_group_msgs ===== | ||
| - | This package should contain all the message and service type definitions used by the perception_ and perception_client_ packages. | + | 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 message | + | 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 | 
| + | Note:Center pose needs to be a //Point//, which is defined in the // | ||
| + | You will also need to define a new service in this same package. This service, call it **GetClusters**, | ||
| ===== 3. perception_client_pkg ===== | ===== 3. perception_client_pkg ===== | ||
| + | |||
| + | This package implements the client side of the pipeline. It is responsible for querying the service for the latest results, and for communicating them to the users. Besides serving as the bridge between users and processing, it is also the entry point for the pipeline, meaning that it needs to offer an easy interface for launching everything that is necessary for the pipeline (roscore, openni, service subscriber etc. ) | ||
| + | |||
| + | |||
| + | For questions and clarifications contact //balintbe **at** tzi **dot** de// | ||
| + | |||
| + | |||
teaching/se-kiba/perception-assignment.1367250374.txt.gz · Last modified:  (external edit)
                
                