MariLib is a Python library for interacting with the Mari network.
Project description
MariLib 💫 👀 🐍
MariLib is a Python library to interact with a local Mari network. It connects to a Mari gateway via:
- UART, using MarilibEdge
- MQTT, using MarilibCloud
Example with TUI
MariLib provides a stateful class with gateway and node information, network statistics, and a rich real-time TUI:
To run with a gateway connected via UART:
# for example, using the Inria Argus MQTT broker
(.venv) $ mari-edge -m mqtts://argus.paris.inria.fr:8883
You can see how it works using mari-edge --help.
To run with a gateway connected via MQTT:
# for example, using the Inria Argus MQTT broker
(.venv) $ mari-cloud -n 0x0100 -m mqtts://argus.paris.inria.fr:8883
Reading the TUI
Most columns in the per-node table are self-explanatory (TX/RX counts, PDR, RSSI). The two that need a key:
-
Latency | host/dl/app/ul (ms) — total host-measured round-trip latency on the left of the bar, then the four-leg breakdown that sums (≈) to it:
host— UART round-trip plus Python parse overhead (typically 10–30 ms at 1 Mbps; sustained higher means host-side congestion).dl— gateway downlink-queue wait plus one radio slot.app— node-side application turnaround (e.g. how long the SwarmIT network-core main loop takes between receiving the probe and enqueueing the response).ul— node uplink-queue wait plus one radio slot. This is the leg that grows when the node is saturating its uplink budget.
Wire legs come from ASN snapshots the firmware stamps into each probe (
gw_tx_enqueued_asn,node_rx_asn,node_tx_enqueued_asn,gw_rx_asn) converted via the slot duration (1.724 ms in the shipped schedules). When the firmware hasn't populated the wire ASNs the row showstotal | ? / ? / ? / ?. -
Q (sf) — estimated TX-queue depth at the node in slotframe units. Each joined node has exactly one uplink slot per slotframe, so
ul_ms / sf_duration_msis the number of packets queued ahead of the probe response when it was enqueued. Coloring: white below 2 (healthy), yellow at 2–4 (contended), red above 4 (saturated). The header panel also shows a⚠ TX queue saturatedline when any node crosses the red threshold.
Setup and dependencies
To setup the environment, do:
$ python -m venv .venv
$ source .venv/bin/activate
(.venv) $ pip install -e .
Minimal example
Here is a minimal example showcasing how to use MariLib:
import time
from marilib.marilib import MarilibEdge
from marilib.serial_uart import get_default_port
def main():
mari = MarilibEdge(lambda event, data: print(event.name, data), get_default_port())
while True:
for node in mari.gateway.nodes:
mari.send_frame(dst=node.address, payload=b"A" * 3)
statistics = [(f"{node.address:016X}", node.stats.received_rssi_dbm()) for node in mari.gateway.nodes]
print(f"Network statistics: {statistics}")
time.sleep(0.25)
if __name__ == "__main__":
main()
See it in action in examples/minimal.py.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file marilib_pkg-0.9.0rc3.tar.gz.
File metadata
- Download URL: marilib_pkg-0.9.0rc3.tar.gz
- Upload date:
- Size: 40.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ed643b7649eec3b1f0dc3d64e8700ce8f52ef99b41a2e2bdc8e3fc7149fd0f65
|
|
| MD5 |
bd7163e9b3d9e84cbfc46fd73dc87a00
|
|
| BLAKE2b-256 |
43e56d56d1138614d0858662d258ad24a14ec2fdefaa9520057e0a79b76883e2
|
File details
Details for the file marilib_pkg-0.9.0rc3-py3-none-any.whl.
File metadata
- Download URL: marilib_pkg-0.9.0rc3-py3-none-any.whl
- Upload date:
- Size: 53.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bedfcc1a0d023a6505771eb866f9cb393c4fa0b3bc232e8ba10a253e01677738
|
|
| MD5 |
8dd0c4aecac598f7e27c15aaff993715
|
|
| BLAKE2b-256 |
3957e640958795fcfb4438c27df581991ebd30b3bf73e21d67ea1cdd43cfe0be
|