
이 전략은 K 선의 양 그림자 길이의 비율을 계산하여 현재 트렌드 방향을 판단하고, 평균 실제 파장 ATR과 함께 트렌드 식별을 수행하고, 돌파구에서 역으로 포지션을 개시하고, 스톱 로드 스톱을 설정하고, 단기 트렌드를 캡처한다.
이 전략은 주로 K 선의 양 그림자 길이의 비율을 계산하여 현재 트렌드 방향을 판단합니다. 양 선의 길이가 너무 길으면 하향 트렌드로 판단하고, 양 선의 길이가 너무 길면 상승 트렌드로 판단합니다.
전략의 구체적인 논리는 다음과 같습니다.
이 전략의 기본 거래 논리는 트렌드 브레이크 포인트를 식별하여 역으로 포지션을 개시하고 스톱 손실 스톱을 설정한 후 수익을 최적화하는 것입니다.
합리적인 손실, 최적화 파라미터, 적시에 손실을 막아 위험을 제어할 수 있다.
이 전략은 다음과 같은 부분에서 최적화될 수 있습니다.
다방면 테스트와 최적화를 통해 전략 효과를 극대화할 수 있다.
전체적으로, 이 전략은 추세를 인식하고 위험을 통제하는 방식으로 단기간의 가격 변동을 활용하여 수익을 창출하는 효과 안정적인 단선 돌파 전략이다. 최적화되면 양적 거래의 중요한 부분이 될 수 있다.
/*backtest
start: 2022-11-08 00:00:00
end: 2023-11-14 00:00:00
period: 1d
basePeriod: 1h
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/
// © ondrej17
//@version=4
strategy("longWickstrategy", overlay=true )
// Inputs
st_yr_inp = input(defval=2020, title='Backtest Start Year')
st_mn_inp = input(defval=01, title='Backtest Start Month')
st_dy_inp = input(defval=01, title='Backtest Start Day')
en_yr_inp = input(defval=2025, title='Backtest End Year')
en_mn_inp = input(defval=01, title='Backtest End Month')
en_dy_inp = input(defval=01, title='Backtest End Day')
sltp_inp = input(defval=0.8, title='N - % offset for N*SL and (2N)*TP')/100
// Dates
start = timestamp(st_yr_inp, st_mn_inp, st_dy_inp,00,00)
end = timestamp(en_yr_inp, en_mn_inp, en_dy_inp,00,00)
canTrade = time >= start and time <= end
// Indicators Setup
// Strategy Calcuations
lowerWick = (open > close) ? close-low : open - low
upperWick = (open > close) ? high-open : high-close
wickLength = max(lowerWick,upperWick)
candleLength = high-low
wickToCandleRatio = wickLength / candleLength
entryFilterCandleLength = candleLength > 0.75*atr(48)
// Entries and Exits
longCondition = entryFilterCandleLength and wickToCandleRatio > 0.5 and lowerWick > upperWick and canTrade and strategy.position_size == 0
shortCondition = entryFilterCandleLength and wickToCandleRatio > 0.5 and lowerWick < upperWick and canTrade and strategy.position_size == 0
strategy.entry("pendingLong", strategy.long, limit=low+wickLength/2, when = longCondition)
strategy.entry("pendingShort", strategy.short, limit=high-wickLength/2, when = shortCondition)
longStop = strategy.position_size > 0 ? strategy.position_avg_price*(1-sltp_inp) : na
longTP = strategy.position_size > 0 ? strategy.position_avg_price*(1+2*sltp_inp) : na
shortStop = strategy.position_size < 0 ? strategy.position_avg_price*(1+sltp_inp) : na
shortTP = strategy.position_size < 0 ? strategy.position_avg_price*(1-2*sltp_inp) : na
strategy.exit("longSLTP","pendingLong", stop=longStop, limit = longTP)
strategy.exit("shortSLTP","pendingShort", stop=shortStop, limit = shortTP)
plot(longStop, color=color.red, style=plot.style_linebr, linewidth=2)
plot(shortStop, color=color.red, style=plot.style_linebr, linewidth=2)
plot(longTP, color=color.green, style=plot.style_linebr, linewidth=2)
plot(shortTP, color=color.green, style=plot.style_linebr, linewidth=2)
plotLongCondition = longCondition ? high+abs(open-close) : na
plot(plotLongCondition, style=plot.style_circles, linewidth=4, color=color.green)
plotShortCondition = shortCondition ? high+abs(open-close) : na
plot(plotShortCondition, style=plot.style_circles, linewidth=4, color=color.red)