rust-port/wifi-densepose-rs/crates/wifi-densepose-wifiscan/README.md
Multi-BSSID WiFi scanning for Windows-enhanced DensePose sensing (ADR-022).
wifi-densepose-wifiscan implements the BSSID Acquisition bounded context for the WiFi-DensePose
system. It discovers and tracks nearby WiFi access points, parses platform-specific scan output,
and feeds multi-AP signal data into a sensing pipeline that performs motion detection, breathing
estimation, attention weighting, and fingerprint matching.
The crate uses #[forbid(unsafe_code)] and is designed as a pure-Rust domain layer with
pluggable platform adapters.
BssidId, BssidObservation, BssidRegistry,
BssidEntry.netsh wlan show networks mode=bssid output into
structured BssidObservation records. Zero platform dependencies.wlanapi feature) -- Async scanning via the Windows WLAN API
with tokio integration.MultiApFrame aggregates observations from multiple BSSIDs into a single
timestamped frame for downstream processing.pipeline feature) -- WindowsWifiPipeline orchestrates motion
detection, breathing estimation, attention-weighted AP selection, and location fingerprint
matching.| Flag | Default | Description |
|---|---|---|
serde | yes | Serialization for domain types |
pipeline | yes | WindowsWifiPipeline sensing orchestration |
wlanapi | no | Tier 2 async scanning via tokio (Windows WLAN API) |
use wifi_densepose_wifiscan::{
NetshBssidScanner, BssidRegistry, WlanScanPort,
};
// Parse netsh output (works on any platform for testing)
let netsh_output = "..."; // output of `netsh wlan show networks mode=bssid`
let observations = wifi_densepose_wifiscan::parse_netsh_output(netsh_output);
// Register observations
let mut registry = BssidRegistry::new();
for obs in &observations {
registry.update(obs);
}
println!("Tracking {} access points", registry.len());
With the pipeline feature enabled:
use wifi_densepose_wifiscan::WindowsWifiPipeline;
let pipeline = WindowsWifiPipeline::new();
// Feed MultiApFrame data into the pipeline for sensing...
wifi-densepose-wifiscan/src/
lib.rs -- Re-exports, feature gates
domain/
bssid.rs -- BssidId, BssidObservation, BandType, RadioType
registry.rs -- BssidRegistry, BssidEntry, BssidMeta, RunningStats
frame.rs -- MultiApFrame (multi-BSSID aggregated frame)
result.rs -- EnhancedSensingResult
port.rs -- WlanScanPort trait (platform abstraction)
adapter.rs -- NetshBssidScanner (Tier 1), WlanApiScanner (Tier 2)
pipeline.rs -- WindowsWifiPipeline (motion, breathing, attention, fingerprint)
error.rs -- WifiScanError
| Crate | Role |
|---|---|
wifi-densepose-signal | Advanced CSI signal processing |
wifi-densepose-vitals | Vital sign extraction from CSI |
wifi-densepose-hardware | ESP32 and other hardware interfaces |
wifi-densepose-mat | Disaster detection using multi-AP data |
MIT OR Apache-2.0