
이 전략은 간단한 이동 평균 (SMA) 을 기반으로 한 BankNifty 선물 거래 전략이다. 전략의 주요 아이디어는 SMA를 트렌드 지표로 사용하여, 가격이 SMA를 통과 할 때 더 많이하고, 가격이 SMA를 통과 할 때 비어있는 것입니다. 동시에, 이 전략은 위험을 제어하고 이익을 잠금하기 위해 중지 및 중지 조건을 설정합니다.
이 전략의 핵심은 SMA를 트렌드 지표로 사용하는 것입니다. 구체적으로, 전략은 먼저 지정된 주기 (설정된 200) 의 SMA를 계산하고, 그 다음 가격과 SMA의 상대적 위치에 따라 트렌드 방향을 판단합니다. 가격이 SMA를 넘으면 상승 추세가 형성되었다고 생각하면, 이 때 더 많이; 가격이 SMA를 넘으면 하향 추세가 형성되었다고 생각하면, 이 때 공백합니다. 또한, 이 전략은 위험을 제어하고 수익을 잠금하기 위해 중지 및 중지 조건을 설정합니다.
이 전략은 SMA 기반의 간단한 거래 전략으로, BankNifty 선물에 적용된다. 그것의 장점은 원칙이 단순하고 적응력이 강하며, 동시에 위험 관리 조치가 있다. 그러나 실제 응용에서는, 변수 최적화, 충격 시장, 추세 역전 및 포스트의 변동과 같은 잠재적인 위험에 주의해야 한다.
// This Pine Script™ code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © Bhasker_S
//@version=5
strategy("Strategy BankNifty SMA", overlay=true, margin_long=100, margin_short=100)
src = input(close, title="Source")
timeFrame = input.timeframe(defval='5', title = "Select Chart Timeframe")
typeMA = input.string(title = "Method", defval = "SMA", options=["SMA", "EMA", "SMMA (RMA)", "WMA", "VWMA"])
len = input.int(200, minval=1, title="Length", step = 10)
alertPrecision = input.float(0, "Alert Precision", minval = 0, maxval = 50, step=1)
slTimeFrame = input.timeframe(defval='1', title = "Select Stoploss Candle Timeframe")
slBuffer = input.float(0, "Stop Loss Buffer", minval = 0, maxval = 50, step = 1)
targetSlab = input.float(150, "Target Price", minval = 1, maxval = 2000, step = 10)
Stoploss = input.float(20, "Stop Loss", minval = 1, maxval = 2000, step = 5)
offset = input.int(title="Offset", defval=0, minval=-500, maxval=500)
//out = ta.sma(src, len)
ma(source, length, type) =>
switch type
"SMA" => ta.sma(source, length)
"EMA" => ta.ema(source, length)
"SMMA (RMA)" => ta.rma(source, length)
"WMA" => ta.wma(source, length)
"VWMA" => ta.vwma(source, length)
tfSource = request.security(syminfo.tickerid, timeFrame, src, barmerge.gaps_on, barmerge.lookahead_off)
mySMA = ma(tfSource, len, typeMA)
plot(mySMA, color=color.rgb(243, 33, 89), title="MA", offset=offset, linewidth = 2)
slClose = request.security(syminfo.tickerid, slTimeFrame, src, barmerge.gaps_on, barmerge.lookahead_off)
highTravel = low > mySMA
lowTravel = high < mySMA
touchabove = (((high[1] + alertPrecision) > mySMA[1]) and (low[1] < mySMA[1])) //and (high[2] < mySMA[2])
touchbelow = (((low[1] - alertPrecision) < mySMA[1]) and (high[1] > mySMA[1])) //and (low[2] > mySMA[2])
crossabove = math.min(open, close) > mySMA
crossbelow = math.max(open, close) < mySMA
upalert = (touchabove or touchbelow) and crossabove
downalert = (touchabove or touchbelow) and crossbelow
h=hour(time('1'),"Asia/Kolkata")
m=minute(time('1'),"Asia/Kolkata")
startTime=h*100+m
if upalert and strategy.position_size == 0
strategy.entry("buy", strategy.long, 15)
if downalert and strategy.position_size == 0
strategy.entry("sell", strategy.short, 15)
longexit = (slClose < (mySMA - slBuffer)) or (slClose < (strategy.opentrades.entry_price(strategy.opentrades - 1) - Stoploss)) or (slClose > (strategy.opentrades.entry_price(strategy.opentrades - 1) + targetSlab)) or (hour(time) == 15)
shortexit = (slClose > (mySMA + slBuffer)) or (slClose > (strategy.opentrades.entry_price(strategy.opentrades - 1) + Stoploss)) or (slClose < (strategy.opentrades.entry_price(strategy.opentrades - 1) - targetSlab)) or (hour(time) == 15)
if longexit
strategy.close("buy")
if shortexit
strategy.close("sell")