該策略使用三條不同週期的指數移動平均線(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)