PINE LIBRARY
Zaktualizowano

lib_smc

7 530
Library "lib_smc"
This is an adaptation of LuxAlgo's Smart Money Concepts indicator with numerous changes. Main changes include integration of object based plotting, plenty of performance improvements, live tracking of Order Blocks, integration of volume profiles to refine Order Blocks, and many more.

This is a library for developers, if you want this converted into a working strategy, let me know.

buffer(item, len, force_rotate)
  Parameters:
    item (float)
    len (int)
    force_rotate (bool)

buffer(item, len, force_rotate)
  Parameters:
    item (int)
    len (int)
    force_rotate (bool)

buffer(item, len, force_rotate)
  Parameters:
    item (Profile type from robbatt/lib_profile/32)
    len (int)
    force_rotate (bool)

swings(len)
  INTERNAL: detect swing points (HH and LL) in given range
  Parameters:
    len (simple int): range to check for new swing points
  Returns: [idx, hh, ll] values are the price level where and if a new HH or LL was detected, else na

method init(this)
  Namespace types: OrderBlockConfig
  Parameters:
    this (OrderBlockConfig)

method delete(this)
  Namespace types: OrderBlock
  Parameters:
    this (OrderBlock)

method clear_broken(this, broken_buffer)
  INTERNAL: delete internal order blocks box coordinates if top/bottom is broken
  Namespace types: map<int, OrderBlock>
  Parameters:
    this (map<int, OrderBlock>)
    broken_buffer (map<int, OrderBlock>)
  Returns: any_bull_ob_broken, any_bear_ob_broken, broken signals are true if an according order block was broken/mitigated, broken contains the broken block(s)

create_ob(id, mode, start_t, start_i, top, end_t, end_i, bottom, break_price, early_confirmation_price, config, init_plot, force_overlay)
  INTERNAL: set internal order block coordinates
  Parameters:
    id (int)
    mode (int): 1: bullish, -1 bearish block
    start_t (int)
    start_i (int)
    top (float)
    end_t (int)
    end_i (int)
    bottom (float)
    break_price (float)
    early_confirmation_price (float)
    config (OrderBlockConfig)
    init_plot (bool)
    force_overlay (bool)
  Returns: [any_bull_ob_broken, any_bear_ob_broken] signals are true if an according order block was broken/mitigated

method align_to_profile(block, align_edge, align_break_price)
  Namespace types: OrderBlock
  Parameters:
    block (OrderBlock)
    align_edge (bool)
    align_break_price (bool)

method create_profile(block, opens, tops, bottoms, closes, values, resolution, vah_pc, val_pc, args, init_calculated, init_plot, force_overlay)
  Namespace types: OrderBlock
  Parameters:
    block (OrderBlock)
    opens (array<float>)
    tops (array<float>)
    bottoms (array<float>)
    closes (array<float>)
    values (array<float>)
    resolution (int)
    vah_pc (float)
    val_pc (float)
    args (ProfileArgs type from robbatt/lib_profile/32)
    init_calculated (bool)
    init_plot (bool)
    force_overlay (bool)

method create_profile(block, resolution, vah_pc, val_pc, args, init_calculated, init_plot, force_overlay)
  Namespace types: OrderBlock
  Parameters:
    block (OrderBlock)
    resolution (int)
    vah_pc (float)
    val_pc (float)
    args (ProfileArgs type from robbatt/lib_profile/32)
    init_calculated (bool)
    init_plot (bool)
    force_overlay (bool)

track_obs(swing_len, hh, ll, top, btm, bull_bos_alert, bull_choch_alert, bear_bos_alert, bear_choch_alert, min_block_size, max_block_size, config_bull, config_bear, init_plot, force_overlay, enabled, extend_blocks, clear_broken_buffer_before, align_edge_to_value_area, align_break_price_to_poc, profile_args_bull, profile_args_bear, use_soft_confirm, soft_confirm_offset, use_retracements_with_FVG_out)
  Parameters:
    swing_len (int)
    hh (float)
    ll (float)
    top (float)
    btm (float)
    bull_bos_alert (bool)
    bull_choch_alert (bool)
    bear_bos_alert (bool)
    bear_choch_alert (bool)
    min_block_size (float)
    max_block_size (float)
    config_bull (OrderBlockConfig)
    config_bear (OrderBlockConfig)
    init_plot (bool)
    force_overlay (bool)
    enabled (bool)
    extend_blocks (simple bool)
    clear_broken_buffer_before (simple bool)
    align_edge_to_value_area (simple bool)
    align_break_price_to_poc (simple bool)
    profile_args_bull (ProfileArgs type from robbatt/lib_profile/32)
    profile_args_bear (ProfileArgs type from robbatt/lib_profile/32)
    use_soft_confirm (simple bool)
    soft_confirm_offset (float)
    use_retracements_with_FVG_out (simple bool)

method draw(this, config, extend_only)
  Namespace types: OrderBlock
  Parameters:
    this (OrderBlock)
    config (OrderBlockConfig)
    extend_only (bool)

method draw(blocks, config)
  INTERNAL: plot order blocks
  Namespace types: array<OrderBlock>
  Parameters:
    blocks (array<OrderBlock>)
    config (OrderBlockConfig)

method draw(blocks, config)
  INTERNAL: plot order blocks
  Namespace types: map<int, OrderBlock>
  Parameters:
    blocks (map<int, OrderBlock>)
    config (OrderBlockConfig)

method cleanup(this, ob_bull, ob_bear)
  removes all Profiles that are older than the latest OrderBlock from this profile buffer
  Namespace types: array<PF.Profile>
  Parameters:
    this (array<Profile> type from robbatt/lib_profile/32)
    ob_bull (OrderBlock)
    ob_bear (OrderBlock)

_plot_swing_points(mode, x, y, show_swing_points, linecolor_swings, keep_history, show_latest_swings_levels, trail_x, trail_y, trend)
  INTERNAL: plot swing points
  Parameters:
    mode (int): 1: bullish, -1 bearish block
    x (int): x-coordingate of swing point to plot (bar_index)
    y (float): y-coordingate of swing point to plot (price)
    show_swing_points (bool): switch to enable/disable plotting of swing point labels
    linecolor_swings (color): color for swing point labels and lates level lines
    keep_history (bool): weater to remove older swing point labels and only keep the most recent
    show_latest_swings_levels (bool)
    trail_x (int): x-coordinate for latest swing point (bar_index)
    trail_y (float): y-coordinate for latest swing point (price)
    trend (int): the current trend 1: bullish, -1: bearish, to determine Strong/Weak Low/Highs

_pivot_lvl(mode, trend, hhll_x, hhll, super_hhll, filter_insignificant_internal_breaks)
  INTERNAL: detect whether a structural level has been broken and if it was in trend direction (BoS) or against trend direction (ChoCh), also track the latest high and low swing points
  Parameters:
    mode (simple int): detect 1: bullish, -1 bearish pivot points
    trend (int): current trend direction
    hhll_x (int): x-coordinate of newly detected hh/ll (bar_index)
    hhll (float): y-coordinate of newly detected hh/ll (price)
    super_hhll (float): level/y-coordinate of superior hhll (if this is an internal structure pivot level)
    filter_insignificant_internal_breaks (bool): if true pivot points / internal structure will be ignored where the wick in trend direction is longer than the opposite (likely to push further in direction of main trend)
  Returns: [x, y, trail_x, trail_y, bos_alert, choch_alert] coordinates of internal structure that has been broken (x,y): start of structure, (trail_x, trail_y): tracking hh/ll after structure break, (bos_alert, choch_alert): signal whether a structural level has been broken

_plot_structure(x, y, is_bos, is_choch, line_color, line_style, label_style, label_size, keep_history)
  INTERNAL: plot structural breaks (BoS/ChoCh)
  Parameters:
    x (int): x-coordinate of newly broken structure (bar_index)
    y (float): y-coordinate of newly broken structure (price)
    is_bos (bool): whether this structural break was in trend direction
    is_choch (bool): whether this structural break was against trend direction
    line_color (color): color for the line connecting the structural level and the breaking candle
    line_style (string): style (line.style_dashed/solid) for the line connecting the structural level and the breaking candle
    label_style (string): style (label.style_label_down/up) for the label above/below the line connecting the structural level and the breaking candle
    label_size (string): size (size.small/tiny) for the label above/below the line connecting the structural level and the breaking candle
    keep_history (bool): weater to remove older swing point labels and only keep the most recent

structure_values(length, super_hh, super_ll, filter_insignificant_internal_breaks)
  detect (and plot) structural breaks and the resulting new trend
  Parameters:
    length (simple int): lookback period for swing point detection
    super_hh (float): level/y-coordinate of superior hh (for internal structure detection)
    super_ll (float): level/y-coordinate of superior ll (for internal structure detection)
    filter_insignificant_internal_breaks (bool): if true pivot points / internal structure will be ignored where the wick in trend direction is longer than the opposite (likely to push further in direction of main trend)
  Returns: [trend, bull_bos_alert, bull_choch_alert, top_x, top_y, trail_up_x, trail_up, hh, bear_bos_alert, bear_choch_alert, btm_x, btm_y, trail_dn_x, trail_dn, ll, hhll_x] trend: direction 1:bullish -1:bearish, (bull_bos_alert, bull_choch_alert, top_x, top_y, trail_up_x, trail_up): whether and which level broke in a bullish direction, trailing high, (bbear_bos_alert, bear_choch_alert, tm_x, btm_y, trail_dn_x, trail_dn): same in bearish direction

structure_plot(trend, bull_bos_alert, bull_choch_alert, top_x, top_y, trail_up_x, trail_up, hh, bear_bos_alert, bear_choch_alert, btm_x, btm_y, trail_dn_x, trail_dn, ll, color_bull, color_bear, show_swing_points, show_latest_swings_levels, show_bos, show_choch, line_style, label_size, keep_history)
  detect (and plot) structural breaks and the resulting new trend
  Parameters:
    trend (int): crrent trend 1: bullish, -1: bearish
    bull_bos_alert (bool): if there was a bullish bos alert -> plot it
    bull_choch_alert (bool): if there was a bullish choch alert -> plot it
    top_x (int): latest shwing high x
    top_y (float): latest swing high y
    trail_up_x (int): trailing high x
    trail_up (float): trailing high y
    hh (float): if there was a higher high
    bear_bos_alert (bool): if there was a bearish bos alert -> plot it
    bear_choch_alert (bool): if there was a bearish chock alert -> plot it
    btm_x (int): latest swing low x
    btm_y (float): latest swing low y
    trail_dn_x (int): trailing low x
    trail_dn (float): trailing low y
    ll (float): if there was a lower low
    color_bull (color): color for bullish BoS/ChoCh levels
    color_bear (color): color for bearish BoS/ChoCh levels
    show_swing_points (bool): whether to plot swing point labels
    show_latest_swings_levels (bool): whether to track and plot latest swing point levels with lines
    show_bos (bool): whether to plot BoS levels
    show_choch (bool): whether to plot ChoCh levels
    line_style (string): whether to plot BoS levels
    label_size (string): label size of plotted BoS/ChoCh levels
    keep_history (bool): weater to remove older swing point labels and only keep the most recent

structure(length, color_bull, color_bear, super_hh, super_ll, filter_insignificant_internal_breaks, show_swing_points, show_latest_swings_levels, show_bos, show_choch, line_style, label_size, keep_history, enabled)
  detect (and plot) structural breaks and the resulting new trend
  Parameters:
    length (simple int): lookback period for swing point detection
    color_bull (color): color for bullish BoS/ChoCh levels
    color_bear (color): color for bearish BoS/ChoCh levels
    super_hh (float): level/y-coordinate of superior hh (for internal structure detection)
    super_ll (float): level/y-coordinate of superior ll (for internal structure detection)
    filter_insignificant_internal_breaks (bool): if true pivot points / internal structure will be ignored where the wick in trend direction is longer than the opposite (likely to push further in direction of main trend)
    show_swing_points (bool): whether to plot swing point labels
    show_latest_swings_levels (bool): whether to track and plot latest swing point levels with lines
    show_bos (bool): whether to plot BoS levels
    show_choch (bool): whether to plot ChoCh levels
    line_style (string): whether to plot BoS levels
    label_size (string): label size of plotted BoS/ChoCh levels
    keep_history (bool): weater to remove older swing point labels and only keep the most recent
    enabled (bool)

_check_equal_level(mode, len, eq_threshold, enabled)
  INTERNAL: detect equal levels (double top/bottom)
  Parameters:
    mode (int): detect 1: bullish/high, -1 bearish/low pivot points
    len (int): lookback period for equal level (swing point) detection
    eq_threshold (float): maximum price offset for a level to be considered equal
    enabled (bool)
  Returns: [eq_alert, x1, y1, x2, y2] eq_alert whether an equal level was detected and coordinates of the first and the second level/swing point

_plot_equal_level(show_eq, x1, y1, x2, y2, label_txt, label_style, label_size, line_color, line_style, keep_history)
  INTERNAL: plot equal levels (double top/bottom)
  Parameters:
    show_eq (bool): whether to plot the level or not
    x1 (int): x-coordinate of the first level / swing point
    y1 (float): y-coordinate of the first level / swing point
    x2 (int): x-coordinate of the second level / swing point
    y2 (float): y-coordinate of the second level / swing point
    label_txt (string): text for the label above/below the line connecting the equal levels
    label_style (string): style (label.style_label_down/up) for the label above/below the line connecting the equal levels
    label_size (string): size (size.tiny) for the label above/below the line connecting the equal levels
    line_color (color): color for the line connecting the equal levels (and it's label)
    line_style (string): style (line.style_dotted) for the line connecting the equal levels
    keep_history (bool): weater to remove older swing point labels and only keep the most recent

equal_levels_values(len, threshold, enabled)
  detect (and plot) equal levels (double top/bottom), returns coordinates
  Parameters:
    len (int): lookback period for equal level (swing point) detection
    threshold (float): maximum price offset for a level to be considered equal
    enabled (bool): whether detection is enabled
  Returns: [eqh_alert, eqh_x1, eqh_y1, eqh_x2, eqh_y2, eql_alert, eql_x1, eql_y1, eql_x2, eql_y2] (eqh_alert, eqh_x1, eqh_y1, eqh_x2, eqh_y2) whether an equal high was detected and coordinates of the first and the second level/swing point, (eql_alert, eql_x1, eql_y1, eql_x2, eql_y2) same for equal lows

equal_levels_plot(eqh_x1, eqh_y1, eqh_x2, eqh_y2, eql_x1, eql_y1, eql_x2, eql_y2, color_eqh, color_eql, show, keep_history)
  detect (and plot) equal levels (double top/bottom), returns coordinates
  Parameters:
    eqh_x1 (int): coordinates of first point of equal high
    eqh_y1 (float): coordinates of first point of equal high
    eqh_x2 (int): coordinates of second point of equal high
    eqh_y2 (float): coordinates of second point of equal high
    eql_x1 (int): coordinates of first point of equal low
    eql_y1 (float): coordinates of first point of equal low
    eql_x2 (int): coordinates of second point of equal low
    eql_y2 (float): coordinates of second point of equal low
    color_eqh (color): color for the line connecting the equal highs (and it's label)
    color_eql (color): color for the line connecting the equal lows (and it's label)
    show (bool): whether plotting is enabled
    keep_history (bool): weater to remove older swing point labels and only keep the most recent
  Returns: [eqh_alert, eqh_x1, eqh_y1, eqh_x2, eqh_y2, eql_alert, eql_x1, eql_y1, eql_x2, eql_y2] (eqh_alert, eqh_x1, eqh_y1, eqh_x2, eqh_y2) whether an equal high was detected and coordinates of the first and the second level/swing point, (eql_alert, eql_x1, eql_y1, eql_x2, eql_y2) same for equal lows

equal_levels(len, threshold, color_eqh, color_eql, enabled, show, keep_history)
  detect (and plot) equal levels (double top/bottom)
  Parameters:
    len (int): lookback period for equal level (swing point) detection
    threshold (float): maximum price offset for a level to be considered equal
    color_eqh (color): color for the line connecting the equal highs (and it's label)
    color_eql (color): color for the line connecting the equal lows (and it's label)
    enabled (bool): whether detection is enabled
    show (bool): whether plotting is enabled
    keep_history (bool): weater to remove older swing point labels and only keep the most recent
  Returns: [eqh_alert, eql_alert] (eqh_alert) whether an equal high was detected, (eql_alert) same for equal lows

_detect_fvg(mode, enabled, o, h, l, c, filter_insignificant_fvgs, change_tf)
  INTERNAL: detect FVG (fair value gap)
  Parameters:
    mode (int): detect 1: bullish, -1 bearish gaps
    enabled (bool): whether detection is enabled
    o (float): reference source open
    h (float): reference source high
    l (float): reference source low
    c (float): reference source close
    filter_insignificant_fvgs (bool): whether to calculate and filter small/insignificant gaps
    change_tf (bool): signal when the previous reference timeframe closed, triggers new calculation
  Returns: [cnd, top, mid, btm] whether a new FVG was detected and its top/mid/bottom levels

_clear_broken_fvg(mode, upper_boxes, lower_boxes)
  INTERNAL: clear mitigated FVGs (fair value gaps)
  Parameters:
    mode (int): detect 1: bullish, -1 bearish gaps
    upper_boxes (array<box>): array<box> that stores the upper parts of the FVG boxes
    lower_boxes (array<box>): array<box> that stores the lower parts of the FVG boxes

_plot_fvg(mode, show, top, mid, btm, border_color, extend_box)
  INTERNAL: plot (and clear broken) FVG (fair value gap)
  Parameters:
    mode (int): plot 1: bullish, -1 bearish gap
    show (bool): whether plotting is enabled
    top (float): top level of fvg
    mid (float): center level of fvg
    btm (float): bottom level of fvg
    border_color (color): color for the FVG box
    extend_box (int): how many bars into the future the FVG box should be extended after detection

fvgs_values(o, h, l, c, filter_insignificant_fvgs, change_tf, enabled)
  detect (and plot / clear broken) FVGs (fair value gaps), and return alerts and level values
  Parameters:
    o (float): reference source open
    h (float): reference source high
    l (float): reference source low
    c (float): reference source close
    filter_insignificant_fvgs (bool): whether to calculate and filter small/insignificant gaps
    change_tf (bool): signal when the previous reference timeframe closed, triggers new calculation
    enabled (bool): whether detection is enabled
  Returns: [bullish_fvg_alert, bull_top, bull_mid, bull_btm, bearish_fvg_alert, bear_top, bear_mid, bear_btm] (bullish_fvg_alert, bull_top, bull_mid, bull_btm): whether a new bullish FVG was detected and its top/mid/bottom levels, (bearish_fvg_alert, bear_top, bear_mid, bear_btm): same for bearish FVGs

fvgs_plot(bullish_fvg_alert, bull_top, bull_mid, bull_btm, bearish_fvg_alert, bear_top, bear_mid, bear_btm, color_bull, color_bear, extend_box, show)
  Parameters:
    bullish_fvg_alert (bool)
    bull_top (float)
    bull_mid (float)
    bull_btm (float)
    bearish_fvg_alert (bool)
    bear_top (float)
    bear_mid (float)
    bear_btm (float)
    color_bull (color): color for bullish FVG boxes
    color_bear (color): color for bearish FVG boxes
    extend_box (int): how many bars into the future the FVG box should be extended after detection
    show (bool): whether plotting is enabled
  Returns: [bullish_fvg_alert, bull_top, bull_mid, bull_btm, bearish_fvg_alert, bear_top, bear_mid, bear_btm] (bullish_fvg_alert, bull_top, bull_mid, bull_btm): whether a new bullish FVG was detected and its top/mid/bottom levels, (bearish_fvg_alert, bear_top, bear_mid, bear_btm): same for bearish FVGs

fvgs(o, h, l, c, filter_insignificant_fvgs, change_tf, color_bull, color_bear, extend_box, enabled, show)
  detect (and plot / clear broken) FVGs (fair value gaps)
  Parameters:
    o (float): reference source open
    h (float): reference source high
    l (float): reference source low
    c (float): reference source close
    filter_insignificant_fvgs (bool): whether to calculate and filter small/insignificant gaps
    change_tf (bool): signal when the previous reference timeframe closed, triggers new calculation
    color_bull (color): color for bullish FVG boxes
    color_bear (color): color for bearish FVG boxes
    extend_box (int): how many bars into the future the FVG box should be extended after detection
    enabled (bool): whether detection is enabled
    show (bool): whether plotting is enabled
  Returns: [bullish_fvg_alert, bearish_fvg_alert] (bullish_fvg_alert): whether a new bullish FVG was detected, (bearish_fvg_alert): same for bearish FVGs

OrderBlock
  Fields:
    id (series int)
    dir (series int)
    left_top (chart.point)
    right_bottom (chart.point)
    break_price (series float)
    early_confirmation_price (series float)
    ltf_high (array<float>)
    ltf_low (array<float>)
    ltf_volume (array<float>)
    plot (Box type from robbatt/lib_plot_objects/49)
    profile (Profile type from robbatt/lib_profile/32)
    trailing (series bool)
    extending (series bool)
    awaiting_confirmation (series bool)
    touched_break_price_before_confirmation (series bool)
    soft_confirmed (series bool)
    has_fvg_out (series bool)
    hidden (series bool)
    broken (series bool)

OrderBlockConfig
  Fields:
    show (series bool)
    show_last (series int)
    show_id (series bool)
    show_profile (series bool)
    args (BoxArgs type from robbatt/lib_plot_objects/49)
    txt (series string)
    txt_args (BoxTextArgs type from robbatt/lib_plot_objects/49)
    delete_when_broken (series bool)
    broken_args (BoxArgs type from robbatt/lib_plot_objects/49)
    broken_txt (series string)
    broken_txt_args (BoxTextArgs type from robbatt/lib_plot_objects/49)
    broken_profile_args (ProfileArgs type from robbatt/lib_profile/32)
    use_profile (series bool)
    profile_args (ProfileArgs type from robbatt/lib_profile/32)
Informacje o Wersji
v2 removed logging for performance improvement
Informacje o Wersji
v3 minor refactoring
Informacje o Wersji
v4 fixed latest pivot line display
Informacje o Wersji
v5 updated to lib_profile v33
Informacje o Wersji
v6 updated to lib_profile v34
Informacje o Wersji
v7 fixed calculation of profile directional volume
Informacje o Wersji
v8 added parameter for capture_directional_volume
Informacje o Wersji
v9 added probability field and plot option
Informacje o Wersji
v10

Added:
method hide(this)
  hide the plot of an object, without deleting it from the chart, so it can re-appear later without triggering a max_bars_back error when redrawing an object that has a x coordinate > 244 bars in the past (the limit for the default buffer)
  Namespace types: OrderBlock
  Parameters:
    this (OrderBlock)
Informacje o Wersji
v11 FVG update
  • added FVG objects ( allows different styles for filled FVGs, current fill level tracking, extension until filled, FillMode via close/high/low, tracking total volume of the 3 FVG bars)
  • simplified basic FVG detection (removed open/close/filter_insignificant_fvgs parameters, removed automatic filter calculation, added fixed min_size_threshold parameter instead (use mult x atr(50))
  • added fill_ratio parameter for basic FVG plot to allow for custom fill level via high/low (defaults to 50% now instead of 100%)
  • refactored settings dialog


Added:
method update(fvgs)
  Namespace types: array<FVG>
  Parameters:
    fvgs (array<FVG>)

fvgs_objects(h, l, v, fill_mode, fvg_fill_target_ratio, size_threshold, change_tf, enabled, filled_max_keep)
  detect FVGs (fair value gaps), and return FVG objects
  Parameters:
    h (float): reference source high
    l (float): reference source low
    v (float)
    fill_mode (series FVGFillMode)
    fvg_fill_target_ratio (float)
    size_threshold (float): filter small/insignificant gaps that are smaller than this value
    change_tf (bool): signal when the previous reference timeframe closed, triggers new calculation
    enabled (bool): whether detection is enabled
    filled_max_keep (int)
  Returns: [bullish_fvg_alert, bearish_fvg_alert, buffer_bull, buffer_bear, new_bull, new_bear, filled_bull, filled_bear] (bullish_fvg_alert, bearish_fvg_alert) boolean flag to indicate a new FVG | (buffer_bull, buffer_bear) persistent buffers of unfilled FVGs with latest at the end | (new_bull, new_bear) newly detected FVG objects additionally to being added to the buffer | (filled_bull, filled_bear) non persistent arrays of FVGs filled in this candle

FVGConfig
  Fields:
    show (series bool)
    show_last (series int)
    show_probability (series bool)
    show_profile (series bool)
    box_args (BoxArgs type from robbatt/lib_plot_objects/49)
    box_text_args (BoxTextArgs type from robbatt/lib_plot_objects/49)
    line_args (LineArgs type from robbatt/lib_plot_objects/49)
    txt (series string)
    extend_bars (series int)
    extend_until_filled (series bool)
    delete_when_filled (series bool)
    filled_txt (series string)
    filled_box_args (BoxArgs type from robbatt/lib_plot_objects/49)
    filled_box_text_args (BoxTextArgs type from robbatt/lib_plot_objects/49)
    filled_line_args (LineArgs type from robbatt/lib_plot_objects/49)

FVG
  Fields:
    dir (series int)
    fill_mode (series FVGFillMode)
    left_top (chart.point)
    right_bottom (chart.point)
    fvg_fill_target_ratio (series float)
    fill_target_level (series float)
    fill_current_ratio (series float)
    fill_current_level (series float)
    filled (series bool)
    hidden (series bool)
    total_volume (series float)
    probability (series float)
    plot_box (Box type from robbatt/lib_plot_objects/49)
    plot_fill_target_level (Line type from robbatt/lib_plot_objects/49)

Updated:
method delete(this)
  delete the plot of an object, including deleting it from the chart
  Namespace types: FVG
  Parameters:
    this (FVG)

method draw(fvgs, config)
  INTERNAL: plot fvgs
  Namespace types: array<FVG>
  Parameters:
    fvgs (array<FVG>)
    config (FVGConfig)

method hide(this)
  hide the plot of an object, without deleting it from the chart, so it can re-appear later without triggering a max_bars_back error when redrawing an object that has a x coordinate > 244 bars in the past (the limit for the default buffer)
  Namespace types: FVG
  Parameters:
    this (FVG)

fvgs_values(h, l, size_threshold, change_tf, enabled)
  detect FVGs (fair value gaps), and return alerts and level values
  Parameters:
    h (float): reference source high
    l (float): reference source low
    size_threshold (float): filter small/insignificant gaps that are smaller than this value
    change_tf (bool): signal when the previous reference timeframe closed, triggers new calculation
    enabled (bool): whether detection is enabled
  Returns: [bullish_fvg_alert, bull_top, bull_btm, bearish_fvg_alert, bear_top, bear_btm] (bullish_fvg_alert, bull_top, bull_btm): whether a new bullish FVG was detected and its top/bottom levels, (bearish_fvg_alert, bear_top, bear_btm): same for bearish FVGs

fvgs_plot(bullish_fvg_alert, bull_top, bull_btm, bearish_fvg_alert, bear_top, bear_btm, color_bull, color_bear, extend_box, fill_ratio, show)
  detect (and plot / clear broken) FVGs (fair value gaps), and return alerts and level values
  Parameters:
    bullish_fvg_alert (bool)
    bull_top (float)
    bull_btm (float)
    bearish_fvg_alert (bool)
    bear_top (float)
    bear_btm (float)
    color_bull (color): color for bullish FVG boxes
    color_bear (color): color for bearish FVG boxes
    extend_box (int): how many bars into the future the FVG box should be extended after detection
    fill_ratio (float): (optional) target fill ratio at which the box is removed (defaults to 0.5)
    show (bool): whether plotting is enabled
  Returns: [bullish_fvg_alert, bull_top, bull_mid, bull_btm, bearish_fvg_alert, bear_top, bear_mid, bear_btm] (bullish_fvg_alert, bull_top, bull_mid, bull_btm): whether a new bullish FVG was detected and its top/mid/bottom levels, (bearish_fvg_alert, bear_top, bear_mid, bear_btm): same for bearish FVGs

fvgs(h, l, size_threshold, change_tf, color_bull, color_bear, extend_box, fill_ratio, enabled, show)
  detect (and plot / clear broken) FVGs (fair value gaps)
  Parameters:
    h (float): reference source high
    l (float): reference source low
    size_threshold (float): filter small/insignificant gaps that are smaller than this value
    change_tf (bool): signal when the previous reference timeframe closed, triggers new calculation
    color_bull (color): color for bullish FVG boxes
    color_bear (color): color for bearish FVG boxes
    extend_box (int): how many bars into the future the FVG box should be extended after detection
    fill_ratio (float): (optional) target fill ratio at which the box is removed (defaults to 0.5)
    enabled (bool): whether detection is enabled
    show (bool): whether plotting is enabled
  Returns: [bullish_fvg_alert, bearish_fvg_alert] (bullish_fvg_alert): whether a new bullish FVG was detected, (bearish_fvg_alert): same for bearish FVGs
Informacje o Wersji
v12 update to lib_profile v35 fixed bug when chart has gaps in ltf data
Informacje o Wersji
v13 refactored display for broken OrderBlocks and filled FVGs
  • added OrderBlockBreakMode (CLOSE/HIGHLOW) similar to FVGFillMode (CLOSE/HIGHLOW)
  • removed OrderBlock.early_confirmation_price, concept not used / valid
  • flags to control showing box/break price/text in broken OB/FVG
  • removed double config data for broken OB/FVG from Config types, using two instances instead, when needed.
  • no auto - deletion for filled OBs/FVGs, please delete from returned broken/filled buffers from track_obs/fvg_objects when needed
  • added parameters for keeping broken/filled OBs/FVGs (enabled flag and max keep count)

Informacje o Wersji
v14 update to lib_profile v36, some refactoring and speed optimizations
Informacje o Wersji
v14 update to lib_profile v36, some refactoring and speed optimizations
Informacje o Wersji
v16 improved performance on FVG object detection, removed option to pass different sources (faster to use use request.security with object-oriented detection for HTF-FVGs)
Informacje o Wersji
v17 added absolute x coordinate overrides for OB/FVG
Informacje o Wersji
v18 removed check for xloc.bar_time in track_obs, fixed display bug for OBs reappearing after hiding
Informacje o Wersji
v19
  • fine tuned swing detection, added confirmation right
  • refactored order block tracking data buffers / create_profile
  • added delete(OrderBlock[])
  • changed broken_time to time_close (to fix HTF block not being plotted to where it was broken)
  • changed broken_index to bar_index + 1
  • added discard_buffers to return tuple instead of paramters
  • added fixed min FVG size of 0.2 * ATR200 for OB.has_fvg_out and soft-confirmations
  • added optional FVG fill_target_label at the fill_level (if show_fill_target_label and show_probability, this will hold the probability instead of the box text)
  • added probability to POC label (if show_poc_label and show_probability, the POC label will show the probability instead of the OB box text)

Informacje o Wersji
v20
  • improved demo plotting performance
  • added discard buffers to return tuples of track_obs and fvg_objects
  • added OB soft confirmation by big candle body > 3xATR200 closing way outside the tracking block
  • fixed bug in real time swing structure (removed confirmation right bars, doesn't make sense)

Informacje o Wersji
v21 improved management of filled FVG / broken OB, returning newly filled/broken in separate buffer, which allows for drawing only those in realtime and all in filled buffer on lastconfirmedhistory bars
Informacje o Wersji
v22 applied changes from lib_plot_objects v56 and lib_profile v43
  • performance improvements
  • remodeled object oriented drawing/plotting system
  • strict separation of data, processing and view
  • top down injection of drawing coordinates and xloc
  • renamed args to config where objects are a composition of args objects to distinguish purpose (args for basic objects, config for composite objects holding multiple args)

Informacje o Wersji
v23 fixed plot of FVG target label
Informacje o Wersji
v24 fixed error in POC label text
Informacje o Wersji
v25 performance optimizations
Informacje o Wersji
v26 restored fixed width FVG option
Informacje o Wersji
v27 resolved naming conflict extend_blocks to include_consecutive_bars
Informacje o Wersji
v28 unified FVGFillMode and OrderBlockBreakMode to LevelBreakMode
Informacje o Wersji
v29
  • updated structural detection and plot functions
  • removed convenience functions (too many params, too many things happening in one function if only parts are needed)
  • made internal functions more accessible
  • using lib_plot_objects argument objects to reduce parameters

Informacje o Wersji
v30 added fix for data gaps in volume profile, resulting in the profiles not being generated properly

Wyłączenie odpowiedzialności

Informacje i publikacje przygotowane przez TradingView lub jego użytkowników, prezentowane na tej stronie, nie stanowią rekomendacji ani porad handlowych, inwestycyjnych i finansowych i nie powinny być w ten sposób traktowane ani wykorzystywane. Więcej informacji na ten temat znajdziesz w naszym Regulaminie.