nautilus_indicators/python/average/
wma.rsuse nautilus_core::python::to_pyvalue_err;
use nautilus_model::{
data::{bar::Bar, quote::QuoteTick, trade::TradeTick},
enums::PriceType,
};
use pyo3::prelude::*;
use crate::{
average::wma::WeightedMovingAverage,
indicator::{Indicator, MovingAverage},
};
#[pymethods]
impl WeightedMovingAverage {
#[new]
#[pyo3(signature = (period, weights, price_type=None))]
pub fn py_new(
period: usize,
weights: Vec<f64>,
price_type: Option<PriceType>,
) -> PyResult<Self> {
Self::new_checked(period, weights, price_type).map_err(to_pyvalue_err)
}
fn __repr__(&self) -> String {
format!("WeightedMovingAverage({},{:?})", self.period, self.weights)
}
#[getter]
#[pyo3(name = "name")]
fn py_name(&self) -> String {
self.name()
}
#[getter]
#[pyo3(name = "period")]
const fn py_period(&self) -> usize {
self.period
}
#[getter]
#[pyo3(name = "count")]
fn py_count(&self) -> usize {
self.count()
}
#[getter]
#[pyo3(name = "has_inputs")]
fn py_has_inputs(&self) -> bool {
self.has_inputs()
}
#[getter]
#[pyo3(name = "initialized")]
const fn py_initialized(&self) -> bool {
self.initialized
}
#[pyo3(name = "handle_quote_tick")]
fn py_handle_quote_tick(&mut self, quote: &QuoteTick) {
self.py_update_raw(quote.extract_price(self.price_type).into());
}
#[pyo3(name = "handle_trade_tick")]
fn py_handle_trade_tick(&mut self, trade: &TradeTick) {
self.update_raw((&trade.price).into());
}
#[pyo3(name = "handle_bar")]
fn py_handle_bar(&mut self, bar: &Bar) {
self.update_raw((&bar.close).into());
}
#[pyo3(name = "reset")]
fn py_reset(&mut self) {
self.reset();
}
#[pyo3(name = "update_raw")]
fn py_update_raw(&mut self, value: f64) {
self.update_raw(value);
}
}