nautilus_indicators/python/average/
ema.rs

1// -------------------------------------------------------------------------------------------------
2//  Copyright (C) 2015-2025 Nautech Systems Pty Ltd. All rights reserved.
3//  https://nautechsystems.io
4//
5//  Licensed under the GNU Lesser General Public License Version 3.0 (the "License");
6//  You may not use this file except in compliance with the License.
7//  You may obtain a copy of the License at https://www.gnu.org/licenses/lgpl-3.0.en.html
8//
9//  Unless required by applicable law or agreed to in writing, software
10//  distributed under the License is distributed on an "AS IS" BASIS,
11//  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12//  See the License for the specific language governing permissions and
13//  limitations under the License.
14// -------------------------------------------------------------------------------------------------
15
16use nautilus_model::{
17    data::{Bar, QuoteTick, TradeTick},
18    enums::PriceType,
19};
20use pyo3::prelude::*;
21
22use crate::{
23    average::ema::ExponentialMovingAverage,
24    indicator::{Indicator, MovingAverage},
25};
26
27#[pymethods]
28impl ExponentialMovingAverage {
29    #[new]
30    #[pyo3(signature = (period, price_type=None))]
31    fn py_new(period: usize, price_type: Option<PriceType>) -> Self {
32        Self::new(period, price_type)
33    }
34
35    fn __repr__(&self) -> String {
36        format!("ExponentialMovingAverage({})", self.period)
37    }
38
39    #[getter]
40    #[pyo3(name = "name")]
41    fn py_name(&self) -> String {
42        self.name()
43    }
44
45    #[getter]
46    #[pyo3(name = "period")]
47    const fn py_period(&self) -> usize {
48        self.period
49    }
50
51    #[getter]
52    #[pyo3(name = "alpha")]
53    const fn py_alpha(&self) -> f64 {
54        self.alpha
55    }
56
57    #[getter]
58    #[pyo3(name = "count")]
59    const fn py_count(&self) -> usize {
60        self.count
61    }
62
63    #[getter]
64    #[pyo3(name = "value")]
65    const fn py_value(&self) -> f64 {
66        self.value
67    }
68
69    #[getter]
70    #[pyo3(name = "has_inputs")]
71    fn py_has_inputs(&self) -> bool {
72        self.has_inputs()
73    }
74
75    #[getter]
76    #[pyo3(name = "initialized")]
77    const fn py_initialized(&self) -> bool {
78        self.initialized
79    }
80
81    #[pyo3(name = "handle_quote_tick")]
82    fn py_handle_quote_tick(&mut self, quote: &QuoteTick) {
83        self.py_update_raw(quote.extract_price(self.price_type).into());
84    }
85
86    #[pyo3(name = "handle_trade_tick")]
87    fn py_handle_trade_tick(&mut self, trade: &TradeTick) {
88        self.update_raw((&trade.price).into());
89    }
90
91    #[pyo3(name = "handle_bar")]
92    fn py_handle_bar(&mut self, bar: &Bar) {
93        self.update_raw((&bar.close).into());
94    }
95
96    #[pyo3(name = "reset")]
97    fn py_reset(&mut self) {
98        self.reset();
99    }
100
101    #[pyo3(name = "update_raw")]
102    fn py_update_raw(&mut self, value: f64) {
103        self.update_raw(value);
104    }
105}