use crate::candle_indicators::{
common::cdl_total_wick_length,
pattern_test::EmaState,
registry::CandleBits,
types::{CandleInfo, ForecastType},
};
use tulip_rs_macros::pattern_template;
use super::{FIRST, SECOND, THIRD};
pub fn info() -> CandleInfo {
CandleInfo {
name: "advanceblock",
full_name: "Advance Block",
forecast: ForecastType::BearishReversal,
bars: 3,
extended_pattern: None,
japanese_name: "Sakizumari",
}
}
#[pattern_template(
name = "AdvanceBlock",
forecast = "BearishReversal",
prev_bar(trend = "UP"),
bar(
colour = "GREEN",
fill = "HALLOW",
line_height = "LONG",
candle_type = "Basic(WhiteCandle | LongWhiteCandle) Marubozu(OpeningWhiteMarubozu | ClosingWhiteMarubozu | WhiteMarubozu)"
),
bar(
colour = "GREEN",
fill = "HALLOW",
open_in_prev_body = "TRUE",
close_in_prev_body = "FALSE",
close_above_prev_mid = "TRUE",
body_gt_prev_body = "FALSE"
),
bar(
colour = "GREEN",
fill = "HALLOW",
open_in_prev_body = "TRUE",
close_in_prev_body = "FALSE",
close_above_prev_mid = "TRUE",
body_gt_prev_body = "FALSE"
)
)]
pub fn calc(
inputs: (&[f64], &[f64], &[f64], &[f64]),
_state: &EmaState,
_bars: &[CandleBits],
) -> bool {
let (open, high, low, close) = inputs;
let first_wick = cdl_total_wick_length(open[FIRST], high[FIRST], low[FIRST], close[FIRST]);
if !(first_wick < cdl_total_wick_length(open[SECOND], high[SECOND], low[SECOND], close[SECOND]))
|| !(first_wick < cdl_total_wick_length(open[THIRD], high[THIRD], low[THIRD], close[THIRD]))
{
return false;
}
true
}