دو طرفہ مومنٹم اسٹاپ پرافٹ اور اسٹاپ لاس اسٹریٹجی


تخلیق کی تاریخ: 2024-01-08 11:58:21 آخر میں ترمیم کریں: 2024-01-08 11:58:21
کاپی: 0 کلکس کی تعداد: 770
1
پر توجہ دیں
1617
پیروکار

دو طرفہ مومنٹم اسٹاپ پرافٹ اور اسٹاپ لاس اسٹریٹجی

جائزہ

یہ حکمت عملی ٹریڈنگ ویو کی بلٹ میں لگاتار اوپر / نیچے کی حکمت عملی پر مبنی ہے۔ اس میں لچکدار حکمت عملی کی سمت کی ترتیب ہے ، جس میں الٹا تجارت کی جاسکتی ہے۔ اس کے علاوہ ، اس میں متعدد اسٹاپ موڈ جیسے سوئنگ بلڈ / لوڈ ، اے ٹی آر اسٹاپ اور ٹریکنگ اسٹاپ ، اور اسی طرح کے اسٹاپ سیٹنگ کو مربوط کیا گیا ہے۔ اس سے حکمت عملی کو اصل ٹریڈنگ سگنل کی بنیاد پر برقرار رکھا جاسکتا ہے ، اور اس سے بہتر رسک مینجمنٹ حاصل ہوتا ہے۔

حکمت عملی کا اصول

یہ حکمت عملی بنیادی طور پر خریدنے اور بیچنے کے سگنل پیدا کرنے کے لئے K لائنوں کی مسلسل اضافہ یا کمی کی تعداد کا فیصلہ کرکے خریدنے اور بیچنے کے سگنل پیدا کرتی ہے۔ صارف خریدنے کے سگنل پیدا کرنے کے لئے درکار K لائنوں کی مسلسل اضافہ کی تعداد ، اور فروخت کے سگنل کے لئے درکار K لائنوں کی مسلسل کمی کی تعداد کو ترتیب دے سکتا ہے۔

اس کے علاوہ ، حکمت عملی میں تجارت کو تبدیل کرنے یا نہ کرنے کی ترتیبات شامل کی گئیں۔ جب تجارت کو تبدیل کرنے کا آغاز ہوتا ہے تو ، اصل خرید سگنل فروخت سگنل میں تبدیل ہوجاتا ہے ، اور فروخت سگنل بھی خرید سگنل میں تبدیل ہوجاتا ہے ، اور اس طرح تجارت کو تبدیل کرنا مکمل ہوجاتا ہے۔

داخل ہونے اور باہر نکلنے کے لئے ، حکمت عملی براہ راست ریورس لیول کی حمایت کرتی ہے ، جس سے اس صورت حال کو کم کیا جاسکتا ہے کہ جب کوئی پوزیشن نہیں ہے تو تجارت نہیں کی جاسکتی ہے۔

اسٹاپ اور اسٹاپ نقصان کے معاملے میں ، حکمت عملی میں اعلی / کم ، اے ٹی آر اور حکمت عملی میں شامل تین اختیارات کی روک تھام کی پیش کش کی گئی ہے۔ اسٹاپ کا طریقہ پوزیشن رکھنے کی سمت کے ساتھ مل کر ، خود بخود سب سے کم وادی یا چوٹی کو متحرک اسٹاپ کے طور پر منتخب کرتا ہے ، یا اے ٹی آر کی حرکیات کے مطابق اسٹاپ کی قیمت کا تعین کرتا ہے۔ اسٹاپ کی ترتیب ، حکمت عملی کے داخلے کی قیمت پر مبنی ہے ، جس میں ایک مقررہ ضرب کی روک تھام کی فاصلہ طے کی گئی ہے۔

اگر ٹریکنگ اسٹاپ کو چالو کیا جائے تو ، حکمت عملی نقصان کے وقت اسٹاپ اسپین کو بڑھا سکتی ہے اور منافع کے وقت اسٹاپ اسپین کو کم کرکے خود کار طریقے سے ٹریکنگ کرسکتی ہے۔

طاقت کا تجزیہ

اس حکمت عملی کا سب سے بڑا فائدہ یہ ہے کہ یہ لچکدار ہے اور مارکیٹ کے مختلف حالات کے مطابق ڈھال سکتا ہے، اس کے فوائد میں شامل ہیں:

  1. رجحانات اور ہلچل کے حالات کے مطابق خرید و فروخت فلٹرنگ پیرامیٹرز کو ترتیب دیں
  2. ریورس ٹریڈنگ کی حمایت کریں ، ضرورت کے مطابق سمت منتخب کریں
  3. براہ راست ریورس پوزیشن کھولنے کی ترتیب ، جس سے خالی پوزیشن کی مدت کو کم کیا جاسکتا ہے
  4. ایک سے زیادہ نقصانات کو روکنے کے طریقوں کو مربوط کریں ، اپنی مرضی کے مطابق منتخب کریں
  5. ٹریکنگ سٹاپ نقصان، خود کار طریقے سے سٹاپ نقصان فعال

خطرے کا تجزیہ

اس حکمت عملی کا بنیادی خطرہ یہ ہے کہ بہت زیادہ مسلسل K لائن سیٹ کرنے سے ٹریڈنگ کے مواقع ضائع ہوسکتے ہیں ، اور اس خطرے کا خطرہ ہے کہ نقصانات کو بڑھانے کے لئے بہت زیادہ اسٹاپ نقصان کی ترتیب ہے۔ اس خطرے کے بارے میں مشورے مندرجہ ذیل ہیں:

  1. اپ / نیچے K لائنوں کی تعداد پیرامیٹرز کو ایڈجسٹ کریں، بہت زیادہ شدت پسند نہیں
  2. نقصان کے مختلف طریقوں کو آزمائیں اور ان میں سے سب سے موزوں کو منتخب کریں
  3. ٹریکنگ اسٹاپ نقصانات کو احتیاط سے ترتیب دیں تاکہ زیادہ نقصانات سے بچا جاسکے

اصلاح کی سمت

اس حکمت عملی میں مزید اصلاحات کی گنجائش ہے۔

  1. اوپر / نیچے K لائنوں کی تعداد جو ATR یا اتار چڑھاؤ کی شرح جیسے اشارے کی بنیاد پر متحرک طور پر ایڈجسٹ ہوسکتی ہے
  2. مختلف پوزیشن ہولڈنگ اوقات کے تحت اسٹاپ نقصان کی روک تھام کے تناسب پیرامیٹرز کے اثرات کی جانچ کی جاسکتی ہے
  3. جعلی رسائی سے بچنے کے لئے اوپن فلٹرز کو ترتیب دیں
  4. سگنل کے معیار کو بہتر بنانے کے لئے دیگر معاون پیمائش کو شامل کیا جاسکتا ہے

خلاصہ کریں۔

یہ حکمت عملی بیس بیس حکمت عملی کی ایک فائدہ مند توسیع ہے ، جس سے خطرے کو بہتر طور پر کنٹرول کیا جاسکتا ہے ، اور زیادہ لچکدار تجارتی طریقوں کو حاصل کیا جاسکتا ہے۔ یہ ایک موثر لمحہ کی حکمت عملی ہے جو آسانی سے بہتر اور عملی ہے۔

حکمت عملی کا ماخذ کوڈ
/*backtest
start: 2023-01-07 00:00:00
end: 2023-08-30 05:20:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

// Extension of the built-in strategy by Tradingview. The strategy buys after an X amount of
// consecutive bullish bars and viceversa for selling. This logic can be reversed and a Stop Loss
// with Take Profit can be added. There's also an option to adapt the SL into a Trailing Stop.

//@version=4
strategy("Consecutive Up/Down Strategy with Reverse", 
     overlay=true, 
     default_qty_type=strategy.percent_of_equity, 
     default_qty_value=100, 
     initial_capital=10000, 
     commission_value=0.04, 
     calc_on_every_tick=false, 
     slippage=0)

direction = input(0, title = "Strategy Direction", type=input.integer, minval=-1, maxval=1)
strategy.risk.allow_entry_in(direction == 0 ? strategy.direction.all : (direction < 0 ? strategy.direction.short : strategy.direction.long))

/////////////////////// STRATEGY INPUTS ////////////////////////////////////////
title1=input(true, "-----------------Strategy Inputs-------------------")  

consecutiveBarsUp = input(3)
consecutiveBarsDown = input(4)

/////////////////////// BACKTESTER /////////////////////////////////////////////
title2=input(true, "-----------------General Inputs-------------------")  

// Backtester General Inputs
i_SL=input(true, title="Use Stop Loss and Take Profit")
i_SLType=input(defval="ATR Stop", title="Type Of Stop", options=["Strategy Stop", "Swing Lo/Hi", "ATR Stop"])
i_SPL=input(defval=10, title="Swing Point Lookback")
i_PercIncrement=input(defval=2, step=.1, title="Swing Point SL Perc Increment")*0.01
i_ATR = input(14, title="ATR Length")
i_ATRMult = input(5, step=.1, title="ATR Multiple")
i_TPRRR = input(5, step=.1, title="Take Profit Risk Reward Ratio")
TS=input(true, title="Trailing Stop")

// Bought and Sold Boolean Signal
bought = strategy.position_size > strategy.position_size[1] 
 or strategy.position_size < strategy.position_size[1]

// Price Action Stop and Take Profit
LL=(lowest(i_SPL))*(1-i_PercIncrement)
HH=(highest(i_SPL))*(1+i_PercIncrement)
LL_price = valuewhen(bought, LL, 0)
HH_price = valuewhen(bought, HH, 0)
entry_LL_price = strategy.position_size > 0 ? LL_price : na 
entry_HH_price = strategy.position_size < 0 ? HH_price : na 
tp=strategy.position_avg_price + (strategy.position_avg_price - entry_LL_price)*i_TPRRR
stp=strategy.position_avg_price - (entry_HH_price - strategy.position_avg_price)*i_TPRRR

// ATR Stop
ATR=atr(i_ATR)*i_ATRMult
ATRLong = ohlc4 - ATR
ATRShort = ohlc4 + ATR
ATRLongStop = valuewhen(bought, ATRLong, 0)
ATRShortStop = valuewhen(bought, ATRShort, 0)
LongSL_ATR_price = strategy.position_size > 0 ? ATRLongStop : na 
ShortSL_ATR_price = strategy.position_size < 0 ? ATRShortStop : na 
ATRtp=strategy.position_avg_price + (strategy.position_avg_price - LongSL_ATR_price)*i_TPRRR
ATRstp=strategy.position_avg_price - (ShortSL_ATR_price - strategy.position_avg_price)*i_TPRRR


// Strategy Stop
float LongStop = na
float ShortStop = na
float StratTP = na
float StratSTP = na

/////////////////////// STRATEGY LOGIC /////////////////////////////////////////

price = close
ups = 0.0
ups := price > price[1] ? nz(ups[1]) + 1 : 0
dns = 0.0
dns := price < price[1] ? nz(dns[1]) + 1 : 0

BUY=ups >= consecutiveBarsUp and bar_index > 40
SELL=dns >= consecutiveBarsDown and bar_index > 40

//Trading Inputs
DPR=input(true, "Allow Direct Position Reverse")
reverse=input(false, "Reverse Trades")

// Entries
if reverse
    if not DPR
        strategy.entry("long", strategy.long, when=SELL and strategy.position_size == 0)
        strategy.entry("short", strategy.short, when=BUY and strategy.position_size == 0)
    else     
        strategy.entry("long", strategy.long, when=SELL)
        strategy.entry("short", strategy.short, when=BUY)
else
    if not DPR 
        strategy.entry("long", strategy.long, when=BUY and strategy.position_size == 0)
        strategy.entry("short", strategy.short, when=SELL and strategy.position_size == 0)
    else
        strategy.entry("long", strategy.long, when=BUY)
        strategy.entry("short", strategy.short, when=SELL)
        



SL= i_SLType == "Swing Lo/Hi" ? entry_LL_price : i_SLType == "ATR Stop" ? LongSL_ATR_price : LongStop
SSL= i_SLType == "Swing Lo/Hi" ? entry_HH_price : i_SLType == "ATR Stop" ? ShortSL_ATR_price : ShortStop
TP= i_SLType == "Swing Lo/Hi" ? tp : i_SLType == "ATR Stop" ? ATRtp : StratTP
STP= i_SLType == "Swing Lo/Hi" ? stp : i_SLType == "ATR Stop" ? ATRstp : StratSTP

//TrailingStop
dif=(valuewhen(strategy.position_size>0 and strategy.position_size[1]<=0, high,0))
 -strategy.position_avg_price
trailOffset     = strategy.position_avg_price - SL
var tstop = float(na)
if strategy.position_size > 0
    tstop := high- trailOffset - dif
    if tstop<tstop[1]
        tstop:=tstop[1]
else
    tstop := na
StrailOffset     = SSL - strategy.position_avg_price
var Ststop = float(na)
Sdif=strategy.position_avg_price-(valuewhen(strategy.position_size<0 
 and strategy.position_size[1]>=0, low,0))
if strategy.position_size < 0
    Ststop := low+ StrailOffset + Sdif
    if Ststop>Ststop[1]
        Ststop:=Ststop[1]
else
    Ststop := na

strategy.exit("TP & SL", "long", limit=TP, stop=TS? tstop : SL, when=i_SL)
strategy.exit("TP & SL", "short", limit=STP, stop=TS? Ststop : SSL, when=i_SL)

/////////////////////// PLOTS //////////////////////////////////////////////////


plot(i_SL and strategy.position_size > 0 and not TS ? SL : i_SL and strategy.position_size > 0 and TS ? tstop : na , title='SL', style=plot.style_cross, color=color.red)
plot(i_SL and strategy.position_size < 0 and not TS ? SSL : i_SL and strategy.position_size < 0 and TS ? Ststop : na , title='SSL', style=plot.style_cross, color=color.red)
plot(i_SL and strategy.position_size > 0 ? TP : na, title='TP', style=plot.style_cross, color=color.green)
plot(i_SL and strategy.position_size < 0 ? STP : na, title='STP', style=plot.style_cross, color=color.green)
// Draw price action setup arrows
plotshape(BUY ? 1 : na, style=shape.triangleup, location=location.belowbar, 
 color=color.green, title="Bullish Setup", size=size.auto)
plotshape(SELL ? 1 : na, style=shape.triangledown, location=location.abovebar, 
 color=color.red, title="Bearish Setup", size=size.auto)