রিসোর্স লোড হচ্ছে... লোডিং...

ডনচিয়ান চ্যানেল এবং ল্যারি উইলিয়ামস লার্জ ট্রেড ইনডেক্স কৌশল

লেখক:চাওঝাং, তারিখঃ 2024-04-12 17:27:25
ট্যাগঃ

img

সারসংক্ষেপ

এই কৌশলটি তিনটি সূচক - ডনচিয়ান চ্যানেল, ল্যারি উইলিয়ামস লার্জ ট্রেড ইনডেক্স (এলডব্লিউটিআই) এবং ভলিউম মুভিং এভারেজকে একত্রিত করে ট্রেডিং সিগন্যাল তৈরি করে। যখন দাম ডনচিয়ান চ্যানেলের উপরের ব্যান্ডের উপরে ভেঙে যায় তখন এটি একটি দীর্ঘ অবস্থানে প্রবেশ করে, এলডব্লিউটিআই সবুজ হয় এবং ভলিউমটি চলমান গড়ের চেয়ে বড়। যখন দাম ডনচিয়ান চ্যানেলের নীচের ব্যান্ডের নীচে ভেঙে যায়, এলডব্লিউটিআই লাল হয় এবং ভলিউমটি চলমান গড়ের চেয়ে বড় হয় তখন এটি একটি শর্ট পজিশনে প্রবেশ করে। যখন দাম স্টপ লস বা লাভ গ্রহণের স্তরে পৌঁছে যায় বা যখন দাম ডনচিয়ান চ্যানেলের মাঝারি ব্যান্ডে ফিরে আসে তখন কৌশলটি অবস্থানগুলি থেকে বেরিয়ে আসে। একই প্রবণীর দিকের পুনরাবৃত্তি এন্ট্রিগুলি রোধ করতে, কৌশলটি একটি ট্রেড কাউন্টার ব্যবহার করে যা কেবলমাত্র নতুন এন্ট

কৌশল নীতি

  1. ডনচিয়ান চ্যানেলঃ দাম উপরের ব্যান্ডের উপরে ভাঙলে একটি দীর্ঘ সংকেত উৎপন্ন হয় এবং দাম নিম্ন ব্যান্ডের নীচে ভাঙলে একটি সংক্ষিপ্ত সংকেত উৎপন্ন হয়।
  2. ল্যারি উইলিয়ামস লার্জ ট্রেড ইনডেক্সঃ লং পজিশন শুধুমাত্র যখন LWTI রঙ সবুজ হয় তখনই অনুমোদিত এবং শর্ট পজিশন শুধুমাত্র যখন লাল হয় তখনই অনুমোদিত।
  3. ভলিউমঃ বর্তমান ভলিউম ভলিউম চলমান গড়ের চেয়ে বেশি হলেই এন্ট্রি অনুমোদিত।
  4. ট্রেড কাউন্টারঃ একই প্রবণতা দিকের পুনরাবৃত্তি এন্ট্রি রোধ করার জন্য, দাম ডোনচিয়ান চ্যানেলের মধ্যবর্তী ব্যান্ড অতিক্রম করার পরে নতুন এন্ট্রি অনুমোদিত।
  5. স্টপ লস এবং টেক প্রফিটঃ প্রবেশের সময় স্টপ লস এবং টেক প্রফিট দূরত্বগুলি এটিআর ভিত্তিতে গণনা করা হয়, যেখানে লাভের দূরত্বটি স্টপ লস দূরত্বকে ঝুঁকি-পুরষ্কার অনুপাতের সাথে গুণিত করে।

কৌশলগত সুবিধা

  1. ট্রেডিং সিগন্যাল নিশ্চিত করার জন্য একাধিক সূচকের সংমিশ্রণ কার্যকরভাবে মিথ্যা সংকেতগুলি ফিল্টার করতে পারে এবং সংকেতের গুণমান উন্নত করতে পারে।
  2. ডায়নামিক স্টপ লস এবং লাভ নিন - স্টপ লস এবং লাভ নিন দূরত্বের পরিবর্তনশীলতার ভিত্তিতে সামঞ্জস্য করা কৌশলটিকে বাজারের পরিবর্তনের সাথে আরও ভালভাবে মানিয়ে নিতে দেয়।
  3. ট্রেড কাউন্টার একই প্রবণতা পুনরাবৃত্তি এন্ট্রি প্রতিরোধ, ট্রেডিং ফ্রিকোয়েন্সি নিয়ন্ত্রণ।
  4. ঝুঁকি-প্রতিদান অনুপাত ভিত্তিক লাভ গ্রহণ - একটি পূর্বনির্ধারিত ঝুঁকি-প্রতিদান অনুপাতের ভিত্তিতে লাভ গ্রহণের স্তর নির্ধারণ করা সম্ভাব্য লাভের ঝুঁকি অতিক্রম করতে দেয়।

কৌশলগত ঝুঁকি

  1. প্যারামিটার ঝুঁকি - বিভিন্ন প্যারামিটার সেটিং দ্বারা কৌশলটির কার্যকারিতা ব্যাপকভাবে প্রভাবিত হয়, যা বিভিন্ন বাজারের বৈশিষ্ট্য এবং সময়সীমার উপর ভিত্তি করে অপ্টিমাইজেশান প্রয়োজন।
  2. বিপজ্জনক বাজার ঝুঁকি - বিপজ্জনক বাজার পরিস্থিতিতে, ঘন ঘন ওঠানামা কৌশলটি ঘন ঘন প্রবেশ এবং পজিশনের প্রস্থান করতে পারে, যার ফলে দুর্বল পারফরম্যান্স হয়।
  3. প্রবণতা ঝুঁকি - যদি প্রবণতার ধারাবাহিকতা না থাকে তবে ঘন ঘন প্রবেশ এবং প্রস্থান ঘটতে পারে, যার ফলে ক্ষতি বৃদ্ধি পায়।
  4. ব্ল্যাক সোয়ান ঝুঁকি - চরম বাজারের পরিস্থিতিতে, সূচকগুলি ব্যর্থ হতে পারে, যার ফলে কৌশলটির দুর্বল পারফরম্যান্স হতে পারে।

কৌশল অপ্টিমাইজেশান নির্দেশাবলী

  1. সেরা প্যারামিটার সমন্বয় খুঁজে পেতে বিভিন্ন যন্ত্র এবং সময়সীমার জন্য পরামিতি অপ্টিমাইজ করুন।
  2. প্রবণতা ফিল্টারিং শর্ত যুক্ত করুন, যেমন চলমান গড় বা গতির সূচক ব্যবহার করে, যখন প্রবণতা পরিষ্কার হয় তখনই অবস্থান প্রবেশ করুন, অস্থির পরিবেশে ব্যবসায়ের সংখ্যা হ্রাস করুন।
  3. বিপজ্জনক বাজারের অবস্থার জন্য রেঞ্জ ব্রেকআউট কৌশল ব্যবহার করার কথা বিবেচনা করুন।
  4. স্টপ লস বা অন্যান্য পদ্ধতি প্রবর্তন করে স্টপ লস এবং লাভের যুক্তিকে অনুকূল করুন।
  5. চরম বাজারের অবস্থার জন্য, স্থির অর্থ ব্যবস্থাপনা এবং সর্বাধিক উত্তোলনের সীমা প্রবর্তন বিবেচনা করুন।

সংক্ষিপ্তসার

ডনচিয়ান চ্যানেল এবং ল্যারি উইলিয়ামস লার্জ ট্রেড ইনডেক্স কৌশল একটি ক্লাসিক ট্রেডিং কৌশল। এটি ডনচিয়ান চ্যানেল ব্যবহার করে ট্রেন্ডের দিক ধরে রাখে, এলডব্লিউটিআই, ভলিউম এবং অন্যান্য সূচকগুলি ব্যবহার করে সংকেতগুলি ফিল্টার করে এবং কঠোর ঝুঁকি নিয়ন্ত্রণের সাথে গতিশীল স্টপ লস এবং লাভ গ্রহণ করে। সামগ্রিকভাবে, এটি একটি কৌশল কাঠামো যা স্থিতিশীল রিটার্নের সম্ভাবনা রয়েছে। তবে, এটি লক্ষ করা গুরুত্বপূর্ণ যে কৌশলটি পরামিতির প্রতি সংবেদনশীল এবং অস্থির বাজারের অবস্থার মধ্যে খারাপভাবে সম্পাদন করে। এটি ট্রেন্ডিং বাজারে ব্যবহারের জন্য প্রস্তাবিত। ব্যবহারিক প্রয়োগে, ভাল এবং স্থিতিশীল রিটার্ন অর্জনের জন্য কঠোর অর্থ পরিচালনার পাশাপাশি ট্রেডিং যন্ত্র এবং বাজারের বৈশিষ্ট্যগুলির উপর ভিত্তি করে পরামিতি এবং যৌক্তিকতার আরও অপ্টিমাইজেশন প্রয়োজন।


/*backtest
start: 2024-04-04 00:00:00
end: 2024-04-11 00:00:00
period: 1m
basePeriod: 1m
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/
// © DillonGrech
//
//This is a Donchian Channel Trading Strategy which was found through the 
//YouTube channel TradingLab. 
//
//This Strategy uses the Donchian Channel, Larry Williams Large Trade Index,
//and Volume with Moving Average indicators for long and short trades.
//
//Strategy will enter based off indicator entry conditions and will not
//re-enter a trade until the price crosses through the Donchian Channel
//basis line (to prevent re-entering trades in same trend). Strategy will
//exit at stop loss or take profit, or when price crosses donchian basis.
//
//The strategy has been coded by Dillon Grech as part of his YouTube channel
//and a detailed video can be found on his channel at:
//https://www.youtube.com/c/DillonGrech
//https://www.youtube.com/watch?v=5IFe2Vjf61Y
//Source code and template files can be found on his GitHub at:
//https://github.com/Dillon-Grech
//==============================================================================
//@version=5
strategy("Donchian Channel Strategy [DillonGrech]", overlay=true, margin_long=100, margin_short=100)

//==============================================================================
//DONCHIAN CHANNEL
//==============================================================================
//Allow user to select whether they would like to use indicator
Don_Input = input(true, title='Use Donchian Channel?', group = "Donchian Settings")

//Indicator
don_length = input.int(96, minval = 1, group = "Donchian Settings")
don_lower  = ta.lowest(don_length)
don_upper  = ta.highest(don_length)
don_basis  = math.avg(don_upper, don_lower)
plot(don_basis,     "Don Basis", color = #FF6D00)
u = plot(don_upper, "Don Upper", color = #2962FF)
l = plot(don_lower, "Don Lower", color = #2962FF)
fill(u, l, color = color.rgb(33, 150, 243, 95), title = "Background")

//Conditions - Enter trades when there is a cross of price and previous donchian channel value
Ind_1_L = Don_Input == false ? false : ta.crossover(close,don_upper[1])
Ind_1_S = Don_Input == false ? false : ta.crossunder(close,don_lower[1])

//==============================================================================
//LARRY WILLIAMS LARGE TRADE INDEX (LWTI) - LOXX
//==============================================================================
//Allow user to select whether they would like to use indicator
LWTI_Input = input(true, title='Use LWTI?', group = "LWTI Settings")

//Indicator
greencolor = #2DD204
redcolor = #D2042D 

variant(type, src, len) =>
    sig = 0.0
    if type == "SMA"
        sig := ta.sma(src, len) 
    else if type == "EMA"
        sig := ta.ema(src, len) 
    else if type == "WMA"
        sig := ta.wma(src, len)   
    else if type == "RMA"
        sig := ta.rma(src, len)  
    sig
    
LWTI_per = input.int(25, "Period", group = "LWTI Settings")
LWTI_smthit = input.bool(false, "Smooth LWPI?", group = "LWTI Settings")
LWTI_type = input.string("SMA", "Smoothing Type", options = ["EMA", "WMA", "RMA", "SMA"], group = "LWTI Settings")
LWTI_smthper = input.int(20, "Smoothing Period", group = "LWTI Settings")

LWTI_ma = ta.sma(close - nz(close[LWTI_per]), LWTI_per)
LWTI_atr = ta.atr(LWTI_per)
LWTI_out = LWTI_ma/LWTI_atr * 50 + 50
LWTI_out := LWTI_smthit ? variant(LWTI_type, LWTI_out, LWTI_smthper) : LWTI_out

LWTI_colorout = LWTI_out > 50 ? greencolor : redcolor

//Conditions - Enter on color of indicator
Ind_2_L = LWTI_Input == false ? true : LWTI_colorout == greencolor
Ind_2_S = LWTI_Input == false ? true : LWTI_colorout == redcolor

//==============================================================================
//VOLUME INDICATOR
//==============================================================================
//Allow user to select whether they would like to use indicator
Vol_Input = input(true, title='Use Volume?', group = "Volume Settings")

//Indicator
Vol_Ma_Period = input.int(30,"Volume MA Period", group = "Volume Settings")
Vol_Ma = ta.sma(volume,Vol_Ma_Period)

//Conditions - Enter when volume is greater than moving average
Ind_3_L = Vol_Input == false ? true : volume > Vol_Ma
Ind_3_S = Vol_Input == false ? true : volume > Vol_Ma

//==============================================================================
//DONCHIAN CHANNEL TRADE COUNTER
//==============================================================================
//Stores whether a trade has been taken, and resets when there is a cross of price and donchain basis
Trade_Counter = float(0)
Don_Basis_Cross = ta.cross(don_basis[1], close)
if strategy.position_size!=0
    Trade_Counter := 1
else if Don_Basis_Cross
    Trade_Counter := 0
else 
    Trade_Counter := Trade_Counter[1]

Plot_Trade_Counter = input.bool(false, "Plot Trade Position Counter?", group = "Plot Settings")
plotchar(Plot_Trade_Counter and Trade_Counter == 0 ? true : false, color = na, text = '0')
plotchar(Plot_Trade_Counter and Trade_Counter == 1 ? true : false, color = na, text = '1')

//==============================================================================
//ENTRY CONDITIONS
//==============================================================================
entry_long  = strategy.position_size<=0 and Ind_1_L and Ind_2_L and Ind_3_L and Trade_Counter[1] == 0
entry_short = strategy.position_size>=0 and Ind_1_S and Ind_2_S and Ind_3_S and Trade_Counter[1] == 0

if(entry_long)
    strategy.entry("Long Entry", strategy.long)
if(entry_short)
    strategy.entry("Short Entry", strategy.short)

//==============================================================================
// TAKE PROFIT AND STOP LOSS CONDITIONS
//==============================================================================
Stop_Input   = input(true, title='Use Stop Loss?', group = "Risk Settings")
Profit_Input = input(true, title='Use Take Profit?', group = "Risk Settings")
Profit_RR = input.float(2.0,"Risk Reward Profit Target", group = "Risk Settings")

//Store Price on new entry signal
Entry_Price = strategy.opentrades.entry_price(strategy.opentrades - 1)

//Store Donchain Channel Basis value on new entry signal
Entry_Don_Basis = float(0.0)
if strategy.position_size == 0 or entry_long or entry_short
    Entry_Don_Basis := don_basis
else
    Entry_Don_Basis := Entry_Don_Basis[1]

//Get stop loss distance
Stop_Distance = math.abs(Entry_Price - Entry_Don_Basis)*1.02

//For Long Trades, find the stop loss level
Stop_L = float(0.0)
if Stop_Input == true
    Stop_L := Entry_Price - Stop_Distance
else
    na

//For Long Trades, find the profit level
Profit_L = float(0.0)
if Profit_Input == true
    Profit_L := Entry_Price + Stop_Distance*Profit_RR
else
    na

//For Short Trades, find the stop loss level
Stop_S = float(0.0)
if Stop_Input == true
    Stop_S   := Entry_Price + Stop_Distance
else
    na

//For Short Trades, find the profit level
Profit_S = float(0.0)
if Profit_Input == true
    Profit_S := Entry_Price - Stop_Distance*Profit_RR
else
    na

//Plot profit and stop loss levels for long and short trades
plot(strategy.position_size > 0 ? Profit_L : na, color=color.lime, style=plot.style_linebr, linewidth=2)
plot(strategy.position_size > 0 ? Stop_L : na,   color=color.red,  style=plot.style_linebr, linewidth=2)
plot(strategy.position_size < 0 ? Profit_S : na, color=color.lime, style=plot.style_linebr, linewidth=2)
plot(strategy.position_size < 0 ? Stop_S : na,   color=color.red,  style=plot.style_linebr, linewidth=2)

//==============================================================================
//EXIT ORDERS
//==============================================================================
//Exit long trades
if Stop_Input
    strategy.exit(id = 'Exit Long', from_entry ='Long Entry', comment='Long Stop',  stop = Stop_L)

if Profit_Input
    strategy.exit(id = 'Exit Long', from_entry ='Long Entry', comment='Long Profit', limit = Profit_L)

//Exit short trades
if Stop_Input
    strategy.exit(id = 'Exit Short', from_entry ='Short Entry', comment='Short Stop', stop = Stop_S)

if Profit_Input
    strategy.exit(id = 'Exit Short', from_entry ='Short Entry', comment='Short Profit', limit = Profit_S)

//==============================================================================
//CLOSE ORDERS
//==============================================================================
exit_long  = close < don_basis
exit_short = close > don_basis

if(exit_long)
    strategy.close("Long Entry", comment='Long Close', qty_percent=100)
if(exit_short)
    strategy.close("Short Entry", comment='Short Close', qty_percent=100)

আরো