pub struct Engulfing { /* private fields */ }Expand description
Engulfing — a 2-bar reversal pattern. The current candle’s body fully engulfs the prior candle’s body and points in the opposite direction.
prev_body = |prev.close − prev.open|
curr_body = |curr.close − curr.open|
bullish = prev red & curr green
& curr.open <= prev.close & curr.close >= prev.open
& curr_body > prev_body
bearish = prev green & curr red
& curr.open >= prev.close & curr.close <= prev.open
& curr_body > prev_bodyOutput is +1.0 for a bullish engulfing, −1.0 for a bearish one, and
0.0 otherwise. The first bar always returns 0.0 because no previous
body exists to engulf. Pattern-shape check only — no trend filter is
applied; combine with a trend indicator for actionable signals.
§Signed ±1 encoding
This detector already emits the uniform candlestick sign convention shared
across the pattern family — +1.0 bullish, −1.0 bearish, 0.0 no
pattern — so it drops straight into a machine-learning feature matrix where
the bullish and bearish variants of the pattern occupy a single dimension.
§Example
use wickra_core::{Candle, Engulfing, Indicator};
let mut indicator = Engulfing::new();
// Prior red candle followed by a larger green engulfing candle.
indicator.update(Candle::new(11.0, 11.2, 9.8, 10.0, 1.0, 0).unwrap());
let out = indicator
.update(Candle::new(9.5, 12.0, 9.5, 11.5, 1.0, 1).unwrap());
assert_eq!(out, Some(1.0));Implementations§
Trait Implementations§
Source§impl Indicator for Engulfing
impl Indicator for Engulfing
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 Engulfing
impl RefUnwindSafe for Engulfing
impl Send for Engulfing
impl Sync for Engulfing
impl Unpin for Engulfing
impl UnsafeUnpin for Engulfing
impl UnwindSafe for Engulfing
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