nautilus_indicators/python/average/
ama.rsuse nautilus_model::{
data::{Bar, QuoteTick, TradeTick},
enums::PriceType,
};
use pyo3::prelude::*;
use crate::{
average::ama::AdaptiveMovingAverage,
indicator::{Indicator, MovingAverage},
};
#[pymethods]
impl AdaptiveMovingAverage {
#[new]
#[pyo3(signature = (period_efficiency_ratio, period_fast, period_slow, price_type=None))]
#[must_use]
pub fn py_new(
period_efficiency_ratio: usize,
period_fast: usize,
period_slow: usize,
price_type: Option<PriceType>,
) -> Self {
Self::new(
period_efficiency_ratio,
period_fast,
period_slow,
price_type,
)
}
fn __repr__(&self) -> String {
format!(
"WeightedMovingAverage({}({},{},{})",
self.name(),
self.period_efficiency_ratio,
self.period_fast,
self.period_slow
)
}
#[getter]
#[pyo3(name = "name")]
fn py_name(&self) -> String {
self.name()
}
#[getter]
#[pyo3(name = "count")]
const 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);
}
}