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.

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.4.4-cp310-abi3-win_amd64.whl (4.3 MB view details)

Uploaded CPython 3.10+Windows x86-64

dexcomm-0.4.4-cp310-abi3-manylinux_2_34_x86_64.whl (4.7 MB view details)

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

dexcomm-0.4.4-cp310-abi3-manylinux_2_34_aarch64.whl (4.5 MB view details)

Uploaded CPython 3.10+manylinux: glibc 2.34+ ARM64

dexcomm-0.4.4-cp310-abi3-macosx_11_0_arm64.whl (4.1 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

File details

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

File metadata

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

File hashes

Hashes for dexcomm-0.4.4-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 8a317eb66650e235e26214ba304d6b35e35c0ca281e87e61e3b20aa885c92b17
MD5 233a548fd7723ebc188ba13cd1762ecd
BLAKE2b-256 2da4074862a162176aa4a84539787c25b71607805b8ff01fd4edb17d351f6148

See more details on using hashes here.

File details

Details for the file dexcomm-0.4.4-cp310-abi3-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for dexcomm-0.4.4-cp310-abi3-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 5defe8364516c2b6afc226dcfd0dd5feba98a8f00e36e901ed0d39d4b2cb331b
MD5 4bcc7a3e48e0c8d991163f51ecf3c969
BLAKE2b-256 b32ff8b91783af8252bb7bed258f4dd773b12e9a88697b639006043a8e74d5d9

See more details on using hashes here.

File details

Details for the file dexcomm-0.4.4-cp310-abi3-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for dexcomm-0.4.4-cp310-abi3-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 0802afdc2c3ceee2fc3a9ec532fb44feafc39d1288bdd3375f33cfb1eb123978
MD5 c83c383c8b77ad7acc364476b3e4cd1a
BLAKE2b-256 14221cd46b38c16211712623356eba260f1eae27ce17bc7b0e7dd63087dbc369

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for dexcomm-0.4.4-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 fa5c6114392daef23cb42ac8c18e255d1592dc5777432de14be6f0e928e1fd9e
MD5 89c3982516cf6b1c8887c3683f427172
BLAKE2b-256 82e52578fdbd99b38435cb6fdddefb224f4f6ad50468bfd832bd874fc17bf305

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