pub struct Doji { /* private fields */ }Expand description
Doji — a candle whose body is negligible relative to its range.
A Doji prints whenever the absolute distance between open and close is
small compared to the total high − low range. It is the canonical
indecision bar and a building block for many three-bar reversal patterns.
body = |close − open|
range = high − low
doji = body <= body_threshold * range§Signed ±1 encoding
By default the output is +1.0 when a Doji is detected and 0.0
otherwise — a direction-less detection flag. For a drop-in machine-learning
feature where every candlestick pattern shares the same sign convention
(+1.0 bullish, −1.0 bearish, 0.0 none), switch the detector into
signed mode with Doji::signed. A detected Doji is then classified by
where its (negligible) body sits within the bar’s range:
pos = (0.5 * (open + close) − low) / (high − low)
pos > 2/3 -> +1.0 dragonfly (long lower shadow, bullish)
pos < 1/3 -> −1.0 gravestone (long upper shadow, bearish)
else -> 0.0 long-legged / standard (neutral)Pattern-shape check only — no trend filter is applied; combine with a trend indicator for actionable signals.
§Example
use wickra_core::{Candle, Doji, Indicator};
// Default: direction-less detection flag.
let mut indicator = Doji::default();
let candle = Candle::new(10.0, 11.0, 9.0, 10.0, 1.0, 0).unwrap();
assert_eq!(indicator.update(candle), Some(1.0));
// Signed: a dragonfly Doji (body at the top, long lower shadow) is bullish.
let mut signed = Doji::new().signed();
let dragonfly = Candle::new(10.0, 10.05, 6.0, 10.0, 1.0, 0).unwrap();
assert_eq!(signed.update(dragonfly), Some(1.0));Implementations§
Source§impl Doji
impl Doji
Sourcepub fn with_threshold(body_threshold: f64) -> Result<Self>
pub fn with_threshold(body_threshold: f64) -> Result<Self>
Construct a Doji detector with a custom body / range threshold.
body_threshold must lie in (0, 1].
Sourcepub fn signed(self) -> Self
pub fn signed(self) -> Self
Switch to the signed dragonfly / gravestone encoding (consuming builder).
In signed mode a detected Doji emits +1.0 (dragonfly, bullish),
−1.0 (gravestone, bearish) or 0.0 (long-legged / neutral) instead of
the default direction-less +1.0 detection flag. See the type-level
docs for the exact classification rule.
Sourcepub fn body_threshold(&self) -> f64
pub fn body_threshold(&self) -> f64
Configured body / range threshold.
Trait Implementations§
Source§impl Indicator for Doji
impl Indicator for Doji
Source§type Input = Candle
type Input = Candle
f64 for a price, or Candle / Tick).Source§fn update(&mut self, candle: Candle) -> Option<f64>
fn update(&mut self, candle: Candle) -> Option<f64>
None if the indicator is still warming up.Source§fn reset(&mut self)
fn reset(&mut self)
Source§fn warmup_period(&self) -> usize
fn warmup_period(&self) -> usize
None output can be produced.Auto Trait Implementations§
impl Freeze for Doji
impl RefUnwindSafe for Doji
impl Send for Doji
impl Sync for Doji
impl Unpin for Doji
impl UnsafeUnpin for Doji
impl UnwindSafe for Doji
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>>
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
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>
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>
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