Skip to main content

Accelerated communication library using Zenoh for robotics and AI

Project description

DexComm - High-Performance Communication Library

High-efficiency pub/sub and RPC for robotics and AI. Zero configuration required.

Installation

System Dependencies

Linux (Ubuntu/Debian):

sudo apt-get update
sudo apt-get install ffmpeg libjpeg-turbo8 -y

macOS:

brew install ffmpeg libjpeg-turbo

Install

pip install dexcomm

Platform Support

  • Python: 3.10+
  • Linux: x86_64, aarch64
  • macOS: x86_64, arm64 (Apple Silicon)

Quick Start

Raw API (Simplest)

from dexcomm import Publisher, Subscriber
from dexcomm.codecs import PickleDataCodec

# Publisher
pub = Publisher("sensor/temperature", encoder=PickleDataCodec.encode)
pub.publish({"value": 25.5, "unit": "celsius"})

# Subscriber
sub = Subscriber("sensor/temperature",
                 decoder=PickleDataCodec.decode,
                 callback=lambda msg: print(f"Received: {msg}"))

Node Pattern (ROS-like)

from dexcomm import Node
from dexcomm.codecs import PickleDataCodec

class RobotController:
    def __init__(self):
        self.node = Node("controller", namespace="robot1")
        self.cmd_pub = self.node.create_publisher("cmd_vel", encoder=PickleDataCodec.encode)
        self.node.create_subscriber("odometry", self.on_odometry, decoder=PickleDataCodec.decode)

    def on_odometry(self, msg):
        self.cmd_pub.publish({"linear": 0.5, "angular": 0.0})

robot = RobotController()
input("Press Enter to stop...\n")

Manager Pattern (Dynamic Topics)

from dexcomm import SubscriberManager
from dexcomm.codecs import PickleDataCodec

manager = SubscriberManager()

# Add/remove topics at runtime
manager.add("sensors/lidar", callback=lambda msg: print(msg), decoder=PickleDataCodec.decode)
manager.add("sensors/imu", callback=lambda msg: print(msg), decoder=PickleDataCodec.decode)
manager.remove("sensors/lidar")

Services (RPC)

from dexcomm import Service, ServiceClient
from dexcomm.codecs import PickleDataCodec

# Server
service = Service("math/add",
                  lambda req: {"sum": req["a"] + req["b"]},
                  request_decoder=PickleDataCodec.decode,
                  response_encoder=PickleDataCodec.encode)

# Client
client = ServiceClient("math/add",
                       request_encoder=PickleDataCodec.encode,
                       response_decoder=PickleDataCodec.decode)
result = client.call({"a": 5, "b": 3})
print(result)  # {"sum": 8}

Remote Robot Connection

Connect directly to a remote robot with a single environment variable:

# Port defaults to 7447 if omitted:
export ROBOT_IP=192.168.50.20
# Or with explicit port:
export ROBOT_IP=192.168.50.20:7447

When ROBOT_IP is set, dexcomm switches to client mode and connects directly to the specified address. Port 7447 is used by default if not specified.

Release hardening

Released wheels are built through scripts/build_wheel.py which applies path remapping, symbol stripping, extra ELF-note scrubbing, SBOM removal from the wheel tree, and a pinned Rust toolchain (rust-toolchain.toml) for reproducible output. Debug/trace tracing events are compiled out of release builds via release_max_level_info; INFO/WARN/ERROR logs are preserved for operations.

Verify a wheel locally:

python scripts/verify_wheel_security.py path/to/dexcomm-*.whl

See docs/PACKAGING_HARDENING_PLAN.md for the full roadmap and implementation status.

License

AGPL-3.0 - see the LICENSE file for details.

Copyright (c) 2026 Dexmate. All rights reserved.

For licensing inquiries: contact@dexmate.ai

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.

dexcomm-0.5.4-cp310-abi3-win_amd64.whl (5.1 MB view details)

Uploaded CPython 3.10+Windows x86-64

dexcomm-0.5.4-cp310-abi3-manylinux_2_35_x86_64.whl (20.9 MB view details)

Uploaded CPython 3.10+manylinux: glibc 2.35+ x86-64

dexcomm-0.5.4-cp310-abi3-manylinux_2_35_aarch64.whl (19.3 MB view details)

Uploaded CPython 3.10+manylinux: glibc 2.35+ ARM64

dexcomm-0.5.4-cp310-abi3-macosx_11_0_arm64.whl (16.6 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

File details

Details for the file dexcomm-0.5.4-cp310-abi3-win_amd64.whl.

File metadata

  • Download URL: dexcomm-0.5.4-cp310-abi3-win_amd64.whl
  • Upload date:
  • Size: 5.1 MB
  • Tags: CPython 3.10+, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for dexcomm-0.5.4-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 d526de96b254ecaa26adc6e58c76c828f7ddf9d09748bce6f6ed6438c8a06e66
MD5 1fbc51ad4b375020783107d7d1f20c4a
BLAKE2b-256 2167cc251bc7a4b6cc0fea6c1fcc68e920cb5fdde8f31f892b57ff8ae6aff017

See more details on using hashes here.

File details

Details for the file dexcomm-0.5.4-cp310-abi3-manylinux_2_35_x86_64.whl.

File metadata

File hashes

Hashes for dexcomm-0.5.4-cp310-abi3-manylinux_2_35_x86_64.whl
Algorithm Hash digest
SHA256 b9dd5f99632f96efa2cc1e5e8c6e0a35663f8d50af798bde7af5ebf52549a71d
MD5 6ffb98a74d690bde7e24fce2084256a6
BLAKE2b-256 08cc85c9e63b687b0c48f0647ef8ae722cf1cc20bad63f25b10ed4b6915969f4

See more details on using hashes here.

File details

Details for the file dexcomm-0.5.4-cp310-abi3-manylinux_2_35_aarch64.whl.

File metadata

File hashes

Hashes for dexcomm-0.5.4-cp310-abi3-manylinux_2_35_aarch64.whl
Algorithm Hash digest
SHA256 6074220f04518d352cd66a0c27f1fb717b9622a793d820483b2dd8056d144bd0
MD5 65919a7297fbdadb6ace2e9289fc3e05
BLAKE2b-256 4013ed07cb1c09c3437b80ec011f582b66af47f22941472878aab1a023ce1702

See more details on using hashes here.

File details

Details for the file dexcomm-0.5.4-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for dexcomm-0.5.4-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 988e193058bb1ebff860b62df3d96fcbae93981f9baf2b6f39ec1bd7247d8ebb
MD5 e30bff65d7bc0cd53295e389a2780117
BLAKE2b-256 b45b6093b3828e4396a8307ad2715653b001d239d284b59efd0ae3adf46f9bc9

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