এই নিবন্ধটি আপনাকে একটি ডিজিটাল মুদ্রা অ্যালগরিদম ট্রেডিং কৌশল সম্পর্কে জানাতে চলেছে, যার নাম হল মাল্টি স্ট্র্যাটেজি ইন্টিগ্রেটেড কোয়ান্টাম ট্রেডিং সিস্টেম। এই কৌশলটি একাধিক একক কৌশলগুলির সুবিধাগুলিকে একত্রিত করে একটি মাল্টি স্ট্র্যাটেজি পোর্টফোলিও তৈরি করে যাতে আরও স্থিতিশীলতা এবং বৈচিত্র্য অর্জন করা যায়।
এই কৌশলটি চারটি সাধারণ পরিমাণগত ট্রেডিং কৌশলকে একত্রিত করেঃ
চ্যানেল ব্রেকিং কৌশলঃ একটি নির্দিষ্ট চক্রের সর্বোচ্চ এবং সর্বনিম্ন মূল্যের উপর ভিত্তি করে একটি উপরের এবং নীচের চ্যানেল তৈরি করুন এবং যখন দাম চ্যানেলটি ভেঙে যায় তখন আরও খালি জায়গা তৈরি করুন।
গতিশীলতা কৌশলঃ নির্দিষ্ট সময়ের মধ্যে দামের পরিবর্তনের দিকের উপর ভিত্তি করে গতিশীলতা বিচার করুন, দাম বাড়ার গতি বাড়লে আরও বেশি করুন, দাম কমার গতি বাড়লে খালি করুন।
MACD কৌশলঃ স্বর্ণ ফর্ক এবং মরা ফর্ক দ্বারা নির্ধারিত হয়।
হারামি ফর্মেশনস কৌশলঃ নির্দিষ্ট ফর্মেশন সনাক্ত করে ভবিষ্যতে সম্ভাব্য মূল্যের বিপর্যয় নির্ধারণ করে, বিপর্যয়ের কাছাকাছি লেনদেন করে।
এই সমস্ত কৌশলগুলির নিজস্ব সুবিধাগুলি রয়েছে, যা একত্রিত হয়ে আরও স্থিতিশীল উপার্জন অর্জন করতে পারে।
চ্যানেল ব্রেকিং কৌশল বাজারের প্রবণতা ক্যাপচার করতে পারে; গতিশীলতা কৌশল সময়মত স্বল্পমেয়াদী প্রবণতা ট্র্যাক করতে পারে; MACD কৌশল মধ্যমেয়াদী প্রবণতা বিপরীত পয়েন্ট আবিষ্কার করতে পারে; হারামি কৌশল গুরুত্বপূর্ণ বিপরীত পয়েন্ট বিচার করতে পারে।
এই সমস্ত কৌশলকে একত্রিত করে, আপনি ট্রেন্ডিংয়ের সময় হ্রাসকে আটকাতে পারেন এবং বিপরীত দিকের অবস্থানের কাছাকাছি বিপরীত দিকের অবস্থানগুলি খুলতে পারেন। একই সাথে, বিভিন্ন কৌশলগুলির মধ্যে ঝুঁকি ছড়িয়ে দেওয়া সম্ভব।
তবে, এই বহু-কৌশল সমন্বয়ের কিছু ত্রুটিও রয়েছেঃ
কৌশলগুলি জটিল এবং প্যারামিটারগুলিকে সামঞ্জস্য করা কঠিন
কিছু নীতির মধ্যে দ্বন্দ্ব থাকতে পারে
লেনদেনের ঘনত্ব এবং লেনদেনের খরচ বৃদ্ধি
একক পদ্ধতির চেয়ে প্রতিক্রিয়াশীলতা খারাপ হতে পারে
সুতরাং, ব্যবহারকারীরা এই মাল্টি-কৌশল সমন্বয়টি ব্যবহার করার সময়, প্যারামিটারগুলি সামঞ্জস্য করার অসুবিধা সম্পর্কে সতর্কতা অবলম্বন করতে হবে, সংঘর্ষের মধ্যে পারস্পরিক প্রভাব পরীক্ষা করতে হবে, লেনদেনের ফ্রিকোয়েন্সি নিয়ন্ত্রণ করতে হবে এবং দীর্ঘমেয়াদী স্থিতিশীলতা নিশ্চিত করার জন্য পর্যাপ্ত ফিডব্যাক করতে হবে।
সামগ্রিকভাবে, এই ধরনের বহু-কৌশল সমন্বিত পরিমাণগত ট্রেডিং সিস্টেমটি একটি খুব সমৃদ্ধ ট্রেডিং পোর্টফোলিও অর্জন করতে পারে এবং বড় প্রবণতাগুলিতে খুব ভাল পারফরম্যান্স দেয়। এটি বিভিন্ন কৌশলগুলির সুবিধাগুলিকে সংহত করে, যা দীর্ঘমেয়াদী ইতিবাচক আয়কে আরও স্থিতিশীল করে তোলে। এটি ব্যবহারকারীদের আরও গবেষণা এবং অপ্টিমাইজেশনের জন্য মূল্যবান, যাতে একটি শক্তিশালী পরিমাণগত ট্রেডিং কৌশল পোর্টফোলিও তৈরি করা যায়।
/*backtest
start: 2023-09-07 00:00:00
end: 2023-09-14 00:00:00
period: 45m
basePeriod: 5m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=3
//Channel breakout
strategy("all_strategy", overlay=true)
length = input(title="Length", minval=1, maxval=1000, defval=5)
upBound = highest(high, length)
downBound = lowest(low, length)
if (not na(close[length]))
strategy.entry("ChBrkLE", strategy.long, stop=upBound + syminfo.mintick, comment="ChBrkLE")
strategy.entry("ChBrkSE", strategy.short, stop=downBound - syminfo.mintick, comment="ChBrkSE")
//plot(strategy.equity, title="equity", color=red, linewidth=2, style=areabr)
//Momentum
length1 = input(12)
price = close
momentum(seria, length) =>
mom = seria - seria[length1]
mom
mom0 = momentum(price, length1)
mom1 = momentum( mom0, 1)
if (mom0 > 0 and mom1 > 0)
strategy.entry("MomLE", strategy.long, stop=high+syminfo.mintick, comment="MomLE")
else
strategy.cancel("MomLE")
if (mom0 < 0 and mom1 < 0)
strategy.entry("MomSE", strategy.short, stop=low-syminfo.mintick, comment="MomSE")
else
strategy.cancel("MomSE")
//plot(strategy.equity, title="equity", color=red, linewidth=2, style=areabr)
//MACD Strategy
fastLength = input(12)
slowlength = input(26)
MACDLength = input(9)
MACD = ema(close, fastLength) - ema(close, slowlength)
aMACD = ema(MACD, MACDLength)
delta = MACD - aMACD
if (crossover(delta, 0))
strategy.entry("MacdLE", strategy.long, comment="MacdLE")
if (crossunder(delta, 0))
strategy.entry("MacdSE", strategy.short, comment="MacdSE")
//plot(strategy.equity, title="equity", color=red, linewidth=2, style=areabr)
//Harami
pctDw = input(60,minval=0,maxval=90,title="Doji, Min % of Range of Candle for Wicks")
pipMin= input(0,minval=0,title="Doji, Previous Candle Min Pip Body Size")
sname=input(true,title="Show Price Action Bar Names")
cbar = input(false,title="Highlight Harami & Doji Bars")
sHm = input(false,title="Show Only Harami Style Doji's")
setalm = input(true, title="Generate Alert for Harami & Doji Bars")
uha =input(true, title="Use Heikin Ashi Candles for Calculations")
bars = input(3,minval=1,maxval=3,step=1, title="Doji, Number of Lookback Bars")
//
// Use only Heikinashi Candles for all calculations
srcclose = uha ? security(heikinashi(syminfo.tickerid), timeframe.period, close) : close
srcopen = uha ? security(heikinashi(syminfo.tickerid), timeframe.period, open) : open
srchigh = uha ? security(heikinashi(syminfo.tickerid), timeframe.period, high) : high
srclow = uha ?security(heikinashi(syminfo.tickerid), timeframe.period, low) : low
//
pip = syminfo.mintick
range = srchigh - srclow
// Calculate Doji/Harami Candles
pctCDw = (pctDw/2) * 0.01
pctCDb = (100-pctDw) * 0.01
//Lookback Candles for bulls or bears
lbBull = bars==1? srcopen[1]>srcclose[1]: bars==2? (srcopen[1]>srcclose[1] and srcopen[2]>srcclose[2]): bars==3?(srcopen[1]>srcclose[1] and srcopen[2]>srcclose[2] and srcopen[3]>srcclose[3]):false
lbBear = bars==1? srcopen[1]<srcclose[1]: bars==2? (srcopen[1]<srcclose[1] and srcopen[2]<srcclose[2]): bars==3?(srcopen[1]<srcclose[1] and srcopen[2]<srcclose[2] and srcopen[3]<srcclose[3]):false
//Lookback Candle Size only if mininum size is > 0
lbSize = pipMin==0? true : bars==1 ? (abs(srcopen[1]-srcclose[1])>pipMin*pip) :
bars==2 ? (abs(srcopen[1]-srcclose[1])>pipMin*pip and abs(srcopen[2]-srcclose[2])>pipMin*pip) :
bars==3 ? (abs(srcopen[1]-srcclose[1])>pipMin*pip and abs(srcopen[2]-srcclose[2])>pipMin*pip and abs(srcopen[3]-srcclose[3])>pipMin*pip) :
false
dojiBu = (srcopen[1] >= max(srcclose,srcopen) and srcclose[1]<=min(srcclose,srcopen)) and lbSize and
(abs(srcclose-srcopen)<range*pctCDb and (srchigh-max(srcclose,srcopen))>(pctCDw*range) and (min(srcclose,srcopen)-srclow)>(pctCDw*range))? 1 : 0
dojiBe = (srcclose[1] >= max(srcclose,srcopen) and srcopen[1]<=min(srcclose,srcopen)) and lbSize and
(abs(srcclose-srcopen)<range*pctCDb and (srchigh-max(srcclose,srcopen))>(pctCDw*range) and (min(srcclose,srcopen)-srclow)>(pctCDw*range))? 1 : 0
haramiBull = (srcopen<=srcclose or (max(srcclose,srcopen)-min(srcclose,srcopen))<pip*0.5) and lbBull and dojiBu
haramiBear = (srcopen>=srcclose or (max(srcclose,srcopen)-min(srcclose,srcopen))<pip*0.5) and lbBear and dojiBe
dojiBull = not sHm and not haramiBull and not haramiBear and lbBull and dojiBu
dojiBear = not sHm and not haramiBull and not haramiBear and lbBear and dojiBe
//
plotshape(haramiBear and sname?srchigh:na,title="Bearish Harami",text='Bearish\nHarami',color=red, style=shape.arrowdown,location=location.abovebar)
plotshape(haramiBear and cbar?max(srcopen,srcclose):na,title="Bear Colour Harami",color=red, style=shape.circle,location=location.absolute,size=size.normal)
//
plotshape(haramiBull and sname?srclow:na,title="Bullish Harami",text='Bullish\nHarami',color=green, style=shape.arrowup,location=location.belowbar)
plotshape(haramiBull and cbar?max(srcopen,srcclose):na,title="Bull Colour Harami",color=green, style=shape.circle,location=location.absolute,size=size.normal)
//
plotshape(dojiBear and sname?srchigh:na,title="Bearish Doji",text='Bearish\nDoji',color=fuchsia, style=shape.arrowdown,location=location.abovebar)
plotshape(dojiBear and cbar?max(srcopen,srcclose):na,title="Bear Colour Doji",color=fuchsia, style=shape.circle,location=location.absolute,size=size.normal)
//
plotshape(dojiBull and sname?srclow:na,title="Bullish Doji",text='Bullish\nDoji',color=aqua, style=shape.arrowup,location=location.belowbar)
plotshape(dojiBull and cbar?max(srcopen,srcclose):na,title="Bull Colour Doji",color=aqua, style=shape.circle,location=location.absolute,size=size.normal)
// Only Alert harami Doji's
bcolor = haramiBull ? 1 : haramiBear ? 2 : dojiBull ? 3 : dojiBear ? 4 : 0
baralert = setalm and bcolor>0
alertcondition(baralert,title="PACDOJI Alert",message="PACDOJI Alert")
//
plotshape(na(baralert[1])?na:baralert[1], transp=0,style=shape.circle,location=location.bottom, offset=-1,title="Bar Alert Confirmed",
color=bcolor[1]==1 ? green : bcolor[1]==2? red : bcolor[1]==3? aqua : bcolor[1]==4? fuchsia : na)
//EOF