0% found this document useful (0 votes)
206 views17 pages

Edit 4

The document is a Pine Script code for a trading indicator called 'Elite Algo v22', designed for use on trading platforms. It includes various user inputs for customizing dashboard settings, buy/sell signals, risk management, trend analysis, and support/resistance features. The script utilizes multiple functions to calculate indicators like ATR, Supertrend, and EMA, and provides options for visual customization and signal filtering.

Uploaded by

trakesavan
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as TXT, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
206 views17 pages

Edit 4

The document is a Pine Script code for a trading indicator called 'Elite Algo v22', designed for use on trading platforms. It includes various user inputs for customizing dashboard settings, buy/sell signals, risk management, trend analysis, and support/resistance features. The script utilizes multiple functions to calculate indicators like ATR, Supertrend, and EMA, and provides options for visual customization and signal filtering.

Uploaded by

trakesavan
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as TXT, PDF, TXT or read online on Scribd
You are on page 1/ 17

//@version=6

indicator('Elite Algo v22', overlay = true, max_lines_count = 500, max_labels_count


= 500, max_boxes_count = 350)
//Freemium indicators >> https://t.me/eyop

// Get user input


enableDashboard = input(true, 'Enable Dashboard', group = 'DASHBOARD SETTINGS')
locationDashboard = input.string('Middle right', 'Location', ['Top right', 'Top
left', 'Middle right', 'Middle left', 'Bottom right', 'Bottom left'], group =
'DASHBOARD SETTINGS')
sizeDashboard = input.string('Normal', 'Size', ['Tiny', 'Small', 'Normal'], group =
'DASHBOARD SETTINGS')
colorBackground = input(#2A2E39, 'Bg color', group = 'DASHBOARD SETTINGS')
colorFrame = input(#2A2E39, 'Frame color', group = 'DASHBOARD SETTINGS')
colorBorder = input(#363A45, 'Border color', group = 'DASHBOARD SETTINGS')
showSignals = input(true, 'Show signals', group = 'BUY AND SELL SIGNALS SETTINGS')
strategy = input.string('Normal', 'Strategy', ['Normal', 'Confirmed', 'Trend
scalper'], group = 'BUY AND SELL SIGNALS SETTINGS')
sensitivity = input.float(6.29, 'Sensitivity', 0.1, step = 0.1, group = 'BUY AND
SELL SIGNALS SETTINGS')
consSignalsFilter = input(false, 'Consolidation signals filter', group = 'BUY AND
SELL SIGNALS SETTINGS')
smartSignalsOnly = input(false, 'Smart signals only', group = 'BUY AND SELL SIGNALS
SETTINGS')
candleColors = input(false, 'Candle colors', group = 'BUY AND SELL SIGNALS
SETTINGS')
momentumCandles = input(false, 'Momentum candles', group = 'BUY AND SELL SIGNALS
SETTINGS')
highVolSignals = input(false, 'High volume signals only', group = 'BUY AND SELL
SIGNALS SETTINGS')
enableTrailingSL = input(false, 'Enable trailing stop-loss', group = 'RISK
MANAGEMENT SETTINGS')
usePercSL = input(false, '% Trailing sl', inline = '2', group = 'RISK MANAGEMENT
SETTINGS')
percTrailingSL = input.float(1, '', 0, step = 0.1, inline = '2', group =
'RISKMANAGEMENT SETTINGS')
enableSwings = input(false, 'Enable Swing High\'s & Swing\'s Low\'s', inline = '3',
group = 'RISK MANAGEMENT SETTINGS')
periodSwings = input.int(10, '', 2, inline = '3', group = 'RISK MANAGEMENT
SETTINGS')
enableTpSlAreas = input(false, 'Enable take profit/stop-loss areas', group = 'RISK
MANAGEMENT SETTINGS')
useTP1 = input(true, '', inline = '4', group = 'RISK MANAGEMENT SETTINGS')
multTP1 = input.float(1, 'TP 1', 0, inline = '4', group = 'RISK MANAGEMENT
SETTINGS')
useTP2 = input(true, '', inline = '5', group = 'RISK MANAGEMENT SETTINGS')
multTP2 = input.float(2, 'TP 2', 0, inline = '5', group = 'RISK MANAGEMENT
SETTINGS')
useTP3 = input(true, '', inline = '6', group = 'RISK MANAGEMENT SETTINGS')
multTP3 = input.float(3, 'TP 3', 0, inline = '6', group = 'RISK MANAGEMENT
SETTINGS')
tpLabels = input(true, 'Take profit labels', group = 'RISK MANAGEMENT SETTINGS')
showTrendCloud = input(true, 'Show Trend cloud', group = 'TREND CLOUD SETTINGS')
periodTrendCloud = input.string('New', 'Trend cloud period', ['Short term', 'Long
term', 'New'], group = 'TREND CLOUD SETTINGS')
signalsTrendCloud = input(false, 'Trend only signals', group = 'TREND
CLOUDSETTINGS')
fastTrendCloud = input(false, 'Fast trend cloud', group = 'TREND CLOUD SETTINGS')
fastTrendCloudLen = input.int(55, 'Fast trend cloud', 2, group = 'TREND CLOUD
SETTINGS')
enableAutoTrend = input(false, 'Enable Auto Trendlines', group = 'AUTO TRENDLINES
SETTINGS')
srcTrendChannel = input(close, 'Trend channel source', group = 'AUTO TRENDLINES
SETTINGS')
lenTrendChannel = input.int(200, 'Trend channel loopback', 2, group = 'AUTO
TRENDLINES SETTINGS')
enableSR = input(false, 'Enable support and resistance', group = 'AUTO SUPPORT AND
RESISTANCE SETTINGS')
lineSrStyle = input.string('Dashed', 'Line Style', ['Solid', 'Dotted', 'Dashed'],
group = 'AUTO SUPPORT AND RESISTANCE SETTINGS')
lineSrWidth = input.int(2, 'Line Width', 1, 4, group = 'AUTO SUPPORT AND RESISTANCE
SETTINGS')
showCons = input(false, 'Consolidation Zones', group = 'CONSOLIDATION ZONES')
lbPeriod = input.int(10, 'Loopback Period', 2, 50, group = 'CONSOLIDATION ZONES')
lenCons = input.int(5, 'Min Consolidation Length', 2, 20, group = 'CONSOLIDATION
ZONES')
paintCons = input(true, 'Paint Consolidation Area', group = 'CONSOLIDATION ZONES')
colorZone = input(color.new(color.blue, 70), 'Zone Color', group = 'CONSOLIDATION
ZONES')
box_ob = input.bool(false, 'Toggle Order Block', group = 'ORDER BLOCK')
box_hide_gray = input.bool(false, 'Hide gray boxes', group = 'ORDER BLOCK')
bos_type = input.string('High and Low', 'MSB trigger', ['High and Low', 'Close and
Open'], group = 'ORDER BLOCK')
box_sv = input.bool(true, 'Plot demand boxes', group = 'ORDER BLOCK')
box_test_delay = input.int(3, 'Delay to count test of demand box', 1, group =
'ORDER BLOCK')
box_fill_delay = input.int(3, 'Delay to count fill of demand box', 1, group =
'ORDER BLOCK')
box_test_sv = input.bool(true, 'Dim tested demand boxes', group = 'ORDER BLOCK')
box_stop_sv = input.bool(true, 'Stop plotting filled demand boxes', group = 'ORDER
BLOCK')
eliteVP = input(false, 'Elite volume profile', group = 'ELITE VOLUME PROFILE')
colorBorderVP = input(color.new(color.black, 80), 'Border color', group = 'ELITE
VOLUME PROFILE')
colorBuyVP = input(#7F1623, 'Buy volume', group = 'ELITE VOLUME PROFILE')
colorSellVP = input(#00DD00, 'Sell volume', group = 'ELITE VOLUME PROFILE')
offset = input.int(2, 'Offset', 2, 20, group = 'ELITE VOLUME PROFILE')
lookback = input.int(100, 'Lookback', 14, 365, group = 'ELITE VOLUME PROFILE')
levelNum = input.int(100, 'Number of levels', 10, 100, group = 'ELITE VOLUME
PROFILE')
levelWidth = input.int(50, 'Level width', 20, 100, group = 'ELITE VOLUME PROFILE')
// Functions
f_chartTfInMinutes() =>
float _resInMinutes = timeframe.multiplier * (timeframe.isseconds ? 1. / 60 :
timeframe.isminutes ? 1. : timeframe.isdaily ? 60. * 24 : timeframe.isweekly ? 60.
* 24 * 7 : timeframe.ismonthly ? 60. * 24 * 30.4375 : na)
_resInMinutes
atr(len) =>
tr = ta.tr
atrVal = 0.0
atrVal := nz(atrVal[1] + (tr - atrVal[1]) / len, tr)
atrVal
supertrend(src, factor, len) =>
atrVal = ta.atr(len) // Rename atr to avoid conflicts
upperBand = src + factor * atrVal
lowerBand = src - factor * atrVal
prevLowerBand = nz(lowerBand[1])
prevUpperBand = nz(upperBand[1])

lowerBand := lowerBand > prevLowerBand or close[1] < prevLowerBand ?


lowerBand : prevLowerBand
upperBand := upperBand < prevUpperBand or close[1] > prevUpperBand ?
upperBand : prevUpperBand

var int direction = na


var float superTrend = na
prevSuperTrend = superTrend[1]

if prevSuperTrend == prevUpperBand
direction := close > upperBand ? 1 : -1
direction
else
direction := close < lowerBand ? -1 : 1
direction

superTrend := direction == 1 ? lowerBand : direction == -1 ? upperBand : na


superTrend
dchannel(len) =>
hh = ta.highest(len)
ll = ta.lowest(len)
trend = 0
trend := close > hh[1] ? 1 : close < ll[1] ? -1 : nz(trend[1])
trend
trendScalper(show, len1, len2, len3, colorBull, colorBear, colorBarBull,
colorBarBear) =>
avgOC = math.avg(open, close)
ha_o = 0.0
ha_o := na(ha_o[1]) ? avgOC : (ha_o[1] + ohlc4[1]) / 2
ema1 = ta.ema(ha_o, len1)
ema2 = ta.ema(ha_o, len2)
ema3 = ta.ema(ha_o, len3)
ris1 = ema1 > ema1[1]
ris2 = ema2 > ema2[1]
ris3 = ema3 > ema3[1]
fal1 = ema1 < ema1[1]
fal2 = ema2 < ema2[1]
fal3 = ema3 < ema3[1]
colorEma1 = ris1 ? colorBull : fal1 ? colorBear : na
colorEma2 = ris2 ? colorBull : fal2 ? colorBear : na
colorEma3 = ris3 ? colorBull : fal3 ? colorBear : na
fillEma1 = avgOC > ema1 ? colorBull : avgOC < ema1 ? colorBear : na
fillEma2 = ema1 > ema2 ? colorBull : ema1 < ema2 ? colorBear : na
fillEma3 = ema2 > ema3 ? colorBull : ema2 < ema3 ? colorBear : na
colorBar = close < ema1 and close < ema2 ? colorBarBear : colorBarBull
[avgOC, show ? ema1 : na, show ? ema2 : na, show ? ema3 : na,
color.new(colorEma1, 55), color.new(colorEma2, 45), color.new(colorEma3, 35),
color.new(fillEma1, 85), color.new(fillEma2, 80), color.new(fillEma3, 75),
colorBar]
candlesMom() =>
[_, _, macd] = ta.macd(close, 12, 26, 9) // Correct destructuring
macd > 0 and macd > macd[1] or macd < 0 and macd < macd[1] // Correct return
statement
trailingSL(buy, sell, factor, len, usePerc, perc) =>
atrVal = ta.atr(len) // Use built-in ATR function

upperBand = high + (usePerc ? high * (perc / 100) : factor * atrVal)


lowerBand = low - (usePerc ? low * (perc / 100) : factor * atrVal)

prevLowerBand = nz(lowerBand[1])
prevUpperBand = nz(upperBand[1])

lowerBand := lowerBand > prevLowerBand or buy ? lowerBand : prevLowerBand


upperBand := upperBand < prevUpperBand or sell ? upperBand : prevUpperBand

var int direction = na


var float stop = na
prevSuperTrend = stop[1]

if prevSuperTrend == prevUpperBand
direction := buy ? 1 : -1
direction
else
direction := sell ? -1 : 1
direction

stop := direction == 1 ? lowerBand : direction == -1 ? upperBand : na


stop
add_to_zz(zz, val, bi) =>
array.unshift(zz, bi)
array.unshift(zz, val)
if array.size(zz) > 12
array.pop(zz)
val // Add a return value
update_zz(zz, val, bi, dir) =>
if array.size(zz) == 0
add_to_zz(zz, val, bi)
else
if dir == 1 and val > array.get(zz, 0) or dir == -1 and val < array.get(zz,
0)
array.set(zz, 0, val)
array.set(zz, 1, bi)
val // Add a return value
float ph = ta.pivothigh(high, 10, 10)
float pl = ta.pivotlow(low, 10, 10)
LSRstyle = lineSrStyle == 'Dashed' ? line.style_dashed : lineSrStyle == 'Solid' ?
line.style_solid : line.style_dotted
prdhighest = ta.highest(300)
prdlowest = ta.lowest(300)
cwidth = (prdhighest - prdlowest) * 10 / 100
var pivotvals = array.new_float(0)
if bool(ph) or bool(pl)
array.unshift(pivotvals, bool(ph) ? ph : pl)
if array.size(pivotvals) > 20
array.pop(pivotvals)
get_sr_vals(ind) =>
float lo = array.get(pivotvals, ind)
float hi = lo
int numpp = 0

for y = 0 to array.size(pivotvals) - 1 by 1
float cpp = array.get(pivotvals, y)
float wdth = cpp <= lo ? hi - cpp : cpp - lo

if wdth <= cwidth


lo := cpp <= lo ? cpp : lo
hi := cpp > lo ? cpp : hi
numpp := numpp + 1
numpp

[hi, lo, numpp] // Ensure proper return of values


var sr_up_level = array.new_float(0)
var sr_dn_level = array.new_float(0)
sr_strength = array.new_float(0)
find_loc(strength) =>
ret = array.size(sr_strength) // Start from array size

if ret > 0
for i = array.size(sr_strength) - 1 to 0 by 1
if strength <= array.get(sr_strength, i)
break
ret := i // Update return value
ret

ret // Return the final value


check_sr(hi, lo, strength) =>
ret = true

// Ensure the loop runs only if sr_up_level is not empty


if array.size(sr_up_level) > 0
for i = 0 to array.size(sr_up_level) - 1 by 1
if array.get(sr_up_level, i) >= lo and array.get(sr_up_level, i) <= hi
or array.get(sr_dn_level, i) >= lo and array.get(sr_dn_level, i) <= hi

if strength >= array.get(sr_strength, i)


array.remove(sr_strength, i)
array.remove(sr_up_level, i)
array.remove(sr_dn_level, i)
else
ret := false
ret

break // Exit loop early if a match is found

ret // Properly return the final result

// Get components
rsi = ta.rsi(close, 14)
vosc = ta.obv - ta.ema(ta.obv, 20)
bs = ta.ema(nz(math.abs((open - close) / (high - low) * 100)), 3)
ema = ta.ema(close, 200)
emaBull = close > ema
equal_tf(res) =>
str.tonumber(res) == f_chartTfInMinutes()
higher_tf(res) =>
str.tonumber(res) > f_chartTfInMinutes()
too_small_tf(res) =>
timeframe.isweekly and res == '1' or timeframe.ismonthly and str.tonumber(res)
< 10
securityNoRep(sym, res, src) =>
var bool bull = false // Use `var` to retain value across bars

bull := equal_tf(res) ? src : bull


bull := higher_tf(res) ? request.security(sym, res, src, barmerge.gaps_off,
barmerge.lookahead_on) : bull
bull_array = request.security_lower_tf(syminfo.tickerid, higher_tf(res) ?
str.tostring(f_chartTfInMinutes()) : too_small_tf(res) ? timeframe.isweekly ? '3' :
'10' : res, src)

if array.size(bull_array) > 1 and not equal_tf(res) and not higher_tf(res)


bull := array.pop(bull_array) // Ensure proper array handling
bull

array.clear(bull_array) // Clear array safely


bull // Return final value
TF1Bull = securityNoRep(syminfo.tickerid, '1', emaBull)
TF3Bull = securityNoRep(syminfo.tickerid, '3', emaBull)
TF5Bull = securityNoRep(syminfo.tickerid, '5', emaBull)
TF10Bull = securityNoRep(syminfo.tickerid, '10', emaBull)
TF15Bull = securityNoRep(syminfo.tickerid, '15', emaBull)
TF30Bull = securityNoRep(syminfo.tickerid, '30', emaBull)
TF60Bull = securityNoRep(syminfo.tickerid, '60', emaBull)
TF120Bull = securityNoRep(syminfo.tickerid, '120', emaBull)
TF240Bull = securityNoRep(syminfo.tickerid, '240', emaBull)
TF720Bull = securityNoRep(syminfo.tickerid, '720', emaBull)
TFDBull = securityNoRep(syminfo.tickerid, '1440', emaBull)
ema150 = ta.ema(close, 150)
ema250 = ta.ema(close, 250)
hma55 = ta.hma(close, 55)
[_, _, macd] = ta.macd(close, 12, 26, 9)
supertrend = supertrend(ohlc4, sensitivity, 10)
maintrend = dchannel(30)
confBull = (ta.crossover(close, supertrend) or ta.crossover(close, supertrend)[1]
and maintrend[1] < 0) and macd > 0 and macd > macd[1] and ema150 > ema250 and hma55
> hma55[2] and maintrend > 0
confBear = (ta.crossunder(close, supertrend) or ta.crossunder(close, supertrend)[1]
and maintrend[1] > 0) and macd < 0 and macd < macd[1] and ema150 < ema250 and hma55
< hma55[2] and maintrend < 0
trendcloud = supertrend(ohlc4, periodTrendCloud == 'Long term' ? 7 : 4, 10)
hma = fastTrendCloud ? ta.hma(close, fastTrendCloudLen) : na
none = close > 0
[_, _, adx] = ta.dmi(14, 14)
consFilter = adx > 20
smartFilter = ta.ema(close, 200)
volFilter = (ta.ema(volume, 25) - ta.ema(volume, 26)) / ta.ema(volume, 26) > 0
trendFilter = trendcloud
bull = (strategy == 'Normal' ? ta.crossover(close, supertrend) : confBull and not
confBull[1]) and strategy != 'Trend scalper' and (smartSignalsOnly ? close >
smartFilter : none) and (consSignalsFilter ? consFilter : none) and (highVolSignals
? volFilter : none) and (signalsTrendCloud ? periodTrendCloud == 'New' ? ema150 >
ema250 : close > trendFilter : none)
bear = (strategy == 'Normal' ? ta.crossunder(close, supertrend) : confBear and not
confBear[1]) and strategy != 'Trend scalper' and (smartSignalsOnly ? close <
smartFilter : none) and (consSignalsFilter ? consFilter : none) and (highVolSignals
? volFilter : none) and (signalsTrendCloud ? periodTrendCloud == 'New' ? ema150 <
ema250 : close < trendFilter : none)
countBull = ta.barssince(bull)
countBear = ta.barssince(bear)
trigger = nz(countBull, bar_index) < nz(countBear, bar_index) ? 1 : 0
[avgOC, ema5, ema9, ema21, colorEma5, colorEma9, colorEma21, fillEma5, fillEma9,
fillEma21, colorBar] = trendScalper(strategy == 'Trend scalper' ? true : false, 5,
9, 21, color.green, color.red, #00DD00, #DD0000)
trailingStop = trailingSL(bull, bear, 2.2, 14, usePercSL, percTrailingSL)
float _ph = ta.highestbars(high, periodSwings) == 0 ? high : na
float _pl = ta.lowestbars(low, periodSwings) == 0 ? low : na
var _dir = 0
dir_ = bool(_pl) and na(_ph) ? -1 : _dir
_dir := bool(_ph) and na(_pl) ? 1 : dir_
dirChg = ta.change(_dir)
var zz = array.new_float(0)
zzOld = array.copy(zz)
float zzLive = bool(_ph) or bool(_pl) ? bool(dirChg) ? add_to_zz(zz, _dir == 1 ?
_ph : _pl, bar_index) : update_zz(zz, _dir == 1 ? _ph : _pl, bar_index, _dir) : na
a = ta.wma(srcTrendChannel, lenTrendChannel)
b = ta.sma(srcTrendChannel, lenTrendChannel)
A = 4 * b - 3 * a
B = 3 * a - 2 * b
m = (A - B) / (lenTrendChannel - 1)
d = 0.0 // Ensure correct float initialization
for i = 0 to lenTrendChannel - 1 by 1
l = B + m * i // Correct indentation inside loop
d := d + math.pow(srcTrendChannel[i] - l, 2) // Correct placement inside loop
d
float hb_ = ta.highestbars(lbPeriod) == 0 ? high : na
float lb_ = ta.lowestbars(lbPeriod) == 0 ? low : na
var int dir = 0
float zz_ = na
float pp = na
var int consCnt = 0
var float condHi = na
var float condLo = na
float H_ = ta.highest(lenCons)
float L_ = ta.lowest(lenCons)
var line lineUp = na
var line lineDn = na
bool breakUp = false
bool breakDn = false
var array<float> pvh1_price = array.new_float(1000, na)
var array<int> pvh1_time = array.new_int(1000, na)
var array<float> pvl1_price = array.new_float(1000, na)
var array<int> pvl1_time = array.new_int(1000, na)
var array<float> pvh2_price = array.new_float(1000, na)
var array<int> pvh2_time = array.new_int(1000, na)
var array<float> pvl2_price = array.new_float(1000, na)
var array<int> pvl2_time = array.new_int(1000, na)
var float htcmrll_price = na
var int htcmrll_time = na
var float ltcmrhh_price = na
var int ltcmrhh_time = na
var array<box> long_boxes = array.new_box()
var array<box> short_boxes = array.new_box()
var float temp_pv_0 = na
var float temp_pv_1 = na
var float temp_pv_2 = na
bool pvh = high < high[1] and high[1] > high[2]
bool pvl = low > low[1] and low[1] < low[2]
int pv1_time = bar_index[1]
float pv1_high = high[1]
float pv1_low = low[1]
float trigger_high = bos_type == 'High and Low' ? high : math.max(open, close)
float trigger_low = bos_type == 'High and Low' ? low : math.min(open, close)
rangeHigh = ta.highest(high, lookback)
rangeLow = ta.lowest(low, lookback)
rangeHeight = rangeHigh - rangeLow
histogramHeight = rangeHeight / levelNum
histogramLowList = array.new_float(levelNum, na)
histogramHighList = array.new_float(levelNum, na)
histogramBuyVolumeList = array.new_float(levelNum, 0.0)
histogramSellVolumeList = array.new_float(levelNum, 0.0)
var buyBars = array.new_box(365, na)
for i = 0 to 364 by 1
box.delete(array.get(buyBars, i)) // Corrected for loop syntax
var sellBars = array.new_box(365, na)
for i = 0 to 364 by 1 // Added 'by 1' to fix the loop syntax
box.delete(array.get(sellBars, i)) // Ensure 'sellBars' is initialized
// Colors
green = #00DD00
green50 = color.new(green, 50)
green20 = color.new(green, 80)
red = #DD0000
red50 = color.new(red, 50)
red20 = color.new(red, 80)
silver = #B2B5BE
silver50 = color.new(silver, 50)
silver20 = color.new(silver, 80)
// Plots
atrBand = usePercSL ? ((trigger != 0 ? low : high) * (percTrailingSL / 100)) :
(ta.atr(14) * 2.2)
atrStop = bool(trigger) ? low - atrBand : high + atrBand // ✅ Converts `trigger`
to `bool`
lastTrade(src) =>
ta.valuewhen(bull or bear, src, 0)
entry_y = lastTrade(close)
stop_y = lastTrade(atrStop)
tp1_y = (entry_y - lastTrade(atrStop)) * multTP1 + entry_y
tp2_y = (entry_y - lastTrade(atrStop)) * multTP2 + entry_y
tp3_y = (entry_y - lastTrade(atrStop)) * multTP3 + entry_y
labelTpSl(cond, y, txt, color) =>
var label lbl = na // Declare a variable to store the label

if enableTpSlAreas and cond


lbl := label.new(bar_index + 1, y, txt, xloc.bar_index, yloc.price, color,
label.style_label_left, color.white, size.normal)
lbl

if not na(lbl[1]) // Ensure previous label exists before deleting


label.delete(lbl[1])

labelTpSl(none, entry_y, 'Entry : ' + str.tostring(math.round_to_mintick(entry_y)),


color.orange)
labelTpSl(none, stop_y, 'Stop loss : ' +
str.tostring(math.round_to_mintick(atrStop)), color.red)
labelTpSl(useTP1 and multTP1 != 0, tp1_y, 'TP 1 : ' +
str.tostring(math.round_to_mintick(tp1_y)), color.green)
labelTpSl(useTP2 and multTP2 != 0, tp2_y, 'TP 2 : ' +
str.tostring(math.round_to_mintick(tp2_y)), color.green)
labelTpSl(useTP3 and multTP3 != 0, tp3_y, 'TP 3 : ' +
str.tostring(math.round_to_mintick(tp3_y)), color.green)
lineTpSl(cond, y, color, style) =>
line lineTpSl = enableTpSlAreas and cond ? line.new(bar_index -
(bool(trigger) ? countBull : countBear), y, bar_index + 1, y, xloc.bar_index,
extend.none, color, style) : na
line.delete(lineTpSl[1])
lineTpSl(none, entry_y, color.orange, line.style_dashed)
lineTpSl(none, stop_y, color.red, line.style_solid)
lineTpSl(useTP1 and multTP1 != 0, tp1_y, color.green, line.style_dotted)
lineTpSl(useTP2 and multTP2 != 0, tp2_y, color.green, line.style_dotted)
lineTpSl(useTP3 and multTP3 != 0, tp3_y, color.green, line.style_dotted)
var dashboard_loc = locationDashboard == 'Top right' ? position.top_right :
locationDashboard == 'Top left' ? position.top_left : locationDashboard == 'Middle
right' ? position.middle_right : locationDashboard == 'Middle left' ?
position.middle_left : locationDashboard == 'Bottom right' ?
position.bottom_right : position.bottom_left
var dashboard_size = sizeDashboard == 'Tiny' ? size.tiny : sizeDashboard == 'Small'
? size.small : size.normal
var dashboard = table.new(dashboard_loc, 2, 20, colorBackground, colorFrame, 3,
colorBorder, 3)
dashboard_cell(column, row, txt) =>
table.cell(dashboard, column, row, txt, 0, 0, color.white, text_size =
dashboard_size)
dashboard_cell_bg(column, row, col) =>
table.cell_set_bgcolor(dashboard, column, row, col)
if barstate.islast and enableDashboard
dashboard_cell(0, 0, 'Current strategy')
dashboard_cell(0, 1, 'Current sensitivity')
dashboard_cell(0, 2, 'Current Position')
dashboard_cell(0, 3, 'Current trend')
dashboard_cell(0, 4, 'Trend strength')
dashboard_cell(0, 5, 'Volume')
dashboard_cell(0, 6, 'Volatility')
dashboard_cell(0, 7, 'Momentum')
dashboard_cell(0, 8, 'Timeframe trends📊')
table.merge_cells(dashboard, 0, 8, 1, 8)
dashboard_cell(0, 9, '1 min')
dashboard_cell(0, 10, '3 min')
dashboard_cell(0, 11, '5 min')
dashboard_cell(0, 12, '10 min')
dashboard_cell(0, 13, '15 min')
dashboard_cell(0, 14, '30 min')
dashboard_cell(0, 15, '1 Hour')
dashboard_cell(0, 16, '2 Hour')
dashboard_cell(0, 17, '4 Hour')
dashboard_cell(0, 18, '12 Hour')
dashboard_cell(0, 19, 'Daily')
dashboard_cell(1, 0, strategy)
dashboard_cell(1, 1, str.tostring(sensitivity))
dashboard_cell(1, 2, strategy != 'Trend scalper' ? (bool(trigger) ? 'Buy' :
'Sell') : '')
dashboard_cell_bg(1, 2, strategy != 'Trend scalper' ? (bool(trigger) ?
color.green : color.red) : colorBackground)
dashboard_cell(1, 3, emaBull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 3, emaBull ? color.green : color.red)
dashboard_cell(1, 4, str.tostring(bs, '0.0') + ' %')
dashboard_cell(1, 5, vosc > 0 ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 5, vosc > 0 ? color.green : color.red)
dashboard_cell(1, 6, adx > 20 ? 'Trending ' : 'Ranging ⚠️ ')
dashboard_cell_bg(1, 6, adx > 20 ? color.green : color.orange)
dashboard_cell(1, 7, rsi > 50 ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 7, rsi > 50 ? color.green : color.red)
dashboard_cell(1, 9, TF1Bull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 9, TF1Bull ? color.green : color.red)
dashboard_cell(1, 10, TF3Bull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 10, TF3Bull ? color.green : color.red)
dashboard_cell(1, 11, TF5Bull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 11, TF5Bull ? color.green : color.red)
dashboard_cell(1, 12, TF10Bull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 12, TF10Bull ? color.green : color.red)
dashboard_cell(1, 13, TF15Bull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 13, TF15Bull ? color.green : color.red)
dashboard_cell(1, 14, TF30Bull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 14, TF30Bull ? color.green : color.red)
dashboard_cell(1, 15, TF60Bull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 15, TF60Bull ? color.green : color.red)
dashboard_cell(1, 16, TF120Bull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 16, TF120Bull ? color.green : color.red)
dashboard_cell(1, 17, TF240Bull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 17, TF240Bull ? color.green : color.red)
dashboard_cell(1, 18, TF720Bull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 18, TF720Bull ? color.green : color.red)
dashboard_cell(1, 19, TFDBull ? 'Bullish' : 'Bearish')
dashboard_cell_bg(1, 19, TFDBull ? color.green : color.red)
l(css, k) =>
line lr = enableAutoTrend ? line.new(bar_index - lenTrendChannel + 1, A + k,
bar_index, B + k, extend = extend.right, color = css) : na
line.delete(lr[1])
var float rmse = 0 // ✅ Declare `rmse` with a default value
l(color.blue, rmse)
l(color.blue, 0)
l(color.blue, -rmse)
buy = showSignals and bull ? label.new(bar_index, low, close > smartFilter ?
'Smart\nBuy' : 'Buy', xloc.bar_index, yloc.belowbar, color.green,
label.style_label_up, color.white, size.normal) : na
sell = showSignals and bear ? label.new(bar_index, high, close < smartFilter ?
'Smart\nSell' : 'Sell', xloc.bar_index, yloc.abovebar, color.red,
label.style_label_down, color.white, size.normal) : na
tpLabels(tp) =>
tp1Bull = ta.crossover(rsi, 70)
tp2Bull = ta.crossover(rsi, 75)
tp3Bull = ta.crossover(rsi, 80)
tp1Bear = ta.crossunder(rsi, 30)
tp2Bear = ta.crossunder(rsi, 25)
tp3Bear = ta.crossunder(rsi, 20)
tp1Bull := tp1Bull and nz(ta.barssince(tp1Bull)[1], 9999) > countBull
tp2Bull := tp2Bull and ta.barssince(tp1Bull)[1] <= countBull
tp2Bull := tp2Bull and nz(ta.barssince(tp2Bull)[1], 9999) > countBull
tp3Bull := tp3Bull and ta.barssince(tp2Bull)[1] <= countBull
tp3Bull := tp3Bull and nz(ta.barssince(tp3Bull)[1], 9999) > countBull
tp1Bear := tp1Bear and nz(ta.barssince(tp1Bear)[1], 9999) > countBear
tp2Bear := tp2Bear and ta.barssince(tp1Bear)[1] <= countBear
tp2Bear := tp2Bear and nz(ta.barssince(tp2Bear)[1], 9999) > countBear
tp3Bear := tp3Bear and ta.barssince(tp2Bear)[1] <= countBear
tp3Bear := tp3Bear and nz(ta.barssince(tp3Bear)[1], 9999) > countBear
tp3Bear
if strategy != 'Trend scalper' and tpLabels
var int tp = 0 // ✅ Declare `tp` before using it
var float tp1Bull = 1.5
var float tp2Bull = 2.0
var float tp3Bull = 2.5
var float tp1Bear = -1.5
var float tp2Bear = -2.0
var float tp3Bear = -2.5
result = bool(trigger) ? (tp == 1 ? tp1Bull : tp == 2 ? tp2Bull : tp3Bull) :
(tp == 1 ? tp1Bear : tp == 2 ? tp2Bear : tp3Bear)

plotshape(tpLabels(1), '', shape.cross, location.abovebar, bool(trigger) ? green :


na, 0, 'TP 1', bool(trigger) ? green : na, false)
plotshape(tpLabels(2), '', shape.cross, location.abovebar, bool(trigger) ? green :
na, 0, 'TP 2', bool(trigger) ? green : na, false)
plotshape(tpLabels(3), '', shape.cross, location.abovebar, bool(trigger) ? green :
na, 0, 'TP 3', bool(trigger) ? green : na, false)
plotshape(tpLabels(1), '', shape.cross, location.belowbar, bool(trigger) ? na :
red, 0, 'TP 1', bool(trigger) ? na : red, false)
plotshape(tpLabels(2), '', shape.cross, location.belowbar, bool(trigger) ? na :
red, 0, 'TP 2', bool(trigger) ? na : red, false)
plotshape(tpLabels(3), '', shape.cross, location.belowbar, bool(trigger) ? na :
red, 0, 'TP 3', bool(trigger) ? na : red, false)
var label zzLabel = na
if array.size(zz) > 12 and enableSwings
if array.get(zz, 0) != array.get(zzOld, 0) or array.get(zz, 1) !=
array.get(zzOld, 1)
if array.get(zz, 2) == array.get(zzOld, 2) and array.get(zz, 3) ==
array.get(zzOld, 3)
label.delete(zzLabel) // Correct indentation

labelText = _dir == 1 ? array.get(zz, 0) > array.get(zz, 4) ? array.get(zz,


4) < array.get(zz, 8) ? 'High' : 'HH' : 'LH' : array.get(zz, 0) < array.get(zz,
4) ? array.get(zz, 4) > array.get(zz, 8) ? 'Low' : 'LL' : 'HL'

zzLabel := label.new(math.round(array.get(zz, 1)), array.get(zz, 0),


labelText, xloc.bar_index, yloc.price, color.new(color.white, 100), _dir == 1 ?
label.style_label_down : label.style_label_up, _dir == 1 ? color.green : color.red)
zzLabel

var sr_lines = array.new_line(11, na) // Ensured it's on a new line


for x = 1 to 10 by 1
line.set_color(array.get(sr_lines, x), color = line.get_y1(array.get(sr_lines,
x)) >= close ? color.red : color.lime)
if bool(ph) or bool(pl)
array.clear(sr_up_level)
array.clear(sr_dn_level)
array.clear(sr_strength)
for x = 0 to array.size(pivotvals) - 1 by 1
[hi, lo, strength] = get_sr_vals(x)
if check_sr(hi, lo, strength)
loc = find_loc(strength)
if loc < 5 and strength >= 2
array.insert(sr_strength, loc, strength)
array.insert(sr_up_level, loc, hi)
array.insert(sr_dn_level, loc, lo)

if enableSR and array.size(sr_strength) > 5 // Fixed condition


array.pop(sr_strength)
array.pop(sr_up_level)
array.pop(sr_dn_level)
for x = 1 to 10 by 1
line.delete(array.get(sr_lines, x))
for x = 0 to array.size(sr_up_level) > 0 ? array.size(sr_up_level) - 1 : na by
1
float mid = math.round_to_mintick((array.get(sr_up_level, x) +
array.get(sr_dn_level, x)) / 2)
rate = 100 * (mid - close) / close
array.set(sr_lines, x + 1, line.new(x1 = bar_index, y1 = mid, x2 =
bar_index - 1, y2 = mid, extend = extend.both, color = mid >= close ? color.red :
color.lime, style = LSRstyle, width = lineSrWidth))
if showCons and barstate.isconfirmed
dir := bool(hb_) and na(lb_) ? 1 : bool(lb_) and na(hb_) ? -1 : dir
if bool(hb_) and bool(lb_)
if bool(hb_) and bool(lb_)
if dir == 1
zz_ = hb_ // Use '=' instead of ':='
zz_
else
zz_ = lb_ // Use '=' instead of ':='
zz_
else
zz_ := bool(hb_) ? hb_ : bool(lb_) ? lb_ : na
zz_
for x = 0 to 1000 by 1 // Ensure correct loop syntax
if na(close) or dir != dir[x]
break // Properly indented inside the loop

if bool(zz_[x])
if na(pp)
pp := zz_[x]
pp
else
if dir[x] == 1 and zz_[x] > pp
pp := zz_[x]
pp
if dir[x] == -1 and zz_[x] < pp
pp := zz_[x]
pp

if pp != pp[1]
if consCnt > lenCons
if pp > condHi
breakUp := true
breakUp
if pp < condLo
breakDn := true
breakDn

if consCnt > 0 and pp <= condHi and pp >= condLo


consCnt := consCnt + 1
consCnt
else
consCnt := 0
consCnt
else
consCnt := consCnt + 1 // Ensure this is properly indented
consCnt

if consCnt >= lenCons


if consCnt == lenCons
condHi := H_
condLo := L_
condLo
else
line.delete(lineUp)
line.delete(lineDn)
condHi := math.max(condHi, high)
condLo := math.min(condLo, low)
condLo

lineUp := line.new(bar_index, condHi, bar_index - consCnt, condHi, color =


color.red, style = line.style_dashed)
lineDn := line.new(bar_index, condLo, bar_index - consCnt, condLo, color =
color.lime, style = line.style_dashed)
lineDn
fill(plot(condHi, '', na, 1, plot.style_stepline, editable = false), plot(condLo,
'', na, 1, plot.style_stepline, editable = false), paintCons and consCnt >
lenCons ? colorZone : na, '', false)
if box_ob and barstate.isconfirmed
if pvh
array.pop(pvh1_price)
array.pop(pvh1_time)
array.unshift(pvh1_price, pv1_high)
array.unshift(pvh1_time, pv1_time)

if array.size(pvh1_price) > 2
temp_pv_0 = array.get(pvh1_price, 0)
temp_pv_1 = array.get(pvh1_price, 1)
temp_pv_2 = array.get(pvh1_price, 2)

if temp_pv_0 > temp_pv_1


for i = 0 to array.size(pvl1_time) - 1 by 1
temp_ltcmrhh_time = array.get(pvl1_time, i)
if temp_ltcmrhh_time < array.get(pvh1_time, 0)
ltcmrhh_price := array.get(pvl1_price, i)
ltcmrhh_time := temp_ltcmrhh_time
break

if temp_pv_0 < temp_pv_1 and temp_pv_1 > temp_pv_2


array.pop(pvh2_price)
array.pop(pvh2_time)
array.unshift(pvh2_price, temp_pv_1)
array.unshift(pvh2_time, array.get(pvh1_time, 1)) // Corrected
indentation

if pvl
array.pop(pvl1_price)
array.pop(pvl1_time)
array.unshift(pvl1_price, pv1_low)
array.unshift(pvl1_time, pv1_time)
if array.size(pvl1_price) > 2
temp_pv_0 := array.get(pvl1_price, 0)
temp_pv_1 := array.get(pvl1_price, 1)
temp_pv_2 := array.get(pvl1_price, 2)
temp_pv_2

if temp_pv_0 < temp_pv_1


var int temp_htcmrll_time = na // Declare variable before using it (outside
loop)

for i = 0 to array.size(pvh1_time) - 1 by 1
temp_htcmrll_time := array.get(pvh1_time, i) // Use ':=' for
reassignment

if temp_htcmrll_time < array.get(pvl1_time, 0)


htcmrll_price := array.get(pvh1_price, i)
htcmrll_time := temp_htcmrll_time
break // Exit loop once condition is met

if temp_pv_0 > temp_pv_1 and temp_pv_1 < temp_pv_2


array.pop(pvl2_price)
array.pop(pvl2_time)
array.unshift(pvl2_price, temp_pv_1)
array.unshift(pvl2_time, array.get(pvl1_time, 1))
if trigger_high > htcmrll_price
if box_sv
loBox = box.new(left = array.get(pvl1_time, 0), top =
math.min(high[bar_index - array.get(pvl1_time, 0)], high[bar_index -
array.get(pvl1_time, 0) + 1]), right = bar_index, bottom = array.get(pvl1_price,
0), bgcolor = color.rgb(0, 255, 0, 80), border_color = color.rgb(0, 255, 0, 80),
extend = extend.right)
if array.size(long_boxes) >= 25
box.delete(array.shift(long_boxes))
array.push(long_boxes, loBox)
htcmrll_price := na
htcmrll_price
if trigger_low < ltcmrhh_price
if box_sv
hiBox = box.new(left = array.get(pvh1_time, 0), top =
array.get(pvh1_price, 0), right = bar_index, bottom = math.max(low[bar_index -
array.get(pvh1_time, 0)], low[bar_index - array.get(pvh1_time, 0) + 1]), bgcolor =
color.rgb(255, 0, 0, 80), border_color = color.rgb(255, 0, 0, 80), extend =
extend.right)
if array.size(short_boxes) >= 25
box.delete(array.shift(short_boxes))
array.push(short_boxes, hiBox)
ltcmrhh_price := na
ltcmrhh_price
if array.size(short_boxes) > 0
for i = array.size(short_boxes) - 1 to 0 by 1
tbox = array.get(short_boxes, i)
top = box.get_top(tbox)
bottom = box.get_bottom(tbox)
if trigger_high > bottom and box.get_left(tbox) + box_test_delay <
bar_index and box_test_sv
if box_hide_gray // Fixed missing 'if
box.set_bgcolor(tbox, #00000000)
box.set_border_color(tbox, #00000000)

else
box.set_bgcolor(tbox, color.rgb(192, 192, 192, 80))
box.set_border_color(tbox, color.rgb(192, 192, 192, 80))
if trigger_high > top and box.get_left(tbox) + box_fill_delay <
bar_index
if box_stop_sv
box.set_right(tbox, bar_index)
box.set_extend(tbox, extend.none)
array.remove(short_boxes, i)
if array.size(long_boxes) > 0
for i = array.size(long_boxes) - 1 to 0 by 1
lbox = array.get(long_boxes, i)
top = box.get_top(lbox)
bottom = box.get_bottom(lbox)
if trigger_low < top and box.get_left(lbox) + box_test_delay <
bar_index and box_test_sv
if box_hide_gray
box.set_bgcolor(lbox, #00000000)
box.set_border_color(lbox, #00000000)
else
box.set_bgcolor(lbox, color.rgb(192, 192, 192, 80))
box.set_border_color(lbox, color.rgb(192, 192, 192, 80))
if trigger_low < bottom and box.get_left(lbox) + box_fill_delay <
bar_index
if box_stop_sv
box.set_right(lbox, bar_index)
box.set_extend(lbox, extend.none)
array.remove(long_boxes, i)
if barstate.islast and eliteVP
for i = 0 to levelNum - 1 by 1
histogramLow = rangeLow + histogramHeight * i
histogramHigh = rangeLow + histogramHeight * (i + 1)
array.set(histogramLowList, i, histogramLow)
array.set(histogramHighList, i, histogramHigh)
for i = 0 to lookback - 1 by 1
currentBarHeight = high[i] - low[i]
currentBuyVolume = high[i] == low[i] ? 0 : volume[i] * (close[i] -
low[i]) / currentBarHeight
currentSellVolume = high[i] == low[i] ? 0 : volume[i] * (high[i] -
close[i]) / currentBarHeight
for j = 0 to levelNum - 1 by 1
histogramLow = array.get(histogramLowList, j)
histogramHigh = array.get(histogramHighList, j)
target = math.max(histogramHigh, high[i]) - math.min(histogramLow,
low[i]) - (math.max(histogramHigh, high[i]) - math.min(histogramHigh, high[i])) -
(math.max(histogramLow, low[i]) - math.min(histogramLow, low[i]))
histogramVolumePercentage = target / currentBarHeight
histogramBuyVolume = array.get(histogramBuyVolumeList, j)
histogramSellVolume = array.get(histogramSellVolumeList, j)
if histogramVolumePercentage > 0
array.set(histogramBuyVolumeList, j, histogramBuyVolume +
currentBuyVolume * histogramVolumePercentage)
array.set(histogramSellVolumeList, j, histogramSellVolume +
currentSellVolume * histogramVolumePercentage)
highestHistogramVolume = 0.0
for i = 0 to levelNum - 1 by 1
histogramBuyVolume = array.get(histogramBuyVolumeList, i)
histogramSellVolume = array.get(histogramSellVolumeList, i)
histogramVolume = histogramBuyVolume + histogramSellVolume
highestHistogramVolume := math.max(highestHistogramVolume, histogramVolume)
highestHistogramVolume
for i = 0 to levelNum - 1 by 1
histogramLow = array.get(histogramLowList, i)
histogramHigh = array.get(histogramHighList, i)
histogramBuyVolume = array.get(histogramBuyVolumeList, i)
histogramSellVolume = array.get(histogramSellVolumeList, i)
histogramVolume = histogramBuyVolume + histogramSellVolume
histogramWidth = levelWidth * histogramVolume / highestHistogramVolume
histogramBuyWidth = math.floor(histogramWidth * histogramBuyVolume /
histogramVolume)
histogramSellWidth = math.floor(histogramWidth * histogramSellVolume /
histogramVolume)
array.set(buyBars, i, box.new(bar_index + offset + levelWidth - 1 -
histogramBuyWidth, histogramHigh, bar_index + offset + levelWidth - 1,
histogramLow, colorBorderVP, bgcolor = colorBuyVP))
array.set(sellBars, i, box.new(bar_index + offset + levelWidth - 1 -
histogramBuyWidth, histogramHigh, bar_index + offset + levelWidth - 1 -
histogramBuyWidth - histogramSellWidth, histogramLow, colorBorderVP, bgcolor =
colorSellVP))
barcolor(momentumCandles and candlesMom() ? color.purple : candleColors ? strategy
== 'Trend scalper' ? colorBar : na(countBull) and na(countBear) ? color.gray :
bool(trigger) ? green : red : na, editable = false)
fill(plot(showTrendCloud and periodTrendCloud == 'New' ? ema150 : na, '', na,
editable = false), plot(showTrendCloud and periodTrendCloud == 'New' ? ema250 : na,
'', na, editable = false), ema150 > ema250 ? color.new(color.green, 70) : ema150 <
ema250 ? color.new(color.red, 70) : na)
plot(enableTrailingSL and bool(trigger) and nz(ta.barssince(low < trailingStop),
bar_index) > countBull ? trailingStop : na, '', green, 1, plot.style_linebr,
editable = false)
plot(enableTrailingSL and not bool(trigger) and nz(ta.barssince(high >
trailingStop), bar_index) > countBear ? trailingStop : na, '', red, 1,
plot.style_linebr, editable = false)
p0 = plot(avgOC, '', na, editable = false)
p1 = plot(ema5, '', colorEma5, editable = false)
p2 = plot(ema9, '', colorEma9, editable = false)
p3 = plot(ema21, '', colorEma21, editable = false)
fill(p0, p1, fillEma5)
fill(p1, p2, fillEma9)
fill(p2, p3, fillEma21)
fill(plot(showTrendCloud and periodTrendCloud != 'New' and trendcloud != 0 and
close > trendcloud ? trendcloud : na, '', color.green, 1, plot.style_linebr,
editable = false), p0, color.new(color.green, 90))
fill(plot(showTrendCloud and periodTrendCloud != 'New' and trendcloud != 0 and
close < trendcloud ? trendcloud : na, '', color.red, 1, plot.style_linebr, editable
= false), p0, color.new(color.red, 90))
fill(plot(hma, '', hma > hma[2] ? green : hma < hma[2] ? red : na, editable =
false), plot(hma[2], '', hma > hma[2] ? green : hma < hma[2] ? red : na, editable =
false), hma > hma[2] ? green : hma < hma[2] ? red : na)
// Alerts
f_crossed_over() =>
ret = false
for x = 0 to array.size(sr_up_level) > 0 ? array.size(sr_up_level) - 1 : na by
1
float mid = math.round_to_mintick((array.get(sr_up_level, x) +
array.get(sr_dn_level, x)) / 2)
if close[1] <= mid and close > mid
ret := true
ret
ret
f_crossed_under() =>
ret = false
for x = 0 to array.size(sr_up_level) > 0 ? array.size(sr_up_level) - 1 : na by
1
float mid = math.round_to_mintick((array.get(sr_up_level, x) +
array.get(sr_dn_level, x)) / 2)
if close[1] >= mid and close < mid
ret := true
ret
ret
f_sl_crossed() =>
ret = false
stop = enableTrailingSL ? trailingStop : stop_y
crossBull = low[1] >= stop[1] and low < stop[1] and ta.barssince(low[1] >=
stop[1] and low < stop[1])[1] >= countBull - 1
crossBear = high[1] <= stop[1] and high > stop[1] and ta.barssince(high[1] <=
stop[1] and high > stop[1])[1] >= countBear - 1
ret := bool(trigger)[1] ? crossBull : crossBear
ret
f_tp_crossed(tp) =>
ret = false
profit = tp
crossBull = high[1] <= profit[1] and high > profit[1] and ta.barssince(high[1]
<= profit[1] and high > profit[1])[1] >= countBull - 1
crossBear = low[1] >= profit[1] and low < profit[1] and ta.barssince(low[1] >=
profit[1] and low < profit[1])[1] >= countBear - 1
ret := bool(trigger)[1] ? crossBull : crossBear
ret
alert01 = bull and close <= smartFilter or bear and close >= smartFilter
alert02 = bull or bear
alert03 = bull and close > smartFilter or bear and close < smartFilter
alert04 = bull and close <= smartFilter
alert05 = f_crossed_over()
alert06 = bear and close >= smartFilter
alert07 = bull and close > smartFilter
alert08 = bear and close < smartFilter
alert09 = f_sl_crossed()
alert10 = f_crossed_under()
alert11 = f_tp_crossed(tp1_y)
alert12 = f_tp_crossed(tp2_y)
alert13 = f_tp_crossed(tp3_y)
alert14 = periodTrendCloud == 'New' ? ta.crossunder(ema150, ema250) : close <
trendcloud and (close > trendcloud)[1]
alert15 = periodTrendCloud == 'New' ? ta.crossover(ema150, ema250) : close >
trendcloud and (close < trendcloud)[1]
alerts(sym) =>
if alert01 or alert02 or alert03 or alert04 or alert05 or alert06 or alert07 or
alert08 or alert09 or alert10 or alert11 or alert12 or alert13 or alert14 or
alert15
alert('NEW ALERT', alert.freq_once_per_bar_close)
alerts(syminfo.tickerid)
alertcondition(alert01, 'Any Signal Buy / sell', 'Buy or Sell')
alertcondition(alert02, 'Any signal Buy/Smart Buy or Sell/Smart Sell', 'Buy/Smart
Buy or Sell/Smart Sell')
alertcondition(alert03, 'Any signal Smart Buy / Smart Sell', 'Smart Buy or Smart
Sell')
alertcondition(alert04, 'Buy alert', 'Buy')
alertcondition(alert05, 'Resistance Broken', 'Resistance Broken')
alertcondition(alert06, 'Sell alert', 'Sell')
alertcondition(alert07, 'Smart Buy', 'Smart Buy')
alertcondition(alert08, 'Smart Sell', 'Smart Sell')
alertcondition(alert09, 'Stop loss', 'Stop loss')
alertcondition(alert10, 'Support Broken', 'Support Broken')
alertcondition(alert11, 'Target 1', 'Target 1')
alertcondition(alert12, 'Target 2', 'Target 2')
alertcondition(alert13, 'Target 3', 'Target 3')
alertcondition(alert14, 'Trend cloud Bearish Alert', 'Trend cloud Bearish')
alertcondition(alert15, 'Trend cloud Bullish Alert', 'Trend cloud Bullish')

You might also like

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy