Trend Mengikuti Strategi Penunjuk EMA Williams Berganda


Tarikh penciptaan: 2023-11-21 15:16:21 Akhirnya diubah suai: 2023-11-21 15:16:21
Salin: 0 Bilangan klik: 630
1
fokus pada
1617
Pengikut

Trend Mengikuti Strategi Penunjuk EMA Williams Berganda

Gambaran keseluruhan

Strategi ini menggabungkan kedua-dua EMA dan Williams untuk mengenal pasti arah trend, dan untuk menjejaki apabila trend kuat.

  1. Menapis trend terkuat menggunakan gabungan dua EMA
  2. Indeks Williams mengesahkan bahawa ia berada di zon overbought dan oversold
  3. Mengekalkan RSI untuk mengelakkan kenaikan dan penurunan

Prinsip

Strategi ini menggunakan EMA jangka pendek dan EMA jangka panjang dalam kedua-dua indikator EMA. Apabila EMA jangka pendek menghasilkan isyarat beli apabila melintasi EMA jangka panjang ke atas, dan EMA jangka pendek menghasilkan isyarat jual apabila melintasi EMA jangka panjang ke bawah, memanfaatkan EMA ganda untuk menangkap trend jangka panjang.

Selain itu, strategi ini juga digabungkan dengan Indeks Williams untuk mengenal pasti keadaan berbalik. Indeks Williams menilai sama ada harga berada dalam keadaan overbought atau oversold dengan menentukan puncak dan titik rendah berkala. Apabila Indeks Williams menunjukkan overbought, ia menghasilkan isyarat jual; apabila ia menunjukkan oversold, ia menghasilkan isyarat beli.

Dalam kod ini, logik penghakiman adalah:

Masukkan banyak mata: EMA jangka pendek melintasi EMA pertengahan dan EMA jangka panjang, dan penunjuk Williams menunjukkan kawasan jual lebihan, dan di kawasan jual lebihan membentuk titik terendah, yang menunjukkan peluang untuk berbalik, ketika ini menghasilkan isyarat beli.

Kemasukan kosong: EMA jangka pendek menembusi EMA pertengahan dan EMA jangka panjang, dan Williams menunjukkan kawasan overbought dan membentuk titik tertinggi di kawasan oversold, yang menunjukkan peluang untuk berbalik, yang menghasilkan isyarat menjual.

Selain itu, strategi ini juga memperkenalkan RSI untuk lebih mengesahkan isyarat perdagangan dan mengelakkan pengejaran buta untuk mematikan penurunan.

Kelebihan

Kelebihan utama strategi ini ialah menggunakan dua EMA untuk menyaring banyak trend yang tidak berkesan dan hanya memilih trend jangka menengah dan jangka panjang yang paling kuat untuk dijejaki, dengan itu menyaring kebisingan dan mengurangkan perdagangan yang tidak berkesan.

Di samping itu, pengenalan penunjuk Williams juga mempunyai kesan yang sangat baik. Pertama, ia dapat mengenal pasti peluang untuk berbalik dan dengan itu melonggarkan kedudukan tepat pada masanya; kedua, ia dapat mengesahkan lebih lanjut keberkesanan isyarat trend.

Penggunaan gabungan dua EMA dan Williams membolehkan strategi ini untuk mendapatkan keuntungan yang baik dalam jangka masa sederhana dan jangka panjang, tetapi juga dapat mengenal pasti pembalikan dan mengehadkan kerugian.

Risiko

Risiko utama strategi ini adalah kesukaran untuk mengenal pasti titik pembalikan trend. Walaupun pengenalan Indeks Williams dan RSI untuk memastikan keberkesanan perdagangan pembalikan, kesukaran untuk berdagang pembalikan masih besar dan tidak dapat sepenuhnya mengelakkan risiko mengejar penurunan.

Di samping itu, terdapat beberapa ketinggalan dalam gabungan EMA ganda itu sendiri. Ia juga boleh menyebabkan kesulitan untuk mengenal pasti strategi apabila trend jangka pendek dan trend jangka menengah dan jangka panjang terputus.

Pengoptimuman

Strategi ini boleh dioptimumkan dalam beberapa aspek:

  1. Uji lebih banyak kombinasi kitaran EMA untuk mencari parameter yang lebih baik

  2. Menambah mekanisme penarikan diri yang beradaptasi, menggunakan ATR, indeks volatiliti dan lain-lain untuk menilai perubahan trend

  3. Menambah elemen pembelajaran mesin, menggunakan LSTM dan lain-lain untuk trend dan ramalan pembalikan

  4. Kaedah-kaedah seperti teori gelombang digunakan untuk menyempurnakan lagi peraturan perdagangan berbalik

  5. Memperkenalkan pengurusan kedudukan yang menyesuaikan diri, menyesuaikan saiz kedudukan mengikut keadaan pasaran

ringkaskan

Strategi ini berjaya menggabungkan kedua-dua EMA dan penunjuk Williams untuk menangkap trend jangka menengah dan panjang, dan memperoleh keuntungan yang lebih tinggi dalam trend besar. Pada masa yang sama, pengenalan penunjuk Williams juga membolehkan strategi untuk mengenali pembalikan dan menghentikan kerugian tepat pada masanya. Langkah seterusnya, dengan memperkenalkan lebih banyak penunjuk dan model untuk mengoptimumkan, meningkatkan lagi kestabilan strategi.

Kod sumber strategi
/*backtest
start: 2022-11-20 00:00:00
end: 2022-11-29 05:20:00
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

// This source code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © B_L_A_C_K_S_C_O_R_P_I_O_N
// v 1.1

//@version=4
strategy("vijkirti buy sell 99%", overlay=true, default_qty_type=strategy.cash, default_qty_value=1000, currency='USD')

// *************Appearance*************
theme = input(type=input.string, defval="dark", options=["light","dark"], group="Appearance")
show_fractals = input(false, "Show Fractals", group="Appearance")
show_ema = input(false, "Show EMAs", group="Appearance")

// *************colors*************
color_green = color.green
color_red = color.red
color_yellow = color.yellow
color_orange = color.orange
color_blue = color.blue
color_white = color.white

// *************WF*************
// Define "n" as the number of periods and keep a minimum value of 2 for error handling.
n = input(title="Fractal Periods", defval=2, minval=2, type=input.integer, group="Williams Fractals")

// UpFractal
bool upflagDownFrontier = true
bool upflagUpFrontier0 = true
bool upflagUpFrontier1 = true
bool upflagUpFrontier2 = true
bool upflagUpFrontier3 = true
bool upflagUpFrontier4 = true

for i = 1 to n
    upflagDownFrontier := upflagDownFrontier and (high[n-i] < high[n])
    upflagUpFrontier0 := upflagUpFrontier0 and (high[n+i] < high[n])
    upflagUpFrontier1 := upflagUpFrontier1 and (high[n+1] <= high[n] and high[n+i + 1] < high[n])
    upflagUpFrontier2 := upflagUpFrontier2 and (high[n+1] <= high[n] and high[n+2] <= high[n] and high[n+i + 2] < high[n])
    upflagUpFrontier3 := upflagUpFrontier3 and (high[n+1] <= high[n] and high[n+2] <= high[n] and high[n+3] <= high[n] and high[n+i + 3] < high[n])
    upflagUpFrontier4 := upflagUpFrontier4 and (high[n+1] <= high[n] and high[n+2] <= high[n] and high[n+3] <= high[n] and high[n+4] <= high[n] and high[n+i + 4] < high[n])
flagUpFrontier = upflagUpFrontier0 or upflagUpFrontier1 or upflagUpFrontier2 or upflagUpFrontier3 or upflagUpFrontier4

upFractal = (upflagDownFrontier and flagUpFrontier)

// downFractal
bool downflagDownFrontier = true
bool downflagUpFrontier0 = true
bool downflagUpFrontier1 = true
bool downflagUpFrontier2 = true
bool downflagUpFrontier3 = true
bool downflagUpFrontier4 = true

for i = 1 to n
    downflagDownFrontier := downflagDownFrontier and (low[n-i] > low[n])
    downflagUpFrontier0 := downflagUpFrontier0 and (low[n+i] > low[n])
    downflagUpFrontier1 := downflagUpFrontier1 and (low[n+1] >= low[n] and low[n+i + 1] > low[n])
    downflagUpFrontier2 := downflagUpFrontier2 and (low[n+1] >= low[n] and low[n+2] >= low[n] and low[n+i + 2] > low[n])
    downflagUpFrontier3 := downflagUpFrontier3 and (low[n+1] >= low[n] and low[n+2] >= low[n] and low[n+3] >= low[n] and low[n+i + 3] > low[n])
    downflagUpFrontier4 := downflagUpFrontier4 and (low[n+1] >= low[n] and low[n+2] >= low[n] and low[n+3] >= low[n] and low[n+4] >= low[n] and low[n+i + 4] > low[n])
flagDownFrontier = downflagUpFrontier0 or downflagUpFrontier1 or downflagUpFrontier2 or downflagUpFrontier3 or downflagUpFrontier4

downFractal = (downflagDownFrontier and flagDownFrontier)

plotshape(downFractal and show_fractals, style=shape.triangleup, location=location.belowbar, offset=-n, color=color_green)
plotshape(upFractal and show_fractals, style=shape.triangledown, location=location.abovebar, offset=-n, color=color_red)

// *************EMA*************
len_a = input(20, minval=1, title="EMA Length A", group="EMA")
src_a = input(close, title="EMA Source A", group="EMA")
offset_a = input(title="EMA Offset A", type=input.integer, defval=0, minval=-500, maxval=500, group="EMA")
out_a = ema(src_a, len_a)
plot(show_ema ? out_a : na, title="EMA A", color=color_green, offset=offset_a)

len_b = input(50, minval=1, title="EMA Length B", group="EMA")
src_b = input(close, title="EMA Source B", group="EMA")
offset_b = input(title="EMA Offset B", type=input.integer, defval=0, minval=-500, maxval=500, group="EMA")
out_b = ema(src_b, len_b)
ema_b_color = (theme == "dark") ? color_yellow : color_orange
plot(show_ema ? out_b : na, title="EMA B", color=ema_b_color, offset=offset_b)

len_c = input(100, minval=1, title="EMA Length C", group="EMA")
src_c = input(close, title="EMA Source C", group="EMA")
offset_c = input(title="EMA Offset C", type=input.integer, defval=0, minval=-500, maxval=500, group="EMA")
out_c = ema(src_c, len_c)
ema_c_color = (theme == "dark") ? color_white : color_blue
plot(show_ema ? out_c : na, title="EMA C", color=ema_c_color, offset=offset_c)

// *************RSI*************
rsi_len = input(14, minval=1, title="RSI Length", group="RSI")
rsi_src = input(close, "RSI Source", type = input.source, group="RSI")
up = rma(max(change(rsi_src), 0), rsi_len)
down = rma(-min(change(rsi_src), 0), rsi_len)
rsi = down == 0 ? 100 : up == 0 ? 0 : 100 - (100 / (1 + up / down))

// *************Calculation*************
long = (out_a > out_b) and (out_a > out_c) and downFractal and low[2] > out_c and rsi[2] < rsi
short = (out_a < out_b) and (out_a < out_c) and upFractal and high[2] < out_c and rsi[2] > rsi

plotshape(long, style=shape.labelup, color=color_green, location=location.belowbar, title="long label", text= "L", textcolor=color_white)
plotshape(short, style=shape.labeldown, color=color_red, location=location.abovebar, title="short label", text= "S", textcolor=color_white)

// *************End of Signals calculation*************

// Make input options that configure backtest date range
startDate = input(title="Start Date", type=input.integer,
     defval=1, minval=1, maxval=31, group="Orders")
startMonth = input(title="Start Month", type=input.integer,
     defval=1, minval=1, maxval=12, group="Orders")
startYear = input(title="Start Year", type=input.integer,
     defval=2018, minval=1800, maxval=2100, group="Orders")

endDate = input(title="End Date", type=input.integer,
     defval=1, minval=1, maxval=31, group="Orders")
endMonth = input(title="End Month", type=input.integer,
     defval=12, minval=1, maxval=12, group="Orders")
endYear = input(title="End Year", type=input.integer,
     defval=2022, minval=1800, maxval=2100, group="Orders")

// Look if the close time of the current bar
// falls inside the date range
inDateRange = (time >= timestamp(syminfo.timezone, startYear,
         startMonth, startDate, 0, 0)) and
     (time < timestamp(syminfo.timezone, endYear, endMonth, endDate, 0, 0))

// Make inputs that set the take profit % (optional)
longProfitPerc = input(title="Long Take Profit (%)",
     type=input.float, minval=0.0, step=0.1, defval=0.5, group="Orders") * 0.01

shortProfitPerc = input(title="Short Take Profit (%)",
     type=input.float, minval=0.0, step=0.1, defval=0.5, group="Orders") * 0.01

// Figure out take profit price
longExitPrice  = strategy.position_avg_price * (1 + longProfitPerc)
shortExitPrice = strategy.position_avg_price * (1 - shortProfitPerc)

// Plot take profit values for confirmation
plot(series=(strategy.position_size > 0) ? longExitPrice : na,
     color=color_green, style=plot.style_circles,
     linewidth=1, title="Long Take Profit")
plot(series=(strategy.position_size < 0) ? shortExitPrice : na,
     color=color_green, style=plot.style_circles,
     linewidth=1, title="Short Take Profit")

// Submit entry orders
if (inDateRange and long and strategy.opentrades == 0)
    strategy.entry(id="Long", long=true)

if (inDateRange and short and strategy.opentrades == 0)
    strategy.entry(id="Short", long=false)
    
// Set stop loss level with input options (optional)
longLossPerc = input(title="Long Stop Loss (%)",
     type=input.float, minval=0.0, step=0.1, defval=3.1, group="Orders") * 0.01

shortLossPerc = input(title="Short Stop Loss (%)",
     type=input.float, minval=0.0, step=0.1, defval=3.1, group="Orders") * 0.01

// Determine stop loss price
longStopPrice  = strategy.position_avg_price * (1 - longLossPerc)
shortStopPrice = strategy.position_avg_price * (1 + shortLossPerc)

// Plot stop loss values for confirmation
plot(series=(strategy.position_size > 0) ? longStopPrice : na,
     color=color_red, style=plot.style_cross,
     linewidth=1, title="Long Stop Loss")
plot(series=(strategy.position_size < 0) ? shortStopPrice : na,
     color=color_red, style=plot.style_cross,
     linewidth=1, title="Short Stop Loss")

// Submit exit orders based on calculated stop loss price
if (strategy.position_size > 0)
    strategy.exit(id="ExL",limit=longExitPrice, stop=longStopPrice)

if (strategy.position_size < 0)
    strategy.exit(id="ExS", limit=shortExitPrice, stop=shortStopPrice)

// Exit open market position when date range ends
if (not inDateRange)
    strategy.close_all()