capnp struct definitions and messaging used in comma ecosystem
Go to file
Robbe Derks 266fc01950 Add MON_HW2 ublox message 2021-01-29 16:49:01 +01:00
.github/workflows Visionipc v2.0 (#101) 2021-01-08 14:54:41 +01:00
include initial commit, internal from 6/13/19 2019-06-13 12:06:15 -07:00
messaging Revert "lower alive threshold to 5x" 2021-01-29 13:02:11 +01:00
site_scons/site_tools cython dependency scanner 2021-01-11 14:15:29 -08:00
visionipc don't crash on invalid buffer type 2021-01-19 15:28:50 +01:00
.dockerignore Run scons in CI (#14) 2019-11-20 16:32:42 -08:00
.gitignore Visionipc v2.0 (#101) 2021-01-08 14:54:41 +01:00
.pre-commit-config.yaml Visionipc v2.0 (#101) 2021-01-08 14:54:41 +01:00
Dockerfile Visionipc v2.0 (#101) 2021-01-08 14:54:41 +01:00
LICENSE Add the same license on this repo as openpilot (#78) 2020-11-25 11:12:13 +01:00
README.md add codecov badge to README 2020-07-29 00:37:16 -07:00
SConscript Visionipc v2.0 (#101) 2021-01-08 14:54:41 +01:00
SConstruct Visionipc v2.0 (#101) 2021-01-08 14:54:41 +01:00
__init__.py add pre-commit static analysis (#48) 2020-05-28 16:04:53 -07:00
car.capnp add managerState (#111) 2021-01-25 20:01:39 -08:00
codecov.yml Coverage analysis in CI (#75) 2020-07-29 00:33:42 -07:00
generate_javascript.sh initial commit, internal from 6/13/19 2019-06-13 12:06:15 -07:00
install_capnp.sh Library cleanup (#43) 2020-05-12 18:50:24 -07:00
log.capnp Add MON_HW2 ublox message 2021-01-29 16:49:01 +01:00
maptile.capnp initial commit, internal from 6/13/19 2019-06-13 12:06:15 -07:00
service_list.yaml add managerState (#111) 2021-01-25 20:01:39 -08:00
services.py Field designator initialization order (#60) 2020-06-25 11:32:56 -07:00

README.md

What is cereal? cereal tests codecov

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 and another 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)