該策略使用三條不同週期的指數移動平均線(EMA)來判斷市場趨勢,並結合相對強弱指數(RSI)和平均真實波幅(ATR)來確定進場點和止損止盈。當價格突破三條EMA形成的通道時,並且RSI也突破其移動平均線時,策略就會觸發開倉信號。同時,ATR用於控制頭寸規模和設置止損位,而收益風險比(RR)則用於確定止盈位。該策略的主要優勢在於其簡單有效,能夠順應市場趨勢進行交易,並通過嚴格的風控措施來限制潛在損失。
該策略通過結合多個常用技術指標,如EMA、RSI和ATR,構建了一個簡單有效的趨勢跟隨交易系統。它利用EMA通道來判斷市場趨勢,RSI來確認趨勢強度,並使用ATR來控制風險。策略的優勢在於其簡單性和適應性,能夠在不同市場條件下順應趨勢進行交易。然而,策略的表現在很大程度上取決於參數的選擇,不當的參數設置可能導致策略失效或表現不佳。此外,在突發事件或極端行情下,策略可能面臨較大風險。為了進一步優化策略,可以考慮引入動態參數調整、組合其他指標、加入市場情緒分析以及多時間框架分析等方法。總的來說,該策略為趨勢跟隨交易提供了一個良好的基礎,但仍需要根據實際市場情況進行調整和優化。
/*backtest
start: 2024-04-01 00:00:00
end: 2024-04-30 23:59:59
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/
// © hatnxkld
//@version=4
strategy("Win ha", overlay=true)
ss2 = input("0300-1700", title = "Khung thời gian")
t2 = time(timeframe.period,ss2)
c2 = #cacae6
bgcolor(t2 ? c2 : na, transp = 70)
//3ema
emangan=input(title="Ema ngắn", defval = 12)
ngan=ema(close, emangan)
a= plot(ngan, title="EMA ngắn", color=color.yellow)
ematb=input(title="Ema trung bình", defval = 100)
tb=ema(close, ematb)
b= plot(tb, title="EMA trung bình", color=color.blue)
//emadai=input(title="Ema dai", defval = 288)
//dai=ema(close,emadai)
//c= plot(dai, title="EMA dai", color=color.red)
// nhập hệ số nhân ATR
i=input(title="Hệ số nhân với ATR", defval=1.25)
// RSI
rsi=rsi(close, emangan)
marsi=sma(rsi, emangan)
// Kênh keltler
//heso=input(defval=1, title="Hệ số Kênh Keltler")
//atr=atr(emangan)
//tren=ngan+atr*heso
//d=plot(tren, title="Kênh trên", color=color.white)
//duoi=ngan-atr*heso
//e=plot(duoi, title="Kênh dưới", color=color.white)
//fill(d,e, color=color.rgb(48, 58, 53))
ban = ( close[1]>open[1] and (high[1]-close[1])>(close[1]-low[1]) and open>close and close<low[1] )
//or ( open[1] > close[1] and (high[1]-open[1])>(open[1]-low[1]) and (open[1]-close[1])>(close[1]-low[1]) and open>close and close <low[1] ) ) //and time(timeframe.period,"2200-1300")
//and (close[1]-open[1])>(open[1]-low[1])
//high > ngan and close < ngan and ngan<tb and
// and time(timeframe.period,"1000-2300")
bgcolor(color = ban ? color.rgb(235, 106, 123) : na)
//bgcolor(color.rgb(82, 255, 154),transp = 100, offset = 1, show_last = 2)
//and time(timeframe.period,"2300-1500") and ((open>ngan and close<ngan) or (open>tren and close<tren))
plotshape(ban , style=shape.arrowdown, location=location.abovebar, color=#ff00ff, size=size.tiny, textcolor=color.rgb(255, 59, 213))
alertcondition(ban, "Ban", "Ban")
mua= ( open[1]>close[1] and (close[1]-low[1])>(high[1]-close[1]) and close > open and close > high[1] ) //and time(timeframe.period,"2200-1300")
//or ( close[1]>open[1] and (open[1]-low[1]) > (high[1]-open[1]) and (close[1]-open[1])>(high[1]-close[1]) and close>open and close>high[1] ) )
//and (open[1]-close[1])>(high[1]-open[1])
//low < ngan and close > ngan and ngan>tb and
//or ( close[1]>open[1] and (open[1]-low[1]) > (high[1]-open[1]) and (close[1]-open[1])>(high[1]-close[1]) and close>open and close>high[1] )
// and time(timeframe.period,"1000-2300")
bgcolor(color= mua? color.rgb(108, 231, 139):na)
//and time(timeframe.period,"2300-1500") and ((open<ngan and close>ngan)or (open<duoi and close>duoi) )
plotshape(mua , style=shape.arrowup, location=location.belowbar, color=#00ff6a, size=size.tiny, textcolor=color.rgb(83, 253, 60))
alertcondition(mua , "Mua", "Mua")
//len1 = ban==true and (high-low)>2*atr
//plotshape(len1 , style=shape.flag, location=location.abovebar, color=#ff00ff, size=size.tiny, title="Sell Signal", text="Xuong 1", textcolor=color.rgb(255, 59, 213))
//bann= ban==true and rsi < marsi and marsi[2]>marsi[1]
//plotshape(bann , style=shape.labeldown, location=location.abovebar, color=#ff00ff, size=size.tiny, title="Sell Signal", text="BAN 2", textcolor=color.rgb(240, 234, 239))
//bannn = mua==true and rsi>marsi and marsi[2]<marsi[1]
//plotshape(bannn , style=shape.labelup, location=location.belowbar, color=#00ff6a, size=size.tiny, title="Buy Signal", text="Mua 2", textcolor=color.rgb(237, 241, 236))
//a1= ban==true and (high - low)<atr
//plotshape(a1 , style=shape.xcross, location=location.bottom, color=#00ff6a, size=size.tiny, title="Sell", text="<atr", textcolor=color.rgb(240, 95, 76))
//a2 = ban ==true and (high - low)>atr and (high - low)<(2*atr)
//plotshape(a2 , style=shape.xcross, location=location.bottom, color=#00ff6a, size=size.tiny, title="Sell", text="<2atr", textcolor=color.rgb(237, 241, 236))
//a3= ban==true and (high - low)>(2*atr)
//plotshape(a3 , style=shape.xcross, location=location.bottom, color=#00ff6a, size=size.tiny, title="Sell", text=">2atr", textcolor=color.rgb(234, 252, 74))
//b1= mua==true and (high - low)<atr
//plotshape(b1 , style=shape.xcross, location=location.bottom, color=#00ff6a, size=size.tiny, title="Buy", text="<atr", textcolor=color.rgb(237, 241, 236))
//b2 = mua ==true and (high - low)>atr and (high - low)<(2*atr)
//plotshape(b2 , style=shape.xcross, location=location.bottom, color=#00ff6a, size=size.tiny, title="Buy", text="<2atr", textcolor=color.rgb(237, 241, 236))
//b3= mua==true and (high - low)>(2*atr)
//plotshape(b3 , style=shape.xcross, location=location.bottom, color=#00ff6a, size=size.tiny, title="Buy", text=">2atr", textcolor=color.rgb(237, 241, 236))
// Đặt SL TP ENTRY
risk= input(title="Rủi ro % per Trade", defval=0.5)
rr= input(title="RR", defval=1.5)
onlylong= input(defval=false)
onlyshort=input(defval=false)
stlong = mua and strategy.position_size<=0 ? low[1]:na
stoplong= fixnan(stlong)
stshort = ban and strategy.position_size>=0 ? high[1]:na
stopshort= fixnan(stshort)
enlong = mua and strategy.position_size<=0 ? close:na
entrylong =fixnan(enlong)
enshort = ban and strategy.position_size>=0 ? close:na
entryshort = fixnan(enshort)
amountL = risk/100* strategy.initial_capital / (entrylong - stoplong)
amountS = risk/100* strategy.initial_capital / (stopshort - entryshort)
TPlong= mua and strategy.position_size<=0? entrylong + (entrylong -stoplong)*rr:na
takeprofitlong =fixnan(TPlong)
TPshort = ban and strategy.position_size>=0? entryshort - (stopshort - entryshort)*rr:na
takeprofitshort = fixnan(TPshort)
strategy.entry("Long", strategy.long , when = enlong and not onlyshort, qty= amountL )
strategy.exit("exitL", "Long", stop = stoplong, limit= takeprofitlong)
strategy.entry("Short", strategy.short , when = enshort and not onlylong, qty= amountS )
strategy.exit("exitS", "Short", stop = stopshort, limit= takeprofitshort)