Berbilang penunjuk teknikal untuk pengesanan perubahan emas masa nyata dan strategi pengurusan risiko

MA EMA ATR STC HEIKIN ASHI CHANDELIER EXIT supertrend RMA VWMA WMA HMA
Tarikh penciptaan: 2025-03-05 10:35:15 Akhirnya diubah suai: 2025-03-05 10:35:15
Salin: 4 Bilangan klik: 548
2
fokus pada
319
Pengikut

Berbilang penunjuk teknikal untuk pengesanan perubahan emas masa nyata dan strategi pengurusan risiko Berbilang penunjuk teknikal untuk pengesanan perubahan emas masa nyata dan strategi pengurusan risiko

Gambaran Keseluruhan Strategi

Strategi pengendalian risiko dan pengesanan perubahan segera dalam pelbagai indikator teknikal emas adalah sistem perdagangan emas berdasarkan carta Heikin Ashi 1 minit, yang menggabungkan pelbagai indikator teknikal sebagai isyarat perdagangan dan alat pengesahan. Strategi ini terutamanya menggunakan keluar kejatuhan ((Chandelier Exit) sebagai petunjuk utama, dan secara pilihan menggabungkan penapis EMA, super trend ((SuperTrend) dan kitaran trend pasir ((Schaff Trend Cycle) sebagai alat pengesahan.

Prinsip Strategi

Strategi ini berdasarkan sistem pengesahan isyarat bertingkat, dengan logik teras sebagai berikut:

  1. Penjanaan isyarat penunjuk utamaStrategi menggunakan Exit Candelier sebagai penunjuk utama. Exit Candelier adalah penunjuk pengesanan trend yang menggunakan ATR (Rang Real Rata-rata) kali untuk menentukan kedudukan berhenti dan menghasilkan isyarat overhead dan overhead.

  2. Filter penunjuk yang disahkanStrategi ini membolehkan peniaga secara pilihan untuk mengaktifkan beberapa penunjuk pengesahan:

    • Penapis EMA: harga perlu berada di atas garis EMA yang ditetapkan (multicore) atau di bawah (blank)
    • Super Trend: perlu selaras dengan arah isyarat dominan
    • Siklus trend Schaff ((STC): perlu lebih tinggi daripada sempadan atas ((multihead) atau lebih rendah daripada sempadan bawah ((head kosong)
  3. Mekanisme tamat tempoh isyaratStrategi: Mempunyai fungsi tamat tempoh isyarat, yang membolehkan anda menetapkan jumlah token yang sah untuk isyarat, untuk mengelakkan perdagangan pada isyarat lama.

  4. Logik pelaksanaan transaksi: Apabila semua syarat yang dipilih dipenuhi, strategi menghasilkan isyarat masuk dan secara automatik menetapkan stop loss dengan jumlah mata tetap.

  5. Pengolahan data yang lebih baik: Kaedah menggunakan fungsi EMA dan SMA sampel bersyarat, dan penapis julat khusus, meningkatkan kecekapan pengiraan petunjuk teknikal.

  6. Sistem penglihatan: Menyediakan dashboard perdagangan yang menunjukkan status setiap petunjuk dan menandakan isyarat perdagangan dan kedudukan stop loss di carta.

Kelebihan Strategik

  1. Mekanisme pengesahan bergandaDengan pengesahan pelbagai petunjuk, pengurangan isyarat palsu yang ketara dan peningkatan ketepatan perdagangan. Isyarat perdagangan lebih dipercayai apabila beberapa petunjuk bersama-sama mengesahkan satu arah.

  2. Kumpulan Indeks Fleksibel: Pengguna bebas memilih untuk mengaktifkan atau mematikan pelbagai indikator pengesahan, menyesuaikan prestasi strategi mengikut keadaan pasaran yang berbeza.

  3. Pengurusan risiko yang tepatStrategi: membolehkan pengguna menetapkan titik berhenti dan kerugian tertentu untuk mengawal kadar risiko dan ganjaran setiap perdagangan.

  4. Kawalan tamat tempoh isyaratStrategi untuk mengelakkan dagangan pada isyarat yang telah tamat tempoh, dengan menetapkan isyarat yang sah, mengurangkan risiko ketinggalan.

  5. Antara muka dagangan yang sangat visual: Dashboard perdagangan secara langsung memaparkan status semua petunjuk, membantu peniaga menilai keadaan pasaran dengan cepat.

  6. Pengoptimuman untuk pasaran emasKaedah: Parameter telah dioptimumkan untuk ciri-ciri pasaran emas, dengan pertimbangan khusus untuk penukaran nilai mata ((1 mata = $ 0.1)).

  7. Kebolehan berdagang frekuensi tinggiTempoh 1 minit membolehkan strategi untuk menangkap turun naik harga jangka pendek, sesuai untuk peniaga dalam hari.

Risiko Strategik

  1. Risiko perdagangan berlebihanPeringkat 1 minit mungkin menghasilkan terlalu banyak isyarat perdagangan, yang menyebabkan peningkatan kos perdagangan dan perdagangan berlebihan. Penyelesaian adalah dengan menyesuaikan jumlah penunjuk pengesahan atau menambah syarat penapisan isyarat.

  2. Kesan kebisingan pasaranTempoh masa rendah lebih mudah diganggu oleh bunyi pasaran, menghasilkan isyarat palsu. Ia disyorkan untuk digunakan dengan berhati-hati pada masa yang bergelombang tinggi, atau untuk mengesahkan trend yang digabungkan dengan tempoh yang lebih lama.

  3. Penumpukan PenunjukPengesahan pelbagai indikator walaupun mengurangkan isyarat palsu, tetapi juga meningkatkan keterbelakangan sistem, yang boleh menyebabkan kehilangan sebahagian peluang keuntungan. Anda boleh mempertimbangkan untuk mengurangkan jumlah indikator pengesahan untuk meningkatkan kelajuan tindak balas.

  4. Batasan kerugian penghalang tetap: Stop loss dengan nombor titik tetap tidak mengambil kira perubahan turun naik pasaran, mungkin berhenti terlalu dekat pada masa turun naik tinggi, dan berhenti terlalu jauh pada masa turun naik rendah. Adalah disyorkan untuk menyesuaikan nilai stop loss mengikut dinamik ATR semasa.

  5. Risiko khas pasaran emasPasaran emas dipengaruhi oleh pelbagai faktor ekonomi makro, termasuk data inflasi, dasar bank pusat, geopolitik, dan lain-lain. Analisis teknikal semata-mata mungkin mengabaikan kesan-kesan ini.

  6. Ketergantungan penunjuk utamaStrategi yang terlalu bergantung kepada eksport Taiwan sebagai penunjuk utama, yang mungkin tidak berfungsi dengan baik di pasaran rantau. Disyorkan untuk menambah pilihan untuk memilih pelbagai penunjuk utama.

Arah pengoptimuman strategi

  1. Penunjuk utama kepelbagaianStrategi semasa hanya menyokong eksport Taiwan sebagai penunjuk utama, tetapi ia boleh diperluaskan untuk menyokong pelbagai pilihan penunjuk utama, seperti Brinband, MACD atau Adaptive Moving Average, untuk menyesuaikan diri dengan keadaan pasaran yang berbeza.

  2. Hentikan Dinamika Hentikan: Mengubah stop loss berangka titik tetap kepada stop loss berganda berasaskan ATR, yang lebih sesuai dengan perubahan turun naik pasaran. Sebagai contoh, boleh menggunakansl_value = atr(14) * 1.5Sebagai gantian kepada nombor mata tetap.

  3. Integrasi penapis masaMenambah penapis waktu dagangan, mengelakkan masa kecairan rendah atau siaran akhbar penting, dapat mengurangkan risiko tergelincir dan turun naik harga yang tidak dijangka.

  4. Tambah analisis volumIndikator jumlah dagangan yang bersepadu boleh mengesahkan kekuatan pergerakan harga, meningkatkan kualiti isyarat. Sebagai contoh, isyarat penembusan hanya disahkan apabila jumlah dagangan meningkat.

  5. Pengoptimuman Pembelajaran Mesin: Memperkenalkan algoritma pembelajaran mesin yang secara dinamik menyesuaikan berat setiap indikator, mengikut prestasi pasaran terkini dan parameter strategi penyesuaian.

  6. Mekanisme penyertaan dan penyertaan: Menerapkan mekanisme kemasukan dan keluar secara beratur untuk mengurangkan risiko masa di satu titik kemasukan dan keluar, seperti tiga pasang dan tiga pasang.

  7. Pengesahan pelbagai kitaran masa: Tambah pengesahan trend untuk tempoh masa yang lebih tinggi, hanya membuka kedudukan di arah trend untuk tempoh masa yang lebih tinggi, mengurangkan risiko perdagangan kebalikan.

  8. Analisis relevansi penunjuk: Analisis hubungan antara penunjuk yang dipilih, mengelakkan penggunaan penunjuk yang sangat berkaitan sebagai pengesahan, yang boleh menyebabkan pengesahan berganda palsu.

ringkaskan

Strategi pengesanan perubahan segera dan pengurusan risiko adalah sistem perdagangan kompleks yang ditujukan untuk peniaga jangka pendek, yang menyediakan isyarat perdagangan yang lebih dipercayai dengan menggabungkan pelbagai petunjuk teknikal. Kelebihan utama strategi ini adalah mekanisme pengesahan petunjuk yang fleksibel dan antara muka visual yang intuitif, yang membolehkan peniaga menyesuaikan parameter strategi mengikut keadaan pasaran. Walau bagaimanapun, pengguna perlu waspada terhadap risiko yang wujud dalam perdagangan jangka masa rendah, termasuk perdagangan berlebihan dan kesan bunyi pasaran.

Strategi ini dapat meningkatkan lagi kesesuaian dan kestabilan dengan melaksanakan langkah-langkah pengoptimuman yang disyorkan, terutamanya dengan penghentian dan kehilangan dinamik, pengesahan kitaran masa dan kepelbagaian penunjuk utama. Strategi ini menyediakan kerangka analisis teknikal untuk peniaga hari dan peminat perdagangan emas garis pendek, tetapi harus digunakan dalam kombinasi dengan prinsip pengurusan wang dan pemahaman asas pasaran untuk mencapai kesan terbaik.

Akhirnya, kejayaan perdagangan bergantung bukan sahaja pada strategi itu sendiri, tetapi juga pada pemahaman dan pelaksanaan strategi yang betul oleh peniaga. Pemantauan, pengoptimuman dan penyesuaian strategi yang berterusan adalah kunci untuk mencapai hasil perdagangan yang stabil dalam jangka panjang.

Kod sumber strategi
/*backtest
start: 2024-03-05 00:00:00
end: 2025-03-03 08:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"ETH_USDT"}]
*/

//@version=5
strategy("1 Min Gold Heikin Ashi Strategy", overlay=true, max_bars_back=500)

// Adjustable TP & SL in Pips
tp_pips = input.int(50, title="Take Profit (Pips)")
sl_pips = input.int(30, title="Stop Loss (Pips)")

// Convert pips to price value for XAUUSD (1 pip = 0.1 in Gold)
tp_value = tp_pips * 0.1
sl_value = sl_pips * 0.1

// Fixed components
justcontinue = bool(true)

ma(_source, _length, _type) => 
    switch _type
        "SMA"  => ta.sma (_source, _length)
        "EMA"  => ta.ema (_source, _length)
        "RMA"  => ta.rma (_source, _length)
        "WMA"  => ta.wma (_source, _length)
        "VWMA" => ta.vwma(_source, _length)

alarm(_osc, _message) => 
    alert(syminfo.ticker + ' ' + _osc + ' : ' + _message + ', price (' + str.tostring(close, format.mintick) + ')')

// Conditional Sampling EMA Function 
Cond_EMA(x, cond, n) =>
    var val = array.new_float(0)
    var ema_val = array.new_float(1)
    if cond
        array.push(val, x)
        if array.size(val) > 1
            array.remove(val, 0)
        if na(array.get(ema_val, 0))
            array.fill(ema_val, array.get(val, 0))
        array.set(ema_val, 0, (array.get(val, 0) - array.get(ema_val, 0)) * (2 / (n + 1)) + array.get(ema_val, 0))
    EMA = array.get(ema_val, 0)
    EMA

// Conditional Sampling SMA Function
Cond_SMA(x, cond, n) =>
    var vals = array.new_float(0)
    if cond
        array.push(vals, x)
        if array.size(vals) > n
            array.remove(vals, 0)
    SMA = array.avg(vals)
    SMA

// Standard Deviation Function
Stdev(x, n) =>
    math.sqrt(Cond_SMA(math.pow(x, 2), 1, n) - math.pow(Cond_SMA(x, 1, n), 2))

// Range Size Function
rng_size(x, scale, qty, n) =>
    ATR = Cond_EMA(ta.tr(true), 1, n)
    AC = Cond_EMA(math.abs(x - x[1]), 1, n)
    SD = Stdev(x, n)
    rng_size = scale == 'Pips' ? qty * 0.0001 : scale == 'Points' ? qty * syminfo.pointvalue : scale == '% of Price' ? close * qty / 100 : scale == 'ATR' ? qty * ATR : scale == 'Average Change' ? qty * AC : scale == 'Standard Deviation' ? qty * SD : scale == 'Ticks' ? qty * syminfo.mintick : qty
    rng_size

// Two Type Range Filter Function
rng_filt(h, l, rng_, n, type, smooth, sn, av_rf, av_n) =>
    rng_smooth = Cond_EMA(rng_, 1, sn)
    r = smooth ? rng_smooth : rng_
    var rfilt = array.new_float(2, (h + l) / 2)
    array.set(rfilt, 1, array.get(rfilt, 0))
    if type == 'Type 1'
        if h - r > array.get(rfilt, 1)
            array.set(rfilt, 0, h - r)
        if l + r < array.get(rfilt, 1)
            array.set(rfilt, 0, l + r)
    if type == 'Type 2'
        if h >= array.get(rfilt, 1) + r
            array.set(rfilt, 0, array.get(rfilt, 1) + math.floor(math.abs(h - array.get(rfilt, 1)) / r) * r)
        if l <= array.get(rfilt, 1) - r
            array.set(rfilt, 0, array.get(rfilt, 1) - math.floor(math.abs(l - array.get(rfilt, 1)) / r) * r)
    rng_filt1 = array.get(rfilt, 0)
    hi_band1 = rng_filt1 + r
    lo_band1 = rng_filt1 - r
    rng_filt2 = Cond_EMA(rng_filt1, rng_filt1 != rng_filt1[1], av_n)
    hi_band2 = Cond_EMA(hi_band1, rng_filt1 != rng_filt1[1], av_n)
    lo_band2 = Cond_EMA(lo_band1, rng_filt1 != rng_filt1[1], av_n)
    rng_filt = av_rf ? rng_filt2 : rng_filt1
    hi_band = av_rf ? hi_band2 : hi_band1
    lo_band = av_rf ? lo_band2 : lo_band1
    [hi_band, lo_band, rng_filt]

// Moving Average Function
ma_function(source, length, type) =>
    if type == 'RMA'
        ta.rma(source, length)
    else if type == 'SMA'
        ta.sma(source, length)
    else if type == 'EMA'
        ta.ema(source, length)
    else if type == 'WMA'
        ta.wma(source, length)
    else if type == 'HMA'
        if (length < 2)
            ta.hma(source, 2)
        else
            ta.hma(source, length)
    else 
        ta.vwma(source, length)

// Get Table Size
table_size(s) => 
    switch s
        "Auto"   => size.auto   
        "Huge"   => size.huge   
        "Large"  => size.large  
        "Normal" => size.normal 
        "Small"  => size.small
        => size.tiny

// Confirmation Setup
confirmation_counter = array.new_string(0)
confirmation_val = array.new_string(0)
confirmation_val_short = array.new_string(0)

pushConfirmation(respect, label, longCondition, shortCondition) =>
    if respect
        array.push(confirmation_counter, label)
        array.push(confirmation_val, longCondition ? "✔️" : "❌")
        array.push(confirmation_val_short, shortCondition ? "✔️" : "❌")

leadinglongcond = bool(na)
leadingshortcond = bool(na)
longCond = bool(na)
shortCond = bool(na)
longCondition = bool(na)
shortCondition = bool(na)

// Indicator Setup Inputs
setup_group = "████████ Indicator Setup ████████"
signalexpiry = input.int(defval=3, title='Signal Expiry Candle Count', group=setup_group, inline='expiry', tooltip="Number of candles to wait for all indicators to confirm a signal. Default is 3.")
alternatesignal = input.bool(true, "Alternate Signal", group=setup_group, inline='alternate')
showsignal = input.bool(true, "Show Long/Short Signal", group=setup_group, inline='showsignal', tooltip="Option to turn on/off the Long/Short signal shown on the chart.")
showdashboard = input.bool(true, "Show Dashboard", group=setup_group, inline='dashboard')

string i_tab1Ypos = input.string('bottom', 'Dashboard Position', group=setup_group, inline='dashboard2', options=['top', 'middle', 'bottom'])
string i_tab1Xpos = input.string('right', '', inline='dashboard2', group=setup_group, options=['left', 'center', 'right'])
in_dashboardtab_size = input.string(title="Dashboard Size", defval="Normal", options=["Auto", "Huge", "Large", "Normal", "Small", "Tiny"], group=setup_group, inline="dashboard3")

// Confirmation Indicator Settings
confirmation_group = "████████ Confirmation Indicators (filter) ████████"
respectce = input.bool(false, "Chandelier Exit", group=confirmation_group, inline='ce')
respectema = input.bool(false, "EMA Filter", group=confirmation_group, inline='respectema')
respectemaperiod = input.int(defval=200, minval=1, title='', group=confirmation_group, inline='respectema', tooltip="EMA filter for confirmation.")
respectst = input.bool(false, "SuperTrend", group=confirmation_group, inline='st')
respectstc = input.bool(false, "Schaff Trend Cycle (STC)", group=confirmation_group, inline='stc')

// Switchboard Indicators
switchboard_group = "████ Switch Board (Turn On/Off Overlay Indicators) ████"
switch_ema = input.bool(false, "EMA", group=switchboard_group, inline='Switch1')
switch_supertrend = input.bool(false, "Supertrend", group=switchboard_group, inline='Switch2')
switch_stc = input.bool(false, "STC", group=switchboard_group, inline='Switch3')

// ----------------------------------------
// 4. Indicator Code

// Chandelier Exit
////////////////////////////////////////////////
////// Chandelier Exit
///////////////////////////////////////////////
ChandelierE = "██████████ Chandelier Exit ██████████"
ce_length = input.int(title='ATR Period', defval=22, group=ChandelierE)
ce_mult = input.float(title='ATR Multiplier', step=0.1, defval=3.0, group=ChandelierE)
showLabels = input.bool(title='Show Buy/Sell Labels?', defval=true, group=ChandelierE)
useClose = input.bool(title='Use Close Price for Extremums?', defval=true, group=ChandelierE)
highlightState = input.bool(title='Highlight State?', defval=true, group=ChandelierE)

ce_atr = ce_mult * ta.atr(ce_length)
longStop = (useClose ? ta.highest(close, ce_length) : ta.highest(ce_length)) - ce_atr
longStopPrev = nz(longStop[1], longStop)
longStop := close[1] > longStopPrev ? math.max(longStop, longStopPrev) : longStop

shortStop = (useClose ? ta.lowest(close, ce_length) : ta.lowest(ce_length)) + ce_atr
shortStopPrev = nz(shortStop[1], shortStop)
shortStop := close[1] < shortStopPrev ? math.min(shortStop, shortStopPrev) : shortStop

var int dir = 1
dir := close > shortStopPrev ? 1 : close < longStopPrev ? -1 : dir

ce_long = dir == 1 
ce_short = dir == -1

// EMA Filter
////////////////////////////////////////////////////////////////////////////
//////////// EMA Filter
////////////////////////////////////////////////////////////////////////////
respectemavalue = ta.ema(close, respectemaperiod)
isaboverespectema = close > respectemavalue
isbelowrespectema = close < respectemavalue

// SuperTrend Calculation
////////////////////////////////
///// SuperTrend
//////////////////////////////
sp_group = "██████████ SuperTrend ██████████"
Periods = input.int(title='ATR Period', defval=10, group=sp_group)
stsrc = input.source(hl2, title='Source', group=sp_group)
Multiplier = input.float(title='ATR Multiplier', step=0.1, defval=3.0, group=sp_group)
changeATR = input.bool(title='Change ATR Calculation Method?', defval=true, group=sp_group)

statr2 = ta.sma(ta.tr, Periods)
statr = changeATR ? ta.atr(Periods) : statr2
stup = stsrc - Multiplier * statr
up1 = nz(stup[1], stup)
stup := close[1] > up1 ? math.max(stup, up1) : stup
dn = stsrc + Multiplier * statr
dn1 = nz(dn[1], dn)
dn := close[1] < dn1 ? math.min(dn, dn1) : dn
sttrend = 1
sttrend := nz(sttrend[1], sttrend)
sttrend := sttrend == -1 and close > dn1 ? 1 : sttrend == 1 and close < up1 ? -1 : sttrend
stbuySignal = sttrend == 1 and sttrend[1] == -1
stsellSignal = sttrend == -1 and sttrend[1] == 1

isstup = bool(na)
isstdown = bool(na)
isstup := sttrend == 1
isstdown := sttrend != 1

// Schaff Trend Cycle (STC)
/////////////////////////
/// STC overlay signal
/////////////////////////
stc_group = "██████████ Schaff Trend Cycle (STC) ██████████"
fastLength = input.int(title='MACD Fast Length', defval=23, group=stc_group)
slowLength = input.int(title='MACD Slow Length', defval=50, group=stc_group)
cycleLength = input.int(title='Cycle Length', defval=10, group=stc_group)
d1Length = input.int(title='1st %D Length', defval=3, group=stc_group)
d2Length = input.int(title='2nd %D Length', defval=3, group=stc_group)
srcstc = input.source(title='Source', defval=close, group=stc_group)
upper = input.int(title='Upper Band', defval=75, group=stc_group)
lower = input.int(title='Lower Band', defval=25, group=stc_group)
v_show_last  = input.int(2000, "Plotting Length", group=stc_group)

macd = ta.ema(srcstc, fastLength) - ta.ema(srcstc, slowLength)
k = nz(fixnan(ta.stoch(macd, macd, macd, cycleLength)))
d = ta.ema(k, d1Length)
kd = nz(fixnan(ta.stoch(d, d, d, cycleLength)))
stc = ta.ema(kd, d2Length)
stc := math.max(math.min(stc, 100), 0)

stcColor1 = stc > stc[1] ? color.green : color.red
stcColor2 = stc > upper ? color.green : stc <= lower ? color.red : color.orange

upperCrossover = ta.crossover(stc, upper)
upperCrossunder = ta.crossunder(stc, upper)
lowerCrossover = ta.crossover(stc, lower)
lowerCrossunder = ta.crossunder(stc, lower)
stcup = stc >= upper
stcdown = stc <= lower

// ----------------------------------------
// 5. Switchboard Code

// Additional code for EMA from Switchboard
/////////////////////////////////////////////////////////////////////////
// EMA Selection
/////////////////////////////////////////////////////////////////////////
ma_group= "██████████ MAs Line ██████████"

len1bool = input.bool(true, '', group=ma_group, inline='len1')
len1 = input.int(5, title='MA 1', group=ma_group, inline='len1')
string ma_1_type = input.string(defval='EMA', title='Type', options=['RMA', 'SMA', 'EMA', 'WMA', 'HMA', 'VWMA'], inline='len1', group=ma_group)
color ma_1_colour = input.color(color.rgb(254, 234, 74, 0), '', inline='len1', group=ma_group)

len2bool = input.bool(true, '', group=ma_group, inline='len2')
len2 = input.int(13, minval=1, title='MA 2', group=ma_group, inline='len2')
string ma_2_type = input.string(defval='EMA', title='Type', options=['RMA', 'SMA', 'EMA', 'WMA', 'HMA', 'VWMA'], inline='len2', group=ma_group)
color ma_2_colour = input.color(color.rgb(253, 84, 87, 0), '', inline='len2', group=ma_group)

len3bool = input.bool(false, '', group=ma_group, inline='len3')
len3 = input.int(20, minval=1, title='MA 3', group=ma_group, inline='len3')
string ma_3_type = input.string(defval='EMA', title='Type', options=['RMA', 'SMA', 'EMA', 'WMA', 'HMA', 'VWMA'], inline='len3', group=ma_group)
color ma_3_colour = input.color(color.new(color.aqua, 0), '', inline='len3', group=ma_group)

len4bool = input.bool(true, '', group=ma_group, inline='len4')
len4 = input.int(50, minval=1, title='MA 4', group=ma_group, inline='len4')
string ma_4_type = input.string(defval='EMA', title='Type', options=['RMA', 'SMA', 'EMA', 'WMA', 'HMA', 'VWMA'], inline='len4', group=ma_group)
color ma_4_colour = input.color(color.new(color.blue, 0), '', inline='len4', group=ma_group)

len5bool = input.bool(true, '', group=ma_group, inline='len5')
len5 = input.int(200, minval=1, title='MA 5', group=ma_group, inline='len5')
string ma_5_type = input.string(defval='EMA', title='Type', options=['RMA', 'SMA', 'EMA', 'WMA', 'HMA', 'VWMA'], inline='len5', group=ma_group)
color ma_5_colour = input.color(color.new(color.white, 0), '', inline='len5', group=ma_group)

// Request Security for MA calculations
ema1 = request.security(syminfo.tickerid, timeframe.period, ma_function(close, len1, ma_1_type))
ema2 = request.security(syminfo.tickerid, timeframe.period, ma_function(close, len2, ma_2_type))
ema3 = request.security(syminfo.tickerid, timeframe.period, ma_function(close, len3, ma_3_type))
ema4 = request.security(syminfo.tickerid, timeframe.period, ma_function(close, len4, ma_4_type))
ema5 = request.security(syminfo.tickerid, timeframe.period, ma_function(close, len5, ma_5_type))

// Plot the Moving Averages
plot(len1bool and switch_ema ? ema1 : na, color=ma_1_colour, linewidth=2, title='MA 1')
plot(len2bool and switch_ema ? ema2 : na, color=ma_2_colour, linewidth=2, title='MA 2')
plot(len3bool and switch_ema ? ema3 : na, color=ma_3_colour, linewidth=2, title='MA 3')
plot(len4bool and switch_ema ? ema4 : na, color=ma_4_colour, linewidth=2, title='MA 4')
plot(len5bool and switch_ema ? ema5 : na, color=ma_5_colour, linewidth=2, title='MA 5')

// Additional code for SuperTrend from switchboard
///////////////////////////////////////////////////
// SuperTrend - Switchboard
///////////////////////////////////////////////////
upPlot = plot(sttrend == 1 and switch_supertrend ? stup : na, title='Up Trend', style=plot.style_linebr, linewidth=2, color=color.new(color.green, 0))
plotshape(stbuySignal and switch_supertrend ? stup : na, title='UpTrend Begins', location=location.absolute, style=shape.circle, size=size.tiny, color=color.new(color.green, 0))

dnPlot = plot(sttrend != 1 and switch_supertrend ? dn : na, title='Down Trend', style=plot.style_linebr, linewidth=2, color=color.new(color.red, 0))
plotshape(stsellSignal and switch_supertrend ? dn : na, title='DownTrend Begins', location=location.absolute, style=shape.circle, size=size.tiny, color=color.new(color.red, 0))

// Additional code for Schaff Trend Cycle (STC) from switchboard
/////////////////////////////////////////////
// Schaff Trend Cycle (STC) - Switchboard
/////////////////////////////////////////////
plotshape(stcdown and switch_stc ? true : na, style=shape.circle, location=location.top, show_last=v_show_last, color=color.new(color.red, 0), title='STC Sell')
plotshape(stcup and switch_stc ? true : na, style=shape.circle, location=location.top, show_last=v_show_last, color=color.new(color.green, 0), title='STC Buy')

// ----------------------------------------
// 6. Declare and Initialize 'leadingindicator'
leadingindicator = input.string(title="Leading Indicator", defval="Chandelier Exit",
  options=["Chandelier Exit"], group="████████ Main Indicator (signal) ████████")

// 6. Leading Indicator Logic
if leadingindicator == 'Chandelier Exit'
    leadinglongcond := ce_long
    leadingshortcond := ce_short

// ----------------------------------------
// 7. Confirmation Indicator Logic
longCond := leadinglongcond
shortCond := leadingshortcond

longCond := longCond  and   (respectce ? ce_long : justcontinue)
shortCond := shortCond and   (respectce ? ce_short : justcontinue)

longCond := longCond  and   (respectema ? isaboverespectema : justcontinue)
shortCond := shortCond and   (respectema ? isbelowrespectema : justcontinue)

longCond := longCond  and   (respectst ? isstup : justcontinue)
shortCond := shortCond and   (respectst ? isstdown : justcontinue)

longCond := longCond  and   (respectstc ? stcup : justcontinue)


// ----------------------------------------
// 7. Confirmation Indicator Logic

longCond := leadinglongcond
shortCond := leadingshortcond

longCond := longCond  and   (respectce ? ce_long : justcontinue)
shortCond := shortCond and   (respectce ? ce_short : justcontinue)

longCond := longCond  and   (respectema ? isaboverespectema : justcontinue)
shortCond := shortCond and   (respectema ? isbelowrespectema : justcontinue)

longCond := longCond  and   (respectst ? isstup : justcontinue)
shortCond := shortCond and   (respectst ? isstdown : justcontinue)

longCond := longCond  and   (respectstc ? stcup : justcontinue)
shortCond := shortCond and   (respectstc ? stcdown : justcontinue)

// ----------------------------------------
// 8. Function to Update Dashboard Label

pushConfirmation(respectce, "Chandelier Exit", ce_long, ce_short)
pushConfirmation(respectema, "EMA", isaboverespectema, isbelowrespectema)
pushConfirmation(respectst, "SuperTrend", isstup, isstdown)
pushConfirmation(respectstc, "Schaff Trend Cycle", stcup, stcdown)

// ----------------------------------------
// 9. Final Part (Dashboard Table and Signal Plotting)

leadingstatus = leadinglongcond ? "✔️" : "❌"
leadingstatus_short = leadingshortcond ? "✔️" : "❌"

rowcount = int(na)
if array.size(confirmation_counter) == 0
    rowcount := 5
else
    rowcount := array.size(confirmation_counter) + 4

// Signal Expiry Logic
var int leadinglong_count = 0
var int leadinglong_count2 = 0
var int leadingshort_count = 0
var int leadingshort_count2 = 0

if leadinglongcond
    leadinglong_count := leadinglong_count + 1
    leadinglong_count2 := leadinglong_count

for i = 1 to 100
    if leadinglongcond[i]
        leadinglong_count := leadinglong_count + 1
        leadinglong_count2 := leadinglong_count
    else
        leadinglong_count := 0
        break

if leadingshortcond
    leadingshort_count := leadingshort_count + 1
    leadingshort_count2 := leadingshort_count

for i = 1 to 100
    if leadingshortcond[i]
        leadingshort_count := leadingshort_count + 1
        leadingshort_count2 := leadingshort_count
    else
        leadingshort_count := 0
        break

// Expiry Condition
CondIni = 0

// If expiry option is used
longcond_withexpiry = longCond and leadinglong_count2 <= signalexpiry
shortcond_withexpiry = shortCond and leadingshort_count2 <= signalexpiry

// Without expiry
longCondition := longcond_withexpiry and CondIni[1] == -1
shortCondition := shortcond_withexpiry and CondIni[1] == 1

if alternatesignal
    longCondition := longcond_withexpiry and CondIni[1] == -1  
    shortCondition := shortcond_withexpiry and CondIni[1] == 1 
else
    longCondition := longcond_withexpiry  
    shortCondition := shortcond_withexpiry 

CondIni := longcond_withexpiry ? 1 : shortcond_withexpiry ? -1 : CondIni[1]

// Check if expiry count is crossed
is_expiry_count_crossed_long = leadinglong_count2 >= signalexpiry 
is_expiry_count_crossed_short = leadingshort_count2 >= signalexpiry 

// Plot signals on chart
plotshape(showsignal ? (longCondition[1] ? false : longCondition) : na, title='Buy Signal', text='long', textcolor=color.new(color.white, 0), style=shape.labelup, size=size.tiny, location=location.belowbar, color=color.new(color.green, 0))
plotshape(showsignal ? (shortCondition[1] ? false : shortCondition) : na, title='Sell Signal', text='short', textcolor=color.new(color.white, 0), style=shape.labeldown, size=size.tiny, location=location.abovebar, color=color.new(color.red, 0))

// Alerts
alertcondition(longCondition, title='Buy Alert', message='BUY')
alertcondition(shortCondition, title='Sell Alert', message='SELL')
alertcondition(longCondition or shortCondition, title='Buy or Sell Alert', message="Buy or Sell Alert")

/// ----------------------------------------
// 10. Strategy Execution - Entries & Exits

// Use already declared TP & SL values (from the start of the script)

// Long Entry Conditions
if longCondition
    strategy.entry("Long", strategy.long)
    strategy.exit("TakeProfit_Long", from_entry="Long", limit=close + tp_value, stop=close - sl_value)

// Short Entry Conditions
if shortCondition
    strategy.entry("Short", strategy.short)
    strategy.exit("TakeProfit_Short", from_entry="Short", limit=close - tp_value, stop=close + sl_value)