Esta estratégia é uma estratégia de negociação baseada em SMA para futuros BankNifty. A ideia principal da estratégia é usar a SMA como um indicador de tendência, indo longo quando o preço cruza acima da SMA e indo curto quando o preço cruza abaixo da SMA. Ao mesmo tempo, a estratégia também define condições de stop-loss e take-profit para controlar o risco e bloquear os lucros.
O núcleo desta estratégia é usar a SMA como um indicador de tendência. Especificamente, a estratégia primeiro calcula a SMA de um período especificado (o padrão é 200), e depois determina a direção da tendência com base na posição relativa do preço e da SMA. Quando o preço cruza acima da SMA, considera-se que uma tendência ascendente se formou e uma posição longa é tomada; quando o preço cruza abaixo da SMA, considera-se que uma tendência descendente se formou e uma posição curta é tomada. Além disso, a estratégia também estabelece condições de stop-loss e take-profit para controlar o risco e bloquear os lucros. As condições de stop-loss incluem: o preço quebrar a SMA por um certo intervalo (definido pelo parâmetro
Esta estratégia é uma estratégia de negociação simples baseada em SMA, adequada para futuros BankNifty. Suas vantagens estão em seu princípio simples, forte adaptabilidade e medidas de controle de risco. No entanto, na aplicação prática, ainda é necessário prestar atenção a riscos potenciais, como otimização de parâmetros, mercados oscilantes, inversão de tendência e volatilidade intradiária. No futuro, a estratégia pode ser otimizada e melhorada a partir de aspectos como otimização de parâmetros, combinação com outros indicadores, stop-loss dinâmico e tempo de negociação limitado.
// 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")