Skip to main content

Lightweight Extensible Signal Transport for Reticulum

Project description

Lightweight Extensible Signal Transport

LXST is a simple and flexible real-time streaming format and delivery protocol that allows a wide variety of implementations, while using as little bandwidth as possible. It is built on top of Reticulum and offers zero-conf stream routing, end-to-end encryption and Forward Secrecy, and can be transported over any kind of medium that Reticulum supports.

  • Cross-platform, works on Linux, Android, Windows and Mac
  • Provides a variety of ready-to-use primitives, for easily creating applications such as:
    • Telephony and live voice calls
    • Two-way radio systems
      • Direct peer-to-peer radio communications
      • Trunked and routed real-time radio systems
    • Media streaming
    • Broadcast radio
    • Public address systems
  • Can handle real-time signal streams with end-to-end latencies below 10 milliseconds
  • Supports encoding and decoding stream contents with a range of different codecs
    • Raw and lossless streams with arbitrary sample rates
      • Up to 32 channels
      • Up to 128-bit sample precision
    • Efficient, high-quality voice and audio with OPUS
      • Many different built-in profiles, from ~4.5kbps to ~96kbps
      • Profiles are pre-tuned for different applications, such as:
        • Low-bandwidth voice
        • Medium quality voice
        • High quality, perceptually lossless voice
        • Media content such as podcasts
        • Perceptually lossless stereo music
    • Ultra low-bandwidth voice communications with Codec2
      • Provides intelligible voice between 700bps and 3200bps
  • Can dynamically switch codecs mid-stream without stream re-initialization or frame loss
  • Has in-band signalling support for call signalling, communications, metadata embedding, media and stream management
  • Uses a fully staged signal pipelining, allowing arbitrary stream routing
  • Provides built-in signal mixing support for any number of channels

Transport Encryption

LXST uses encryption provided by Reticulum, and thus provides end-to-end encryption, guaranteed data integrity and authenticity, as well as forward secrecy by default.

Project Status & License

This software is in a very early alpha state, and will change rapidly with ongoing development. Consider no APIs stable. Consider everything explosive. Not all features are implemented. Nothing is documented. For a fully functional LXST program, take a look at Sideband or the included rnphone program, which provides telephony service over Reticulum. Everything else will currently be a voyage of your own making.

While under early development, and unless otherwise noted, the project is kept under a CC BY-NC-ND 4.0 license.

Installation

If you want to try out LXST, you can install it with pip:

pip install lxst

On Raspberry Pi (assuming Trixie / Debian 13), install various dependencies with:

# Audio codecs
sudo apt install python3-pyaudio codec2

# For hardware control over I2C:
pip install smbus2 --break-system-packages # Install smbus module if not already installed
sudo raspi-config # Enable the I2C bus under "Interface Options"
sudo apt install python3-rpi.gpio # Install gpio module system-wide

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

lxst-0.4.3-py3-none-any.whl (3.7 MB view details)

Uploaded Python 3

lxst-0.4.3-3-py3-none-any.whl (3.7 MB view details)

Uploaded Python 3

lxst-0.4.3-2-py3-none-any.whl (3.7 MB view details)

Uploaded Python 3

lxst-0.4.3-1-py3-none-any.whl (3.7 MB view details)

Uploaded Python 3

File details

Details for the file lxst-0.4.3-py3-none-any.whl.

File metadata

  • Download URL: lxst-0.4.3-py3-none-any.whl
  • Upload date:
  • Size: 3.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for lxst-0.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 53bf2dbce6e79ad553ceb602b9d7a0d2d929028606dd13974329d72a34531809
MD5 8a1be9ba193847f58e923aecdbdcc397
BLAKE2b-256 fd3d2d44bfb83a1b7bafce4540e558a96996225e3e322c9bf897cf3e3ed6c79b

See more details on using hashes here.

File details

Details for the file lxst-0.4.3-3-py3-none-any.whl.

File metadata

  • Download URL: lxst-0.4.3-3-py3-none-any.whl
  • Upload date:
  • Size: 3.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for lxst-0.4.3-3-py3-none-any.whl
Algorithm Hash digest
SHA256 3812cc42cb06b4e7995629ae0f8912699ff44b73b4b94f956c74fe8022e13c99
MD5 0c2d8c0ed50a47464a40638f2de1406c
BLAKE2b-256 0ba21cd02b516557c6eeca8f8e1759d35010a04894bce7b5119ce0cd06bef967

See more details on using hashes here.

File details

Details for the file lxst-0.4.3-2-py3-none-any.whl.

File metadata

  • Download URL: lxst-0.4.3-2-py3-none-any.whl
  • Upload date:
  • Size: 3.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for lxst-0.4.3-2-py3-none-any.whl
Algorithm Hash digest
SHA256 5d227ce7e6ab294cf113842f5ff2c8f0c126773863ce0a95833b70943c917cbb
MD5 b9ef3d2c65856549c4197fa23defae00
BLAKE2b-256 c167839627a945606c65d2b5070168668c139f0bf323888973d13c15434eb54b

See more details on using hashes here.

File details

Details for the file lxst-0.4.3-1-py3-none-any.whl.

File metadata

  • Download URL: lxst-0.4.3-1-py3-none-any.whl
  • Upload date:
  • Size: 3.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for lxst-0.4.3-1-py3-none-any.whl
Algorithm Hash digest
SHA256 79b7947033c549eaeff25124d500d088ce4046bac8e720bea6504e58b26d1abe
MD5 27129eabb161029b5cbbf40b3eb29cdf
BLAKE2b-256 7efb368a65a8cb15556d4edc2154faa2cc8c642cc841f2a2fe2eff2e3d042023

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page