
트렌드 추적 구매/판매 전략은 간단한 트렌드를 따르는 일일 거래 전략이다. 이 전략의 기본 아이디어는 이동 평균에 따라 트렌드 방향을 판단하고, 트렌드 속의 흔들림에서 구매/판매하는 것이다.
이 전략은 간단한 이동 평균 SMA를 사용하여 트렌드 방향을 판단한다. 상승 추세에서 K 선이 낮은 지점을 나타낼 때, 전략은 이전 K 선의 최고 지점을 돌파 할 때 더 많이 한다. 하향 추세에서 K 선이 높은 지점을 나타낼 때, 전략은 이전 K 선의 최저 지점을 돌파 할 때 공백을 한다.
이 전략은 또한 Blanchflower 지표 %K와%D를 사용하여 트렌드를 판단한다. %K가 %D를 통과할 때 평소 위치로 역방향 거래를 한다. 또한, 전략은 MACD와 Signal 곡선을 필터링 조건으로 사용하여 MACD와 Signal이 트렌드 방향에 부합하는 경우에만 거래를 수행한다.
이 전략은 단지 더 많은 공백을 하거나, 단지 공백을 하거나, 동시에 더 많은 공백을 할 수 있다. 시작 날짜는 측정의 시작 달과 해를 설정할 수 있다. 이동 평균 주기, K 주기, D 주기, MACD 파라미터 등과 같은 모든 매개 변수는 사용자 정의할 수 있다.
이 전략에는 다음과 같은 위험들이 있습니다.
이 전략은 다음과 같은 부분에서 최적화될 수 있습니다.
트렌드 추적 거래 전략의 전체적인 아이디어는 명확하고 간단하며, 이동 평균을 통해 트렌드 방향을 판단하고, 지표 필터를 사용하여 트렌드에 있는 거래 기회를 잠금한다. 이 전략은 파라미터 최적화를 통해 좋은 효과를 얻을 수 있지만, 여전히 최적화 된 위험을 줄이고 안정성을 높이기 위해 콤바인 코드 패키징이 필요합니다. 또한, 위험을 제어하기 위해 적절한 최적화가 중요합니다.
/*backtest
start: 2022-10-10 00:00:00
end: 2023-10-16 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=4
strategy("Higher High / Lower Low Strategy", overlay=true)
// Getting inputs
longOnly = input(true, title="Long or Short Only")
useMACD = input(true, title="Use MACD Filter")
useSignal = input(true, title="Use Signal Filter")
//Filter backtest month and year
startMonth = input(10, minval=1, maxval=12, title="Month")
startYear = input(2020, minval=2000, maxval=2100, title="Year")
//Filter funtion inputs
periodA = input(20, minval=1, title="Period SMA")
periodK = input(5, minval=1, title="Period %K")
fast_length = input(title="Period Fast", type=input.integer, defval=5)
slow_length = input(title="Period Slow", type=input.integer, defval=20)
signal_length = input(title="Signal Smoothing", type=input.integer, minval = 1, maxval = 50, defval = 30)
//Calculations
smoothD = 3 //input(3, minval=1, title="Smooth %D")
smoothK = 2 //input(2, minval=1, title="Smooth %K")
ma50 = sma(close, periodA)
k = sma(stoch(close, high, low, periodK), smoothK) - 50
d = sma(k, smoothD)
macd = ema(close,fast_length) - ema(close,slow_length)
signal = ema(macd,signal_length)
hist = macd - signal
if (not na(k) and not na(d) and not na(macd) and not na(signal) and longOnly and month>=startMonth and year>=startYear)// if(k > k[1] and k[2] >= k[1] and (ma50 > ma50[1]) and (not useK or k[1] <= -threshold_k) and (not useMACD or macd > macd[1]) and (not useSignal or signal > signal[1]) and (not useHHLL or close >= high[1]) and (not useD or d <= -threshold_d))
if(high[2] >= high[1] and high > high[1] and (ma50 > ma50[1]) and (not useMACD or macd > macd[1]) and (not useSignal or signal > signal[1]))
strategy.order("HH_LE", strategy.long, when=strategy.position_size == 0, comment="HH_LE")
if (k < k[1])
strategy.order("HH_SX", strategy.short, when=strategy.position_size != 0, comment="HH_SX")
if (not na(k) and not na(d) and not na(macd) and not na(signal) and not longOnly and month>=startMonth and year>=startYear)
if(low[2] <= low[1] and low < low[1] and (ma50 < ma50[1]) and (not useMACD or macd < macd[1]) and (not useSignal or signal < signal[1]))
strategy.order("HH_SE", strategy.short, when=strategy.position_size == 0, comment="HH_SE")
if (k > k[1])
strategy.order("HH_LX", strategy.long, when=strategy.position_size != 0, comment="HH_LX")
//plot(strategy.equity, title="equity", color=color.red, linewidth=2, style=plot.style_areabr)