The control plane for the DotBot - a small wireless wheeled robot built to operate in large swarms, for research and education.
PyDotBot allows you to flash a DotBot and control a whole fleet over the air, from one DotBot to a thousand.
┌───────────┐ ┌────────────┐ ┌─────────┐
│ web UI / │ │ │ │ │
│ CLI / │──REST/WS─▶│ controller │──serial/MQTT─▶│ gateway │──radio─▶ 🤖🤖🤖 DotBot swarm
│ your code │ │ │ │ │
└───────────┘ └────────────┘ └─────────┘
╰─────────── PyDotBot ───────────╯
What you can do
- 🕹️ Drive one DotBot or a whole fleet from a web UI (live map + joystick) or your own Python code
- 📡 Flash the swarm over the air - one command, hundreds of DotBots at once
- 🛰️ Get real-world (x, y) positions with Lighthouse 2 localization
- 🧪 Try it all with zero hardware using the built-in simulator
- 🛠️ One
dotbotCLI takes you from build → flash → run
PyDotBot is available on PyPi, install it with:
pip install pydotbotThen, check your installation with dotbot --version and learn what's possible with dotbot --help.
Every command and flag is documented in the CLI reference.
See the whole thing run with nothing but Python!
The command below will run a simulated swarm, which you can observe in a web UI at http://localhost:8000/PyDotBot/ :
dotbot run simulatorThe web UI opens automatically; pass --headless to suppress it (it's still
served). Drive the simulated DotBots from the UI, or run a bundled demo in a
second terminal:
dotbot run demo circle # drive one DotBot in a circle (the simplest demo)Learn how to script the swarm from your own code, run the richer examples, and more - all with no hardware - in the simulator guide.
The DotBot is made to operate as a swarm, here is how you can deploy it on real robots.
Minimal hardware setup:
- DotBot v3, as well as a USB-C cable and a barrel-jack charger (2.5 mm, 6–18 V, 5/10 A)
- nRF5340-DK to use as gateway, as well as a micro-USB cable
Software to install (as needed):
- Python ≥ 3.11 - ensure you also have pip available in your PATH
- nRF Command Line Tools (
nrfjprog), for commands such asdotbot device flash
To operate as a swarm, set your swarm connection config:
dotbot config init --conn mqtts://argus.paris.inria.fr:8883 --swarm-id 1234
--connis your MQTT broker and--swarm-ida 16-bit hex id that identifies your swarm. Running your own handful of DotBots? Pick any swarm id - the example points--connat our Inria Paris broker so it works out of the box, but swap in your own broker once you have one. (On a shared testbed, your admin gives you the broker and swarm id to use.) This writes./dotbot.toml; commands run from this directory pick it up, so you don't repeat the flags. Full schema: the configuration reference.
The swarm mode also requires a special "sandbox" firmware in each DotBot. We also need a more powerful gateway firmware. Let's flash both - the network id comes from your config:
dotbot fw fetch # pull the pinned pre-compiled firmwares (swarmit + dotbot-firmware)
dotbot device flash-mari-gateway --probe 10 # flash the gateway
dotbot device flash-swarmit-sandbox --probe 77 # the sandbox firmware - do this on each DotBot(device flash-mari-gateway / flash-swarmit-sandbox auto-fetch
the firmware into ~/.dotbot/artifacts/ if it isn't already there.)
Now, run the gateway (the broker comes from your config):
dotbot run gateway -p /dev/cu.usbmodem0010500324491You can flash as many DotBots as you want, all at once! First, how about making them spinnnn 🔄 🔄
# flash the whole fleet with a simple spinning app
# the -ys flags confirms (y) the flash,
# and tell the app to start (s) right away after flashing is done
dotbot swarm flash spin -ys(dotbot swarm reads the same dotbot.toml as the rest - pass --conn /
--swarm-id to override it for one run. spin is a bundled app name -
dotbot swarm flash --list shows them all, and an explicit .bin path still
works. Names resolve to what dotbot fw fetch cached; dotbot fw list shows
the exact paths and versions on your machine.)
Then, flash another experiment:
dotbot swarm stop # ensure all DotBots are in bootloader
dotbot swarm flash rc-car -ys # this firmware lets DotBots be remote-controlledObserve and control your swarm from a web interface:
dotbot run controller # opens a webpage at http://localhost:8000/PyDotBot/Full walkthrough of fleet operations - status, OTA flash, start/stop, monitor -
is in the swarm reference.
Give the DotBots real-world (x, y) with Lighthouse 2. It's a two-step flow:
collect a calibration from one DotBot over the air, then push it to the
whole fleet - a single DotBot's capture calibrates the shared arena. This needs
the [calibrate] extra (opencv, for the homography solve):
pip install 'pydotbot[calibrate]'First, collect from one DotBot. Get its address from dotbot swarm status (the
Device Addr column):
dotbot swarm status # pick one Device Addr, e.g., BDF2B04BC00D2725
dotbot swarm stop # DotBots must be idle to capture
dotbot swarm lh2-calibration collect --device <addr> -d 500 # capture + solve + save-d is your reference square's side, in mm. This saves a
~/.dotbot/calibrations/calibration-<UTC>.toml. Then push that file to the
whole fleet:
dotbot swarm lh2-calibration push ~/.dotbot/calibrations/calibration-<UTC>.tomlFull walkthrough - arena sizing and the cabled alternative - is in the LH2 calibration guide.
- Drive a single DotBot end to end - build, flash, and control one DotBot: the one-bot guide.
- Position tracking with Lighthouse 2 - give the fleet real-world
(x, y), calibrated over the air: the LH2 calibration guide (a cabled alternative is covered there too). - The controller + web UI - drive and visualize a swarm from the browser: the controller guide.
- Build firmware from source instead of
dotbot fw fetch- needs SEGGER Embedded Studio and a DotBot-firmware checkout:thengit clone --recurse-submodules --branch develop https://github.com/DotBots/DotBot-firmware.git export DOTBOT_FIRMWARE_REPO=$(pwd)/DotBot-firmware
dotbot fw build/dotbot fw artifacts(seefw). - Everything else - the full
dotbotCLI (fw/device/swarm/runconfig), the REST/WS and MQTT surfaces, and hardware notes: the documentation.
Hitting a snag (e.g. the web UI not loading in Firefox)? See Troubleshooting.
To run the tests, run tox:
tox
See LICENSE in each component repository.