trigrass2 / lcm

Lightweight Communications and Marshalling

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Lightweight Communications and Marshalling (LCM)

LCM is a set of libraries and tools for message passing and data marshalling, targeted at real-time systems where high-bandwidth and low latency are critical. It provides a publish/subscribe message passing model and automatic marshalling/unmarshalling code generation with bindings for applications in a variety of programming languages.

Roadmap

The LCM project is active again. The current long-term plan is to focus on stability and maintenance patches to fix longstanding issues. Longer term we're open to evolution of LCM to have additional features (as long as backwards compatibility is enforced). We're very open to community feedback and involvement on new features.

Quick Links

Features

  • Low-latency inter-process communication
  • Efficient broadcast mechanism using UDP Multicast
  • Type-safe message marshalling
  • User-friendly logging and playback
  • No centralized "database" or "hub" -- peers communicate directly
  • No daemons
  • Few dependencies

Supported platforms and languages

  • Platforms:
    • GNU/Linux
      • Ubuntu (20.04 and 22.04)
      • Fedora (37)
    • macOS (11 and 12)
    • Windows (2019 and 2022) via MSYS2
  • Languages
    • C
    • C++
    • Java
    • Lua
    • MATLAB
    • Python (3.6 and later)

Unmaintained languages

The following languages are currently unmaintained. PRs for these languages are still welcome and if you are interested in maintaining them please let us know.

  • Go
  • C#/.NET

About

Lightweight Communications and Marshalling

License:GNU Lesser General Public License v2.1


Languages

Language:Java 48.1%Language:C++ 28.0%Language:C 16.8%Language:CMake 2.5%Language:C# 1.7%Language:HTML 0.8%Language:Python 0.6%Language:Roff 0.4%Language:Go 0.3%Language:Lua 0.3%Language:CSS 0.2%Language:Shell 0.1%Language:M4 0.1%