feat(mat/tracking): add fingerprint re-ID + lib.rs integration (WIP)

- tracking/fingerprint.rs: CsiFingerprint for CSI-based survivor re-ID
  across signal gaps. Weighted normalized Euclidean distance on breathing
  rate, breathing amplitude, heartbeat rate, and location hint.
  EMA update (α=0.3) blends new observations into the fingerprint.

- lib.rs: fully integrated tracking bounded context
  - pub mod tracking added
  - TrackingEvent added to domain::events re-exports
  - pub use tracking::{SurvivorTracker, TrackerConfig, TrackId, ...}
  - DisasterResponse.tracker field + with_defaults() init
  - tracker()/tracker_mut() public accessors
  - prelude updated with tracking types

Remaining: tracking/tracker.rs (SurvivorTracker aggregate root)

https://claude.ai/code/session_0164UZu6rG6gA15HmVyLZAmU
This commit is contained in:
Claude
2026-03-01 07:54:28 +00:00
parent 01d42ad73f
commit fa4927ddbc
2 changed files with 354 additions and 2 deletions

View File

@@ -84,6 +84,7 @@ pub mod domain;
pub mod integration;
pub mod localization;
pub mod ml;
pub mod tracking;
// Re-export main types
pub use domain::{
@@ -97,7 +98,7 @@ pub use domain::{
},
triage::{TriageStatus, TriageCalculator},
coordinates::{Coordinates3D, LocationUncertainty, DepthEstimate},
events::{DetectionEvent, AlertEvent, DomainEvent, EventStore, InMemoryEventStore},
events::{DetectionEvent, AlertEvent, DomainEvent, EventStore, InMemoryEventStore, TrackingEvent},
};
pub use detection::{
@@ -141,6 +142,13 @@ pub use ml::{
UncertaintyEstimate, ClassifierOutput,
};
pub use tracking::{
SurvivorTracker, TrackerConfig, TrackId, TrackedSurvivor,
DetectionObservation, AssociationResult,
KalmanState, CsiFingerprint,
TrackState, TrackLifecycle,
};
/// Library version
pub const VERSION: &str = env!("CARGO_PKG_VERSION");
@@ -289,6 +297,7 @@ pub struct DisasterResponse {
alert_dispatcher: AlertDispatcher,
event_store: std::sync::Arc<dyn domain::events::EventStore>,
ensemble_classifier: EnsembleClassifier,
tracker: tracking::SurvivorTracker,
running: std::sync::atomic::AtomicBool,
}
@@ -312,6 +321,7 @@ impl DisasterResponse {
alert_dispatcher,
event_store,
ensemble_classifier,
tracker: tracking::SurvivorTracker::with_defaults(),
running: std::sync::atomic::AtomicBool::new(false),
}
}
@@ -335,6 +345,7 @@ impl DisasterResponse {
alert_dispatcher,
event_store,
ensemble_classifier,
tracker: tracking::SurvivorTracker::with_defaults(),
running: std::sync::atomic::AtomicBool::new(false),
}
}
@@ -372,6 +383,16 @@ impl DisasterResponse {
&self.detection_pipeline
}
/// Get the survivor tracker
pub fn tracker(&self) -> &tracking::SurvivorTracker {
&self.tracker
}
/// Get mutable access to the tracker (for integration in scan_cycle)
pub fn tracker_mut(&mut self) -> &mut tracking::SurvivorTracker {
&mut self.tracker
}
/// Initialize a new disaster event
pub fn initialize_event(
&mut self,
@@ -547,7 +568,7 @@ pub mod prelude {
Coordinates3D, Alert, Priority,
// Event sourcing
DomainEvent, EventStore, InMemoryEventStore,
DetectionEvent, AlertEvent,
DetectionEvent, AlertEvent, TrackingEvent,
// Detection
DetectionPipeline, VitalSignsDetector,
EnsembleClassifier, EnsembleConfig, EnsembleResult,
@@ -559,6 +580,8 @@ pub mod prelude {
MlDetectionConfig, MlDetectionPipeline, MlDetectionResult,
DebrisModel, MaterialType, DebrisClassification,
VitalSignsClassifier, UncertaintyEstimate,
// Tracking
SurvivorTracker, TrackerConfig, TrackId, DetectionObservation, AssociationResult,
};
}