5.1 KiB
5.1 KiB
wifi-densepose-swarm
Drone swarm control system for the RuView wifi-densepose workspace. Implements ADR-148.
Overview
wifi-densepose-swarm provides a hierarchical-mesh drone swarm coordination system
with Raft consensus, MAPPO-based multi-agent reinforcement learning, and tight
integration with the existing WiFi CSI sensing pipeline (wifi-densepose-signal,
wifi-densepose-ruvector).
Features
- Hierarchical-Mesh Topology — cluster heads over Raft consensus; inter-cluster Gossip for map dissemination
- Formation Control — F1 VirtualStructure, F2 LeaderFollower, F3 Reynolds flocking
- 3-Phase Coverage — boustrophedon sweep → Bayesian probability grid → multi-drone triangulation
- RRT-APF Path Planner — RRT* with Artificial Potential Field reactive collision avoidance
- MARL Actor (MAPPO) — 64-dim local observation, 3-layer MLP actor, CTDE training interface
- CSI Sensing Integration — drone payload pipeline (ESP32-S3 → Jetson), multi-drone CSI fusion
- OccWorld Bridge — integrates ADR-147 OccWorld occupancy prior as path planner environment
- Security Hardening — MAVLink v2 HMAC-SHA256 signing, UWB GPS anti-spoofing, onboard geofencing, Remote ID
- Fail-Safe State Machine — 10-state onboard safety system, GCS-independent
- Demo & Training Modes — synthetic CSI generation, Gazebo/PX4 SITL interface, TOML mission configs
ITAR Notice
⚠️ Export-controlled capability. Swarming coordination features (formation control, Raft consensus, task allocation) are gated behind the
itar-unrestrictedfeature flag per USML Category VIII(h)(12). Default builds compile only safe stubs. Do not enableitar-unrestrictedfor international distribution without export counsel review.
Crate Features
| Feature | Description |
|---|---|
default |
Core types, sensing, failsafe, config, MARL — no ITAR-gated code |
itar-unrestricted |
Enables formation control, Raft consensus, task allocation |
mavlink |
MAVLink v2 protocol support |
onnx |
ONNX Runtime backend for MARL actor inference (INT8) |
simulation |
Simulation-mode stubs |
demo |
Synthetic CSI generation, scenario runners |
full |
All of the above |
Quick Start
use wifi_densepose_swarm::{config::SwarmConfig, demo::scenario::DemoScenario};
// Load a mission profile
let config = SwarmConfig::sar_default();
// Run a demo scenario
let scenario = DemoScenario::sar_rubble_field(4); // 4-drone SAR
let estimated_secs = scenario.estimate_coverage_time_secs();
// → < 240 s for 4 drones over 400×400 m (beyond Wi2SAR SOTA single-drone baseline)
Mission Profiles
| Profile | Drones | Area | Application |
|---|---|---|---|
sar |
6–12 | 400×400 m | Structural collapse victim search |
inspection |
3–6 | Linear corridor | Infrastructure (power lines, bridges) |
agriculture |
4–12 | Field-configurable | NDVI mapping, variable-rate spraying |
mine |
2–4 | Tunnel | GPS-denied underground exploration |
relay |
6–20 | Perimeter | Emergency telecom relay chain |
demo |
Any | Configurable | Synthetic CSI, configurable victims |
Module Structure
src/
├── types.rs — NodeId, DroneState, SwarmTask, SwarmError, FailSafeState
├── topology/ — Raft consensus¹, Gossip dissemination, MeshTopology
├── formation/ — VirtualStructure¹, LeaderFollower¹, Reynolds flocking¹
├── planning/ — RRT-APF planner, 3-phase coverage, Bayesian grid, pheromone
├── allocation/ — Auction-based task allocation¹, FNN bid scorer¹
├── sensing/ — CSI payload pipeline, multi-drone fusion, OccWorld bridge
├── marl/ — MAPPO actor, LocalObservation, reward shaping, TrainingConfig
├── security/ — MAVLink signing, UWB anti-spoofing, geofencing, Remote ID
├── failsafe/ — 10-state onboard fail-safe machine
├── config/ — TOML SwarmConfig with mission presets
├── demo/ — Synthetic CSI, DemoScenario runners
├── integration/ — FlightController trait (PX4/ArduPilot/Sim)
└── bench_support.rs — Criterion fixture generators
¹ Requires `itar-unrestricted` feature.
Related ADRs
| ADR | Title | Relation |
|---|---|---|
| ADR-148 | Drone Swarm Control System | This crate |
| ADR-147 | OccWorld Occupancy World Model | Environment prior via sensing::occworld_bridge |
| ADR-134 | CSI→CIR ISTA Sparse Recovery | Drone payload sensing |
| ADR-146 | RF Encoder Multitask Heads | Drone payload inference |
| ADR-016 | RuVector Training Integration | CrossViewpointAttention |
Performance Targets (vs. Wi2SAR SOTA)
| Metric | Wi2SAR baseline (1 drone) | 4-drone target |
|---|---|---|
| Coverage | 160,000 m² | 160,000 m² |
| Time | 13.5 min | ≤ 4 min |
| Localization | 5 m | ≤ 2 m (3-view fusion) |
| MARL inference | N/A | ≤ 5 ms (INT8, release) |
| Raft election | N/A | ≤ 300 ms |