ایل پی بی مائکرو سائیکلز ایڈجسٹ ایبل آسکیلیشن کنٹور ٹریکنگ حکمت عملی

مصنف:چاؤ ژانگ، تاریخ: 2024-02-19 11:32:12
ٹیگز:

img

جائزہ

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

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

  1. قیمت کے رجحان کو نکالنے کے لئے ایچ پی فلٹر کا استعمال کریں۔ ایچ پی فلٹر قلیل مدتی اتار چڑھاؤ کو فلٹر کرتے ہوئے قیمتوں کے طویل مدتی رجحان جزو کو نکالنے کے لئے اصلاح کے طریقوں کا استعمال کرتا ہے۔

  2. صارف کی مرضی کے مطابق وقت کی حد پر مبنی VWAP کا حساب لگائیں۔ VWAP ادوار میں اوسط قیمتوں کو زیادہ درست طریقے سے ظاہر کرسکتا ہے۔

  3. جب قیمت ایچ پی ٹرینڈ لائن سے اوپر ہوتی ہے تو لمبی شرط کو پورا کریں۔ جب قیمت نیچے ہوتی ہے تو مختصر شرط کو پورا کریں۔ اس سے اوپر کی خرابی یا نیچے کی خرابی کا پتہ چلتا ہے۔

  4. اے ٹی آر سٹاپ نقصان معقول خطرہ فرض کرتا ہے اور ضرورت سے زیادہ نقصانات کو روکتا ہے۔

فوائد کا تجزیہ

  1. ایچ پی فلٹر ایم اے پر مبنی اشارے کے مقابلے میں زیادہ ہموار قیمت کے رجحانات کو نکالتا ہے، قلیل مدتی قیمتوں میں اتار چڑھاؤ سے مشغول ہونے سے بچتا ہے.

  2. قابل تخصیص وی ڈبلیو اے پی کے ادوار مارکیٹ کے بدلتے ہوئے دوروں کے مطابق بہتر طور پر اپناتے ہیں۔

  3. رجحان کی سمت کے ساتھ ٹریڈنگ رجحان ٹریڈنگ کے تصورات کے مطابق ہے اور اس میں زیادہ جیت کی شرح ہے.

  4. اے ٹی آر سٹاپ نقصان ہر تجارت کے نقصان کو کنٹرول کرتا ہے، زیادہ نقصانات کو روکتا ہے.

  5. انتہائی سایڈست پیرامیٹرز مختلف مارکیٹوں کے لئے زیادہ سے زیادہ اصلاح کی جگہ فراہم کرتے ہیں.

خطرات اور حل

  1. سٹاپ نقصان کو رینج سے منسلک استحکام کے دوران اکثر مارا جا سکتا ہے۔ سٹاپ نقصان کو تھوڑا سا نرم کر سکتا ہے۔

  2. رجحان کے اختتام پر واپسی اکثر جھوٹے بریک آؤٹ پیدا کرتی ہے جو حکمت عملی کو پھنس جاتی ہے۔ رجحان کے اختتام کی نشاندہی کرنے اور بروقت پوزیشنوں کو بند کرنے کے لئے دوسرے اشارے کے ساتھ مل کر ہونا چاہئے۔

  3. غلط VWAP مدت کی ترتیبات زیادہ موثر تجارتی مواقع سے محروم ہوسکتی ہیں۔ رجحان کے اشارے کے ساتھ VWAP مدت کو متحرک طور پر ایڈجسٹ کرنا چاہئے۔

اصلاح کی ہدایات

  1. ایچ پی فلٹر پیرامیٹر λ ہموار کرنے کی شدت کو ایڈجسٹ کرتا ہے۔ بڑا λ ٹرینڈ لائن کو ہموار اور طویل مدتی رجحانات کو بہتر طور پر پکڑتا ہے۔ چھوٹا λ اسے قیمت کی تبدیلیوں پر زیادہ ردعمل ظاہر کرتا ہے اور درمیانے مختصر مواقع کے مطابق بناتا ہے۔

  2. اے ٹی آر ضرب کار اسٹاپ نقصان کی حد کو ٹون کرتا ہے۔ اصلاح کے لئے λ پیرامیٹر کے ساتھ ہم آہنگ ہوسکتا ہے۔ بڑا λ وسیع اسٹاپ کی ضمانت دیتا ہے۔ چھوٹا λ تنگ اسٹاپ کی اجازت دیتا ہے اور زیادہ منافع میں تالے لگاتا ہے۔

  3. خطرہ:انعامی تناسب براہ راست منافع اور منافع کی شرح پر اثر انداز ہوتا ہے۔ ڈراؤنڈ کنٹرول اور منافع کی صلاحیت کے ل different مختلف تناسب کا تجربہ کرسکتا ہے۔

نتیجہ

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


/*backtest
start: 2024-02-17 00:00:00
end: 2024-02-18 00:00:00
period: 1h
basePeriod: 15m
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/
// © tathal animouse hajixde

//@version=4
strategy("LPB MicroCycles Strategy", "HPVWAP", overlay=true, default_qty_type=strategy.percent_of_equity, default_qty_value=100, max_bars_back=5000)
startDate = input(title="Start Date", type=input.integer,
     defval=1, minval=1, maxval=31)
startMonth = input(title="Start Month", type=input.integer,
     defval=1, minval=1, maxval=12)
startYear = input(title="Start Year", type=input.integer,
     defval=2010, minval=1800, maxval=2100)

endDate = input(title="End Date", type=input.integer,
     defval=31, minval=1, maxval=31)
endMonth = input(title="End Month", type=input.integer,
     defval=12, minval=1, maxval=12)
endYear = input(title="End Year", type=input.integer,
     defval=2021, minval=1800, maxval=2100)
     
// STEP 2:
// Look if the close time of the current bar
// falls inside the date range
inDateRange = true

///

// Strategy Settings
var g_strategy      = "Strategy Settings"
stopMultiplier      = input(title="Stop Loss ATR", type=input.float, defval=1.0, group=g_strategy, tooltip="Stop loss multiplier (x ATR)")
rr                  = input(title="R:R", type=input.float, defval=1.0, group=g_strategy, tooltip="Risk:Reward profile")

/// Backtester Settings
var g_tester        = "Backtester Settings"
startBalance        = input(title="Starting Balance", type=input.float, defval=10000.0, group=g_tester, tooltip="Your starting balance for the custom inbuilt tester system")
riskPerTrade        = input(title="Risk Per Trade", type=input.float, defval=1.0, group=g_tester, tooltip="Your desired % risk per trade (as a whole number)")
drawTester          = input(title="Draw Backtester", type=input.bool, defval=true, group=g_tester, tooltip="Turn on/off inbuilt backtester display")

////////////////INPUTS///////////////////
lambda = input(defval = 1000, type = input.float, title = "Smoothing Factor (Lambda)", minval = 1)
leng = input(defval = 100, type = input.integer, title = "Filter Length", minval = 1)
src = ohlc4
atr = atr(14)

///////////Construct Arrays///////////////
a = array.new_float(leng, 0.0) 
b = array.new_float(leng, 0.0)
c = array.new_float(leng, 0.0)
d = array.new_float(leng, 0.0)
e = array.new_float(leng, 0.0)
f = array.new_float(leng, 0.0)

/////////Initialize the Values///////////

ll1 = leng-1
ll2 = leng-2

for i = 0 to ll1
    array.set(a,i, lambda*(-4))
    array.set(b,i, src[i])
    array.set(c,i, lambda*(-4))
    array.set(d,i, lambda*6 + 1)
    array.set(e,i, lambda)
    array.set(f,i, lambda)

array.set(d, 0,  lambda + 1.0)
array.set(d, ll1, lambda + 1.0)
array.set(d, 1,  lambda * 5.0 + 1.0)
array.set(d, ll2, lambda * 5.0 + 1.0)

array.set(c, 0 , lambda * (-2.0))
array.set(c, ll2, lambda * (-2.0))

array.set(a, 0 , lambda * (-2.0))
array.set(a, ll2, lambda * (-2.0))

//////////////Solve the optimization issue/////////////////////
float r = array.get(a, 0)
float s = array.get(a, 1)
float t = array.get(e, 0)
float xmult = 0.0

for i = 1 to ll2
    xmult := r / array.get(d, i-1) 
    array.set(d, i, array.get(d, i) - xmult * array.get(c, i-1))
    array.set(c, i, array.get(c, i) - xmult * array.get(f, i-1))
    array.set(b, i, array.get(b, i) - xmult * array.get(b, i-1))

    xmult := t / array.get(d, i-1)
    r     := s - xmult*array.get(c, i-1)
    array.set(d, i+1, array.get(d, i+1) - xmult * array.get(f, i-1))
    array.set(b, i+1, array.get(b, i+1) - xmult * array.get(b, i-1))
    
    s     := array.get(a, i+1)
    t     := array.get(e, i)

xmult := r / array.get(d, ll2)
array.set(d, ll1, array.get(d, ll1) - xmult * array.get(c, ll2))

x = array.new_float(leng, 0) 
array.set(x, ll1, (array.get(b, ll1) - xmult * array.get(b, ll2)) / array.get(d, ll1))
array.set(x, ll2, (array.get(b, ll2) - array.get(c, ll2) * array.get(x, ll1)) / array.get(d, ll2))

for j = 0 to leng-3
    i = leng-3 - j
    array.set(x, i, (array.get(b,i) - array.get(f,i)*array.get(x,i+2) - array.get(c,i)*array.get(x,i+1)) / array.get(d, i))



//////////////Construct the output///////////////////
HP = array.get(x,0)

///////////////Custom VWAP////////////////////////
TimeFrame = input('1', type=input.resolution)
start = security(syminfo.tickerid, TimeFrame, time)

//------------------------------------------------
newSession = iff(change(start), 1, 0)
//------------------------------------------------
vwapsum = 0.0
vwapsum := iff(newSession, HP*volume, vwapsum[1]+HP*volume)
volumesum = 0.0
volumesum := iff(newSession, volume, volumesum[1]+volume)
v2sum = 0.0
v2sum := iff(newSession, volume*HP*HP, v2sum[1]+volume*HP*HP)
myvwap = vwapsum/volumesum
dev = sqrt(max(v2sum/volumesum - myvwap*myvwap, 0))
Coloring=close>myvwap?color.new(#81c784, 62):color.new(#c2185b, 38)
av=myvwap
showBcol = input(true, type=input.bool, title="Show barcolors")


///////////////Entry & Exit///////////////////

// Custom function to convert pips into whole numbers
toWhole(number) =>
    return = atr < 1.0 ? (number / syminfo.mintick) / (10 / syminfo.pointvalue) : number
    return := atr >= 1.0 and atr < 100.0 and syminfo.currency == "JPY" ? return * 100 : return
    
// Custom function to convert whole numbers back into pips
toPips(number) =>
    return = atr >= 1.0 ? number : (number * syminfo.mintick) * (10 / syminfo.pointvalue)
    return := atr >= 1.0 and atr < 100.0 and syminfo.currency == "JPY" ? return / 100 : return
    
// Custom function to truncate (cut) excess decimal places
truncate(_number, _decimalPlaces) =>
    _factor = pow(10, _decimalPlaces)
    int(_number * _factor) / _factor


///////////////Conditional Strategy Logic//////////////
Long = crossover(av, ohlc4)
Sell = crossunder(av, ohlc4)

// Check if we have confirmation for our setup
validLong = Long and strategy.position_size == 0 and inDateRange and barstate.isconfirmed
validShort = Sell and strategy.position_size == 0 and inDateRange and barstate.isconfirmed


// Calculate our stop distance & size for the current bar
stopSize = atr * stopMultiplier
longStopPrice = low < low[1] ? low - stopSize : low[1] - stopSize
longStopDistance = close - longStopPrice
longTargetPrice = close + (longStopDistance * rr)


// Save trade stop & target & position size if a valid setup is detected
var t_entry = 0.0
var t_stop = 0.0
var t_target = 0.0
var t_direction = 0

// Detect valid long setups & trigger alert
if validLong
    t_entry := close
    t_stop := longStopPrice
    t_target := longTargetPrice
    t_direction := 1
    strategy.entry(id="Long", long=strategy.long, when=validLong, comment="(SL=" + tostring(truncate(toWhole(longStopDistance),2)) + " pips)")
    // Fire alerts
    alert(message="Long Detected", freq=alert.freq_once_per_bar_close)
    
// Check if price has hit long stop loss or target
if t_direction == 1 and (low <= t_stop or high >= t_target)
    t_direction := 0

// Check if price has hit short stop loss or target
if t_direction == -1 and (high >= t_stop or low <= t_target)
    t_direction := 0


// Exit trades whenever our stop or target is hit
strategy.exit(id="Long Exit", from_entry="Long", limit=t_target, stop=t_stop, when=strategy.position_size > 0)

// Draw trade data
plot(strategy.position_size != 0 or validLong? t_stop : na, title="Trade Stop Price", color=color.red, style=plot.style_linebr)
plot(strategy.position_size != 0 or validLong? t_target : na, title="Trade Target Price", color=color.green, style=plot.style_linebr)

/////////////////////Plotting//////////////////////////

A=plot(av, color=Coloring, title="HP VWAP")

barcolor(showBcol?Coloring:na)

fill(A, plot(ohlc4), Coloring)

// Draw price action setup arrows
plotshape(validLong ? 1 : na, style=shape.triangleup, location=location.belowbar, color=color.green, title="Bullish Setup")

// // --- BEGIN TESTER CODE --- //
// // Declare performance tracking variables
// var balance = startBalance
// var drawdown = 0.0
// var maxDrawdown = 0.0
// var maxBalance = 0.0
// var totalPips = 0.0
// var totalWins = 0
// var totalLoss = 0

// // Detect winning trades
// if strategy.wintrades != strategy.wintrades[1]
//     balance := balance + ((riskPerTrade / 100) * balance) * rr
//     totalPips := totalPips + abs(t_entry - t_target)
//     totalWins := totalWins + 1
//     if balance > maxBalance
//         maxBalance := balance
        
// // Detect losing trades
// if strategy.losstrades != strategy.losstrades[1]
//     balance := balance - ((riskPerTrade / 100) * balance)
//     totalPips := totalPips - abs(t_entry - t_stop)
//     totalLoss := totalLoss + 1
//     // Update drawdown
//     drawdown := (balance / maxBalance) - 1
//     if drawdown < maxDrawdown
//         maxDrawdown := drawdown
        
// // Prepare stats table
// var table testTable = table.new(position.top_right, 5, 2, border_width=1)
// f_fillCell(_table, _column, _row, _title, _value, _bgcolor, _txtcolor) =>
//     _cellText = _title + "\n" + _value
//     table.cell(_table, _column, _row, _cellText, bgcolor=_bgcolor, text_color=_txtcolor)
    
// // Draw stats table
// var bgcolor = color.new(color.black,0)
// if drawTester
//     if barstate.islastconfirmedhistory
//         // Update table
//         dollarReturn = balance - startBalance
//         f_fillCell(testTable, 0, 0, "Total Trades:", tostring(strategy.closedtrades), bgcolor, color.white)
//         f_fillCell(testTable, 0, 1, "Win Rate:", tostring(truncate((strategy.wintrades/strategy.closedtrades)*100,2)) + "%", bgcolor, color.white)
//         f_fillCell(testTable, 1, 0, "Starting:", "$" + tostring(startBalance), bgcolor, color.white)
//         f_fillCell(testTable, 1, 1, "Ending:", "$" + tostring(truncate(balance,2)), bgcolor, color.white)
//         f_fillCell(testTable, 2, 0, "Return:", "$" + tostring(truncate(dollarReturn,2)), dollarReturn > 0 ? color.green : color.red, color.white)
//         f_fillCell(testTable, 2, 1, "Pips:", (totalPips > 0 ? "+" : "") + tostring(truncate(toWhole(totalPips),2)), bgcolor, color.white)
//         f_fillCell(testTable, 3, 0, "Return:", (dollarReturn > 0 ? "+" : "") + tostring(truncate((dollarReturn / startBalance)*100,2)) + "%", dollarReturn > 0 ? color.green : color.red, color.white)
//         f_fillCell(testTable, 3, 1, "Max DD:", tostring(truncate(maxDrawdown*100,2)) + "%", color.red, color.white)
// // --- END TESTER CODE --- //

مزید