pub struct AtrTrailingStop { /* private fields */ }Expand description
ATR Trailing Stop — a stop level that trails price by a fixed ATR multiple and ratchets in the direction of the trend.
loss = multiplier · ATR
stop_t = max(stop_{t−1}, close − loss) while price holds above the stop
= min(stop_{t−1}, close + loss) while price holds below the stop
= close − loss on a fresh break above the stop
= close + loss on a fresh break below the stopWhile price stays on one side of the stop the level only ratchets toward
price — up in an uptrend, down in a downtrend — never away from it. When a
close crosses the stop the level snaps to the opposite side, loss away
from the new close, flipping the trade. This is the trailing stop used by
the well-known “UT Bot”; the first ATR-ready bar seeds the stop below
price (a long).
§Example
use wickra_core::{Candle, Indicator, AtrTrailingStop};
let mut indicator = AtrTrailingStop::new(14, 3.0).unwrap();
let mut last = None;
for i in 0..80 {
let base = 100.0 + f64::from(i);
let candle =
Candle::new(base, base + 2.0, base - 2.0, base + 1.0, 10.0, i64::from(i)).unwrap();
last = indicator.update(candle);
}
assert!(last.is_some());Implementations§
Source§impl AtrTrailingStop
impl AtrTrailingStop
Sourcepub fn new(atr_period: usize, multiplier: f64) -> Result<Self>
pub fn new(atr_period: usize, multiplier: f64) -> Result<Self>
Construct an ATR Trailing Stop with an explicit ATR period and multiple.
§Errors
Returns Error::PeriodZero if atr_period == 0 and
Error::NonPositiveMultiplier if multiplier is not strictly
positive and finite.
Trait Implementations§
Source§impl Clone for AtrTrailingStop
impl Clone for AtrTrailingStop
Source§fn clone(&self) -> AtrTrailingStop
fn clone(&self) -> AtrTrailingStop
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for AtrTrailingStop
impl Debug for AtrTrailingStop
Source§impl Indicator for AtrTrailingStop
impl Indicator for AtrTrailingStop
Source§type Input = Candle
type Input = Candle
Type of one input data point (typically
f64 for a price, or Candle / Tick).Source§fn update(&mut self, candle: Candle) -> Option<f64>
fn update(&mut self, candle: Candle) -> Option<f64>
Feed one new data point into the indicator and return the freshly computed
output, or
None if the indicator is still warming up.Source§fn reset(&mut self)
fn reset(&mut self)
Reset all internal state, leaving the indicator equivalent to a freshly
constructed instance with the same parameters.
Source§fn warmup_period(&self) -> usize
fn warmup_period(&self) -> usize
Number of inputs required before the first non-
None output can be produced.Auto Trait Implementations§
impl Freeze for AtrTrailingStop
impl RefUnwindSafe for AtrTrailingStop
impl Send for AtrTrailingStop
impl Sync for AtrTrailingStop
impl Unpin for AtrTrailingStop
impl UnsafeUnpin for AtrTrailingStop
impl UnwindSafe for AtrTrailingStop
Blanket Implementations§
Source§impl<T> BatchExt for Twhere
T: Indicator,
impl<T> BatchExt for Twhere
T: Indicator,
Source§fn batch(&mut self, inputs: &[Self::Input]) -> Vec<Option<Self::Output>>
fn batch(&mut self, inputs: &[Self::Input]) -> Vec<Option<Self::Output>>
Run the indicator over a slice of inputs in order, returning one output (or
None during warmup) per input.Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more