1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
use serde::{Deserialize, Serialize};
#[derive(Deserialize, Serialize, Debug, Clone)]
pub struct Ema {
ema: f64,
k: f64,
}
impl Ema {
pub fn new(initial: f64, period: u32) -> Self {
let k = 2.0 / (period as f64 + 1.0);
Self { ema: initial, k }
}
pub fn update(&mut self, value: f64) {
self.ema = value * self.k + self.ema * (1.0 - self.k);
}
pub fn value(&self) -> f64 {
self.ema
}
}