openpilot/cereal
Vehicle Researcher d692982601 Merge cereal subtree 2020-05-09 13:01:20 -07:00
..
.github/workflows Merge cereal subtree 2020-02-17 18:12:44 -08:00
include Merge commit '24e096d9f0f424c22b616b43957a5fd310f4ee83' as 'cereal' 2019-06-28 21:09:10 +00:00
messaging Merge cereal subtree 2020-05-09 13:01:20 -07:00
.dockerignore Merge cereal subtree 2019-12-13 13:02:45 -08:00
.gitignore Merge cereal subtree 2020-01-15 14:04:38 -08:00
Dockerfile Merge cereal subtree 2019-12-13 13:02:45 -08:00
README.md Merge cereal subtree 2020-03-16 16:19:31 -07:00
SConscript Merge cereal subtree 2020-05-09 13:01:20 -07:00
SConstruct Merge cereal subtree 2019-12-13 13:02:45 -08:00
__init__.py Merge commit '24e096d9f0f424c22b616b43957a5fd310f4ee83' as 'cereal' 2019-06-28 21:09:10 +00:00
car.capnp Merge cereal subtree 2020-05-09 13:01:20 -07:00
generate_javascript.sh Merge commit '24e096d9f0f424c22b616b43957a5fd310f4ee83' as 'cereal' 2019-06-28 21:09:10 +00:00
install_capnp.sh Merge cereal subtree 2019-12-13 13:02:45 -08:00
log.capnp Merge cereal subtree 2020-05-09 13:01:20 -07:00
maptile.capnp Merge commit '24e096d9f0f424c22b616b43957a5fd310f4ee83' as 'cereal' 2019-06-28 21:09:10 +00:00
service_list.yaml Merge cereal subtree 2020-05-09 13:01:20 -07:00
services.py Merge cereal subtree 2019-12-13 13:02:45 -08:00

README.md

What is cereal?

cereal is both a messaging spec for robotics systems as well as generic high performance IPC pub sub messaging with a single publisher and multiple subscribers.

Imagine this use case:

  • A sensor process reads gyro measurements directly from an IMU and publishes a sensorEvents packet
  • A calibration process subscribes to the sensorEvents packet to use the IMU
  • A localization process subscribes to the sensorEvents packet to use the IMU also

Messaging Spec

You'll find the message types in log.capnp. It uses Cap'n proto and defines one struct called Event.

All Events have a logMonoTime and a valid. Then a big union defines the packet type.

Pub Sub Backends

cereal supports two backends, one based on zmq, the other called msgq, a custom pub sub based on shared memory that doesn't require the bytes to pass through the kernel.

Example

import cereal.messaging as messaging

# in subscriber
sm = messaging.SubMaster(['sensorEvents'])
while 1:
  sm.update()
  print(sm['sensorEvents'])

# in publisher
pm = messaging.PubMaster(['sensorEvents'])
dat = messaging.new_message('sensorEvents', size=1)
dat.sensorEvents[0] = {"gyro": {"v": [0.1, -0.1, 0.1]}}
pm.send('sensorEvents', dat)