
이 전략은 일련의 기술 지표들을 결합한 완전한 거래 시스템으로, 주로 일회용 구름 도표 (Ichimoku Cloud) 를 기반으로 거래 결정을 내린다. 시스템은 안테나 (Tenkan) 와 기준선 (Kijun) 의 교차를 통해 진출 시기를 결정하며, 상대적으로 약한 지수 (RSI) 와 이동 평균 (MA) 를 보조 필터링 조건으로 결합한다. 전략은 구름 도표 구성 요소를 동적 스톱 로즈로 사용하여, 완전한 위험 제어 시스템을 형성한다.
전략의 핵심 논리는 다음과 같은 핵심 요소에 기초합니다.
이 전략은 여러 기술 지표를 결합하여 완전한 거래 시스템을 구축한다. 이 전략은 신호의 발생에 초점을 맞추는 것뿐만 아니라 완벽한 위험 제어 장치도 포함하고 있다. 여러 필터링 조건을 설정하여 거래의 성공률을 효과적으로 향상시킨다. 동시에, 동적 중지 손실 디자인은 전략에 좋은 위험 수익률을 제공합니다.
/*backtest
start: 2019-12-23 08:00:00
end: 2024-11-27 00:00:00
period: 1d
basePeriod: 1d
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy("Ichimoku Strategy with Optional RSI, MA Filters and Alerts", overlay=true)
// Input for date and time filter
startDate = input(timestamp("2020-01-01 00:00"), title="Start Date")
endDate = input(timestamp("2023-01-01 00:00"), title="End Date")
// Inputs for Ichimoku settings
tenkanPeriod = input.int(9, title="Tenkan Period")
kijunPeriod = input.int(26, title="Kijun Period")
senkouBPeriod = input.int(52, title="Senkou B Period")
// Inputs for Moving Average settings
useMAFilter = input.bool(true, title="Enable Moving Average Filter?")
ma50Period = input.int(50, title="50-day MA Period")
ma200Period = input.int(200, title="200-day MA Period")
// Inputs for RSI settings
useRSIFilter = input.bool(true, title="Enable RSI Filter?")
rsiPeriod = input.int(14, title="RSI Period")
rsiOverbought = input.int(70, title="RSI Overbought Level")
rsiOversold = input.int(30, title="RSI Oversold Level")
// Ichimoku Cloud components
tenkan = (ta.highest(high, tenkanPeriod) + ta.lowest(low, tenkanPeriod)) / 2
kijun = (ta.highest(high, kijunPeriod) + ta.lowest(low, kijunPeriod)) / 2
senkouA = ta.sma(tenkan + kijun, 2) / 2
senkouB = (ta.highest(high, senkouBPeriod) + ta.lowest(low, senkouBPeriod)) / 2
chikou = close[26]
// Moving Averages
ma50 = ta.sma(close, ma50Period)
ma200 = ta.sma(close, ma200Period)
// Weekly RSI
rsiSource = request.security(syminfo.tickerid, "W", ta.rsi(close, rsiPeriod))
// Plotting the Ichimoku Cloud components
pTenkan = plot(tenkan, color=color.blue, title="Tenkan")
pKijun = plot(kijun, color=color.red, title="Kijun")
pSenkouA = plot(senkouA, color=color.green, title="Senkou A")
pSenkouB = plot(senkouB, color=color.maroon, title="Senkou B")
plot(chikou, color=color.purple, title="Chikou")
plot(ma50, color=color.orange, title="50-day MA")
plot(ma200, color=color.yellow, title="200-day MA")
// Corrected fill function
fill(pSenkouA, pSenkouB, color=senkouA > senkouB ? color.green : color.red, transp=90)
// Debugging: Output values on the chart to see if conditions are ever met
plotshape(series=(tenkan > kijun), color=color.blue, style=shape.triangleup, title="Tenkan > Kijun")
plotshape(series=(tenkan < kijun), color=color.red, style=shape.triangledown, title="Tenkan < Kijun")
plotshape(series=(ma50 > ma200), color=color.orange, style=shape.labelup, title="MA 50 > MA 200")
plotshape(series=(ma50 < ma200), color=color.yellow, style=shape.labeldown, title="MA 50 < MA 200")
// Define the trailing stop loss using Kumo
var float trailingStopLoss = na
// Check for MA conditions (apply only if enabled)
maConditionLong = not useMAFilter or (useMAFilter and ma50 > ma200)
maConditionShort = not useMAFilter or (useMAFilter and ma50 < ma200)
// Check for Ichimoku Cloud conditions
ichimokuLongCondition = close > math.max(senkouA, senkouB)
ichimokuShortCondition = close < math.min(senkouA, senkouB)
// Check for RSI conditions (apply only if enabled)
rsiConditionLong = not useRSIFilter or (useRSIFilter and rsiSource > rsiOverbought)
rsiConditionShort = not useRSIFilter or (useRSIFilter and rsiSource < rsiOversold)
// Combine conditions for entry
longCondition = maConditionLong and tenkan > kijun and ichimokuLongCondition and rsiConditionLong
shortCondition = maConditionShort and tenkan < kijun and ichimokuShortCondition and rsiConditionShort
// Date and time filter
withinDateRange = true
// Check for Long Condition
if (longCondition and withinDateRange)
strategy.entry("Long", strategy.long)
trailingStopLoss := math.min(senkouA, senkouB)
alert("Buy Signal: Entering Long Position", alert.freq_once_per_bar_close)
// Check for Short Condition
if (shortCondition and withinDateRange)
strategy.entry("Short", strategy.short)
trailingStopLoss := math.max(senkouA, senkouB)
alert("Sell Signal: Entering Short Position", alert.freq_once_per_bar_close)
// Exit conditions
exitLongCondition = close < kijun or tenkan < kijun
exitShortCondition = close > kijun or tenkan > kijun
if (exitLongCondition and strategy.position_size > 0)
strategy.close("Long")
alert("Exit Signal: Closing Long Position", alert.freq_once_per_bar_close)
if (exitShortCondition and strategy.position_size < 0)
strategy.close("Short")
alert("Exit Signal: Closing Short Position", alert.freq_once_per_bar_close)
// Apply trailing stop loss
if (strategy.position_size > 0)
strategy.exit("Trailing Stop Long", stop=trailingStopLoss)
else if (strategy.position_size < 0)
strategy.exit("Trailing Stop Short", stop=trailingStopLoss)