nautilus_indicators/python/average/
vidya.rsuse nautilus_model::{
data::{bar::Bar, quote::QuoteTick, trade::TradeTick},
enums::PriceType,
};
use pyo3::prelude::*;
use crate::{
average::{vidya::VariableIndexDynamicAverage, MovingAverageType},
indicator::{Indicator, MovingAverage},
};
#[pymethods]
impl VariableIndexDynamicAverage {
#[new]
#[pyo3(signature = (period, price_type=None, cmo_ma_type=None))]
#[must_use]
pub fn py_new(
period: usize,
price_type: Option<PriceType>,
cmo_ma_type: Option<MovingAverageType>,
) -> Self {
Self::new(period, price_type, cmo_ma_type)
}
fn __repr__(&self) -> String {
format!(
"VariableIndexDynamicAverage({},{:?})",
self.period, self.price_type
)
}
#[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 = "alpha")]
const fn py_alpha(&self) -> f64 {
self.alpha
}
#[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
}
#[getter]
#[pyo3(name = "cmo_pct")]
const fn py_cmo_pct(&self) -> f64 {
self.cmo_pct
}
#[getter]
#[pyo3(name = "value")]
const fn py_value(&self) -> f64 {
self.value
}
#[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);
}
}