quantwave_core/regimes/
ensemble.rs1use crate::regimes::MarketRegime;
7use serde::{Deserialize, Serialize};
8
9#[derive(Debug, Clone, Serialize, Deserialize)]
11pub struct RegimeEnsemble {
12 pub weights: Vec<f64>,
13}
14
15impl RegimeEnsemble {
16 pub fn new(weights: Vec<f64>) -> Self {
17 Self { weights }
18 }
19
20 pub fn vote(&self, regimes: &[MarketRegime]) -> MarketRegime {
25 if regimes.is_empty() { return MarketRegime::Steady; }
26
27 let mut scores: std::collections::HashMap<MarketRegime, f64> = std::collections::HashMap::new();
28
29 for (i, ®ime) in regimes.iter().enumerate() {
30 let weight = self.weights.get(i).unwrap_or(&1.0);
31 *scores.entry(regime).or_insert(0.0) += weight;
32 }
33
34 scores.into_iter()
36 .max_by(|a, b| a.1.partial_cmp(&b.1).unwrap_or(std::cmp::Ordering::Equal))
37 .map(|(regime, _)| regime)
38 .unwrap_or(MarketRegime::Steady)
39 }
40}