ROS Resources: Documentation | Support | Discussion Forum | Index | Service Status | ros @ Robotics Stack Exchange
Ask Your Question
4

set-up for real-time control in ROS

asked 2013-04-19 06:04:32 -0600

this post is marked as community wiki

This post is a wiki. Anyone with karma >75 is welcome to improve it.

Hello,

I am new to real-time control in ROS. When I looked up it in this wiki, integrating ROS and OROCOS and using Xenomai seems to be a good solution for it. I don't have a high level understanding of the advantage of using them. If you could share your insight into it with me, I would really appreciate it.

I can enumerate several possible set-ups for real-time control in ROS although some of these may not make sense.

  1. ROS on Ubuntu
  2. ROS on Xenomai patched Ubuntu
  3. ROS+OROCOS on Ubuntu
  4. ROS+OROCOS on Xenomai patched Ubuntu

We may scarcely be able to expect any good real-time performance on (1). How/why bad is it? Would be there any improvement in using (2) over (1)? How would (3) be different to (4) in real-time performance? Do you have any other recommended set-up? Dose it need to be broken down into some subdivided set-ups?

Thank you very much in advance.

edit retag flag offensive close merge delete

3 Answers

Sort by ยป oldest newest most voted
7

answered 2013-04-19 07:22:45 -0600

this post is marked as community wiki

This post is a wiki. Anyone with karma >75 is welcome to improve it.

You can only get good realtime performance with option 4. The OROCOS RTT toolkit provides realtime behaviour but only on a kernel with a realtime extension. The other options can also give good performance but it will vary a lot. See also this: http://answers.ros.org/question/9500/what-realtime-patch-should-i-use-with-ros/

A good example is how the realtime controllers of the PR2 work. ROS runs non realtime while the controller manager (which uses the RRT toolkit I think) is realtime.

image description From:http://pr2support.willowgarage.com/wiki/PR2%20Manual/Chapter7#Realtime_Loop

edit flag offensive delete link more

Comments

Thank you very much for your answer. I'd also like to know the advantage of using OROCOS. If both a ROS node and a OROCOS component can be real-time priority threads, what makes OROCOS on Xenomai better perform than ROS on Xenomai?

dj gravatar image dj  ( 2013-04-19 08:20:22 -0600 )edit

http://engineering.oregonstate.edu/mailman/archives/public/ethercat-ros/ -- That mailing list has a lot of discussion about using ROS in a real-time system.

Thomas D gravatar image Thomas D  ( 2013-04-19 09:23:30 -0600 )edit
5

answered 2014-05-10 23:26:51 -0600

drewm1980 gravatar image

In our research group we have used OROCOS for several years, and have hired some of the OROCOS developers as consultants to help us tune the real-time performance of our system. I would recommend starting with the easiest to set up system (ROS on a vanilla kernel, components written in Python), and make the following upgrades ONLY as necessary after MEASURING your current performance, and ONLY to the parts of your system that NEED it:

  1. Make sure you have your components/nodes that need it running with real-time priority
  2. Upgrade your kernel to one with the PREEMPT_RT patches applied
  3. Dedicate a fraction of the cores on your CPU (if multicore) to your real-time processes, make sure the non-critical processes are launched on the other cores.
  4. Port components to C++ if delays within the components are the bottleneck
  5. Port components to Orocos if delays of message transmission between components is the bottleneck
  6. Install Xenomai kernel and recompile against it's API's (at this point you are pretty deep into black magic territory; the only people using this are either operating obscenely tight control loops, or implementing safety-critical systems)

Never make any assumptions about where your bottleneck is; ALWAYS measure at every stage of development. Rules of thumb like "avoid dynamic memory allocation" and "only use low-level systems programming languages like C/C++/Fortran" come secondary to this.

edit flag offensive delete link more
1

answered 2013-04-25 05:58:56 -0600

this post is marked as community wiki

This post is a wiki. Anyone with karma >75 is welcome to improve it.

Hi, I've mainly used option 2. Theoretically options 2 and 4 should give you the same performance. The benefit of OROCOS is that it makes the integration easier, and makes it possible to switch between different real-time Kernels. OROCOS also provides many other tools to help develop real-time applications, such as methods for real-time modules to communicate with each other.

So your list should include options 5,6, etc. for other real-time Kernels.

e.g. Option 5, ROS on Preempt patched Ubuntu (this is what the PR2 uses)

edit flag offensive delete link more

Question Tools

4 followers

Stats

Asked: 2013-04-19 06:04:32 -0600

Seen: 5,421 times

Last updated: May 10 '14