প্রবণতা রায়ের সাথে মিলিত গতিশীলতা মাল্টি-ফ্যাক্টর পরিমাণগত ট্রেডিং কৌশল

লেখক:চাওঝাং, তারিখঃ ২০২৩-১১-২৩ 14:58:57
ট্যাগঃ

img

সারসংক্ষেপ

এই কৌশলটি একটি মাল্টি-ফ্যাক্টর বিচারকৃত পরিমাণগত ট্রেডিং কৌশল যা গতির সূচক এবং প্রবণতা সূচককে একত্রিত করে। কৌশলটি একাধিক চলমান গড়ের গাণিতিক সমন্বয় গণনা করে বাজারের সামগ্রিক প্রবণতা এবং গতির দিক নির্ধারণ করে এবং প্রান্তিক অবস্থার উপর ভিত্তি করে ট্রেডিং সংকেত তৈরি করে।

কৌশল নীতি

  1. একাধিক চলমান গড় এবং গতির সূচক গণনা করুন
    • হিসাব করুন হারমোনিক চলমান গড়, স্বল্পমেয়াদী চলমান গড়, মধ্যমেয়াদী চলমান গড়, দীর্ঘমেয়াদী চলমান গড় এবং অন্যান্য একাধিক চলমান গড়
    • মূল্য পরিবর্তনের প্রবণতা প্রতিফলিত করার জন্য প্রতিটি চলমান গড়ের মধ্যে পার্থক্য গণনা করুন
    • মূল্য পরিবর্তনের গতি প্রতিফলিত করার জন্য প্রতিটি চলমান গড়ের প্রথম অর্ডার ডেরিভেটিভ গণনা করুন
    • প্রবণতা দিক নির্ধারণের জন্য সাইন এবং কোসাইন সূচক গণনা করুন
  2. ব্যাপকভাবে ট্রেডিং সংকেত বিচার
    • গতির সূচক, প্রবণতা সূচক এবং অন্যান্য মাল্টিফ্যাক্টরগুলির ওজনযুক্ত গণনা
    • ফলাফলের মান এবং প্রান্তিকের মধ্যে দূরত্ব অনুযায়ী বর্তমান বাজারের অবস্থা বিচার করুন
    • দীর্ঘ ও সংক্ষিপ্ত ট্রেডিং সিগন্যাল ইস্যু করুন

সুবিধা বিশ্লেষণ

  1. মাল্টি-ফ্যাক্টর বিচার সিগন্যালের নির্ভুলতা উন্নত করে
    • মূল্য, প্রবণতা, গতি এবং অন্যান্য কারণগুলি ব্যাপকভাবে বিবেচনা করুন
    • বিভিন্ন ফ্যাক্টর বিভিন্ন ওজন সঙ্গে কনফিগার করা যেতে পারে
  2. সামঞ্জস্যযোগ্য পরামিতি, বিভিন্ন বাজারে অভিযোজিত
    • চলমান গড়ের পরামিতি, ট্রেডিং পরিসীমা সীমানা কাস্টমাইজ করা যেতে পারে
    • বিভিন্ন চক্র এবং বাজার পরিবেশের সাথে মানিয়ে নিতে পারে
  3. পরিষ্কার কোড কাঠামো, বুঝতে সহজ
    • নামকরণের স্পেসিফিকেশন, সম্পূর্ণ মন্তব্য
    • সেকেন্ডারি ডেভেলপমেন্ট এবং অপ্টিমাইজেশান সহজ

ঝুঁকি বিশ্লেষণ

  1. প্যারামিটার অপ্টিমাইজেশনের অসুবিধা বেশি
    • অপ্টিমাম পরামিতি খুঁজে পেতে অনেক ঐতিহাসিক তথ্য ব্যাক টেস্টিং প্রয়োজন
  2. ট্রেডিং ফ্রিকোয়েন্সি খুব বেশি হতে পারে
    • একাধিক কারণের সমন্বয়মূলক সিদ্ধান্তের ফলে অনেক লেনদেন হতে পারে
  3. বাজারের সাথে উচ্চ সম্পর্ক
    • প্রবণতা মূল্যায়ন কৌশল অযৌক্তিক আচরণের প্রবণতা আছে

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

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

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

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


/*backtest
start: 2022-11-16 00:00:00
end: 2023-11-22 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=2
////////////////////////////////////////////////////////////
//  Copyright by HPotter v1.0 14/03/2017
// This is modified version of Dale Legan's "Confluence" indicator written by Gary Fritz.
// ================================================================
// Here is Gary`s commentary:
// Since the Confluence indicator returned several "states" (bull, bear, grey, and zero), 
// he modified the return value a bit:
// -9 to -1 = Bearish
// -0.9 to 0.9 = "grey" (and zero)
// 1 to 9 = Bullish
// The "grey" range corresponds to the "grey" values plotted by Dale's indicator, but 
// they're divided by 10.
//
// You can change long to short in the Input Settings
// Please, use it only for learning or paper trading. Do not for real trading.
////////////////////////////////////////////////////////////

strategy(title="Confluence", shorttitle="Confluence")
Harmonic = input(10, minval=1)
BuyBand = input(9)
SellBand = input(-9)
reverse = input(false, title="Trade reverse")
hline(SellBand, color=red, linestyle=line)
hline(BuyBand, color=green, linestyle=line)

Price = close

STL = round((Harmonic * 2) - 1 - 0.5)
ITL = round((STL * 2) - 1 - 0.5)
LTL = round((ITL * 2) - 1 - 0.5)
HOFF = round(Harmonic / 2 - 0.5)
SOFF = round(STL / 2 - 0.5)
IOFF = round(ITL / 2 - 0.5)

xHavg = sma(Price, Harmonic)
xSavg = sma(Price, STL)
xIavg = sma(Price, ITL)
xLavg = sma(Price, LTL)

xvalue2 = xSavg - xHavg[HOFF]
xvalue3 = xIavg - xSavg[SOFF]
xvalue12 = xLavg - xIavg[IOFF]

xmomsig = xvalue2 + xvalue3 + xvalue12

xLavgOHLC = sma(ohlc4, LTL - 1)

xH2 = sma(Price, Harmonic - 1)
xS2 = sma(Price, STL - 1)
xI2 = sma(Price, ITL - 1)
xL2 = sma(Price, LTL - 1)

DerivH = (xHavg * 2) - xHavg[1]
DerivS = (xSavg * 2) - xSavg[1]
DerivI = (xIavg * 2) - xIavg[1]
DerivL = (xLavg * 2) - xLavg[1]
SumDH = Harmonic * DerivH
SumDS = STL * DerivS
SumDI = ITL * DerivI
SumDL = LTL * DerivL

LengH = Harmonic - 1
LengS = STL - 1
LengI = ITL - 1
LengL = LTL - 1

N1H = xH2 * LengH
N1S = xS2 * LengS
N1I = xI2 * LengI
N1L = xL2 * LengL

DRH = SumDH - N1H
DRS = SumDS - N1S
DRI = SumDI - N1I
DRL = SumDL - N1L

SumH = xH2 * (Harmonic - 1)
SumS = xS2 * (STL - 1)
SumI = xI2 * (ITL - 1)
SumL = xLavgOHLC * (LTL - 1)

xvalue5 = (SumH + DRH) / Harmonic
xvalue6 = (SumS + DRS) / STL
xvalue7 = (SumI + DRI) / ITL
xvalue13 = (SumL + DRL) / LTL

value9 = xvalue6 - xvalue5[HOFF]
value10 = xvalue7 - xvalue6[SOFF]
value14 = xvalue13 - xvalue7[IOFF]
xmom = value9 + value10 + value14

HT = sin(xvalue5 * 2 * 3.14 / 360) + cos(xvalue5 * 2 * 3.14 / 360)
HTA = sin(xHavg * 2 * 3.14 / 360) + cos(xHavg * 2 * 3.14 / 360)
ST = sin(xvalue6 * 2 * 3.14 / 360) + cos(xvalue6 * 2 * 3.14 / 360)
STA = sin(xSavg * 2 * 3.14 / 360) + cos(xSavg * 2 * 3.14 / 360)
IT = sin(xvalue7 * 2 * 3.14 / 360) + cos(xvalue7 * 2 * 3.14 / 360)
ITA = sin(xIavg * 2 * 3.14 / 360) + cos(xIavg * 2 * 3.14 / 360)

xSum = HT + ST + IT
xErr = HTA + STA + ITA

Condition2 = (((xSum > xSum[SOFF]) and (xHavg < xHavg[SOFF])) or ((xSum < xSum[SOFF]) and (xHavg > xHavg[SOFF])))
Phase = iff(Condition2 , -1 , 1)
xErrSum = (xSum - xErr) * Phase
xErrSig = sma(xErrSum, SOFF)

xvalue70 = xvalue5 - xvalue13
xvalue71 = sma(xvalue70, Harmonic)


ErrNum = iff (xErrSum > 0 and xErrSum < xErrSum[1] and xErrSum < xErrSig, 1,
          iff (xErrSum > 0 and xErrSum < xErrSum[1] and xErrSum > xErrSig, 2, 
           iff (xErrSum > 0 and xErrSum > xErrSum[1] and xErrSum < xErrSig, 2,
             iff (xErrSum > 0 and xErrSum > xErrSum[1] and xErrSum > xErrSig, 3,
              iff (xErrSum < 0 and xErrSum > xErrSum[1] and xErrSum > xErrSig, -1,
               iff (xErrSum < 0 and xErrSum < xErrSum[1] and xErrSum > xErrSig, -2,
                 iff (xErrSum < 0 and xErrSum > xErrSum[1] and xErrSum < xErrSig, -2,
                  iff (xErrSum < 0 and xErrSum < xErrSum[1] and xErrSum < xErrSig, -3, 0))))))))


momNum = iff (xmom > 0 and xmom < xmom[1] and xmom < xmomsig , 1,
          iff (xmom > 0 and xmom < xmom[1] and xmom > xmomsig, 2,
           iff (xmom > 0 and xmom > xmom[1] and xmom < xmomsig, 2,
             iff (xmom > 0 and xmom > xmom[1] and xmom > xmomsig, 3,
              iff (xmom < 0 and xmom > xmom[1] and xmom > xmomsig, -1,
               iff (xmom < 0 and xmom < xmom[1] and xmom > xmomsig, -2,
                 iff (xmom < 0 and xmom > xmom[1] and xmom < xmomsig, -2,
                  iff (xmom < 0 and xmom < xmom[1] and xmom < xmomsig, -3, 0))))))))

TCNum =  iff (xvalue70 > 0 and xvalue70 < xvalue70[1] and xvalue70 < xvalue71, 1,
          iff (xvalue70 > 0 and xvalue70 < xvalue70[1] and xvalue70 > xvalue71, 2,
           iff (xvalue70 > 0 and xvalue70 > xvalue70[1] and xvalue70 < xvalue71, 2,
             iff (xvalue70 > 0 and xvalue70 > xvalue70[1] and xvalue70 > xvalue71, 3,
              iff (xvalue70 < 0 and xvalue70 > xvalue70[1] and xvalue70 > xvalue71, -1,
               iff (xvalue70 < 0 and xvalue70 < xvalue70[1] and xvalue70 > xvalue71, -2,
                 iff (xvalue70 < 0 and xvalue70 > xvalue70[1] and xvalue70 < xvalue71, -2,
                  iff (xvalue70 < 0 and xvalue70 < xvalue70[1] and xvalue70 < xvalue71, -3,0))))))))

value42 = ErrNum + momNum + TCNum
Confluence = iff (value42 > 0 and xvalue70 > 0, value42,
              iff (value42 < 0 and xvalue70 < 0, value42,
               iff ((value42 > 0 and xvalue70 < 0) or (value42 < 0 and xvalue70 > 0), value42 / 10, 0)))
Res1 = iff (Confluence >= 1, Confluence, 0)
Res2 = iff (Confluence <= -1, Confluence, 0)
Res3 = iff (Confluence == 0, 0, iff (Confluence > -1 and Confluence < 1, 10 * Confluence, 0))
pos = iff(Res2 >= SellBand and Res2 != 0, -1,
	     iff(Res1 <= BuyBand and Res1 != 0, 1, 
	       iff(Res3 != 0, 0, nz(pos[1], 0))))
possig = iff(reverse and pos == 1, -1,
          iff(reverse and pos == -1, 1, pos))	   
if (possig == 1) 
    strategy.entry("Long", strategy.long)
if (possig == -1)
    strategy.entry("Short", strategy.short)	   	 
if (possig == 0)
    strategy.close("Long", when = possig == 0)	 
    strategy.close("Short", when = possig == 0)	 
barcolor(possig == -1 ? red: possig == 1 ? green : blue )
plot(Res1, color=green, title="Confluence", linewidth=3, style = histogram)
plot(Res2, color=red, title="Confluence", linewidth=3, style = histogram)
plot(Res3, color=gray, title="Confluence",  linewidth=3, style = histogram)



আরো