Implement 6 optional enhancements for the wifi-Mat module: 1. Hardware Integration (csi_receiver.rs + hardware_adapter.rs) - ESP32 CSI support via serial/UDP - Intel 5300 BFEE file parsing - Atheros CSI Tool integration - Live UDP packet streaming - PCAP replay capability 2. CLI Commands (wifi-densepose-cli/src/mat.rs) - `wifi-mat scan` - Run disaster detection scan - `wifi-mat status` - Check event status - `wifi-mat zones` - Manage scan zones - `wifi-mat survivors` - List detected survivors - `wifi-mat alerts` - View and acknowledge alerts - `wifi-mat export` - Export data in various formats 3. REST API (wifi-densepose-mat/src/api/) - Full CRUD for disaster events - Zone management endpoints - Survivor and alert queries - WebSocket streaming for real-time updates - Comprehensive DTOs and error handling 4. WASM Build (wifi-densepose-wasm/src/mat.rs) - Browser-based disaster dashboard - Real-time survivor tracking - Zone visualization - Alert management - JavaScript API bindings 5. Detection Benchmarks (benches/detection_bench.rs) - Single survivor detection - Multi-survivor detection - Full pipeline benchmarks - Signal processing benchmarks - Hardware adapter benchmarks 6. ML Models for Debris Penetration (ml/) - DebrisModel for material analysis - VitalSignsClassifier for triage - FFT-based feature extraction - Bandpass filtering - Monte Carlo dropout for uncertainty All 134 unit tests pass. Compilation verified for: - wifi-densepose-mat - wifi-densepose-cli - wifi-densepose-wasm (with mat feature)
133 lines
3.8 KiB
Rust
133 lines
3.8 KiB
Rust
//! WiFi-DensePose WebAssembly bindings
|
|
//!
|
|
//! This crate provides WebAssembly bindings for browser-based applications using
|
|
//! WiFi-DensePose technology. It includes:
|
|
//!
|
|
//! - **mat**: WiFi-Mat disaster response dashboard module for browser integration
|
|
//!
|
|
//! # Features
|
|
//!
|
|
//! - `mat` - Enable WiFi-Mat disaster detection WASM bindings
|
|
//! - `console_error_panic_hook` - Better panic messages in browser console
|
|
//!
|
|
//! # Building for WASM
|
|
//!
|
|
//! ```bash
|
|
//! # Build with wasm-pack
|
|
//! wasm-pack build --target web --features mat
|
|
//!
|
|
//! # Or with cargo
|
|
//! cargo build --target wasm32-unknown-unknown --features mat
|
|
//! ```
|
|
//!
|
|
//! # Example Usage (JavaScript)
|
|
//!
|
|
//! ```javascript
|
|
//! import init, { MatDashboard, initLogging } from './wifi_densepose_wasm.js';
|
|
//!
|
|
//! async function main() {
|
|
//! await init();
|
|
//! initLogging('info');
|
|
//!
|
|
//! const dashboard = new MatDashboard();
|
|
//!
|
|
//! // Create a disaster event
|
|
//! const eventId = dashboard.createEvent('earthquake', 37.7749, -122.4194, 'Bay Area Earthquake');
|
|
//!
|
|
//! // Add scan zones
|
|
//! dashboard.addRectangleZone('Building A', 50, 50, 200, 150);
|
|
//! dashboard.addCircleZone('Search Area B', 400, 200, 80);
|
|
//!
|
|
//! // Subscribe to events
|
|
//! dashboard.onSurvivorDetected((survivor) => {
|
|
//! console.log('Survivor detected:', survivor);
|
|
//! updateUI(survivor);
|
|
//! });
|
|
//!
|
|
//! dashboard.onAlertGenerated((alert) => {
|
|
//! showNotification(alert);
|
|
//! });
|
|
//!
|
|
//! // Render to canvas
|
|
//! const canvas = document.getElementById('map');
|
|
//! const ctx = canvas.getContext('2d');
|
|
//!
|
|
//! function render() {
|
|
//! ctx.clearRect(0, 0, canvas.width, canvas.height);
|
|
//! dashboard.renderZones(ctx);
|
|
//! dashboard.renderSurvivors(ctx);
|
|
//! requestAnimationFrame(render);
|
|
//! }
|
|
//! render();
|
|
//! }
|
|
//!
|
|
//! main();
|
|
//! ```
|
|
|
|
use wasm_bindgen::prelude::*;
|
|
|
|
// WiFi-Mat module for disaster response dashboard
|
|
pub mod mat;
|
|
pub use mat::*;
|
|
|
|
/// Initialize the WASM module.
|
|
/// Call this once at startup before using any other functions.
|
|
#[wasm_bindgen(start)]
|
|
pub fn init() {
|
|
// Set panic hook for better error messages in browser console
|
|
#[cfg(feature = "console_error_panic_hook")]
|
|
console_error_panic_hook::set_once();
|
|
}
|
|
|
|
/// Initialize logging with specified level.
|
|
///
|
|
/// @param {string} level - Log level: "trace", "debug", "info", "warn", "error"
|
|
#[wasm_bindgen(js_name = initLogging)]
|
|
pub fn init_logging(level: &str) {
|
|
let log_level = match level.to_lowercase().as_str() {
|
|
"trace" => log::Level::Trace,
|
|
"debug" => log::Level::Debug,
|
|
"info" => log::Level::Info,
|
|
"warn" => log::Level::Warn,
|
|
"error" => log::Level::Error,
|
|
_ => log::Level::Info,
|
|
};
|
|
|
|
let _ = wasm_logger::init(wasm_logger::Config::new(log_level));
|
|
log::info!("WiFi-DensePose WASM initialized with log level: {}", level);
|
|
}
|
|
|
|
/// Get the library version.
|
|
///
|
|
/// @returns {string} Version string
|
|
#[wasm_bindgen(js_name = getVersion)]
|
|
pub fn get_version() -> String {
|
|
env!("CARGO_PKG_VERSION").to_string()
|
|
}
|
|
|
|
/// Check if the MAT feature is enabled.
|
|
///
|
|
/// @returns {boolean} True if MAT module is available
|
|
#[wasm_bindgen(js_name = isMatEnabled)]
|
|
pub fn is_mat_enabled() -> bool {
|
|
true
|
|
}
|
|
|
|
/// Get current timestamp in milliseconds (for performance measurements).
|
|
///
|
|
/// @returns {number} Timestamp in milliseconds
|
|
#[wasm_bindgen(js_name = getTimestamp)]
|
|
pub fn get_timestamp() -> f64 {
|
|
let window = web_sys::window().expect("no global window");
|
|
let performance = window.performance().expect("no performance object");
|
|
performance.now()
|
|
}
|
|
|
|
// Re-export all public types from mat module for easy access
|
|
pub mod types {
|
|
pub use super::mat::{
|
|
JsAlert, JsAlertPriority, JsDashboardStats, JsDisasterType, JsScanZone, JsSurvivor,
|
|
JsTriageStatus, JsZoneStatus,
|
|
};
|
|
}
|