স্টোক্যাস্টিক এবং সিসিআই ভিত্তিক কৌশল অনুসরণ করে প্রবণতা

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

img

সারসংক্ষেপ

এই কৌশলটি প্রবণতা অনুসরণ করার জন্য প্রবণতা দিক সনাক্ত করতে স্টোকাস্টিক সূচক এবং সিসিআই সূচককে একত্রিত করে এবং প্রবণতা অনুসরণ করার জন্য পরিসীমা-সীমাবদ্ধ প্রবণতা ফিল্টার করতে রেট অফ চেঞ্জ সূচক ব্যবহার করে। কৌশলটি ব্রেকআউট এন্ট্রি এবং স্টপ লস আউট গ্রহণ করে।

কৌশলগত যুক্তি

  1. স্টোকাস্টিক সূচকটি বাউলি/বেয়ারি প্যাটার্নের বিচার করে
    স্টোকাস্টিকের গোল্ডেন ক্রস হল ক্রয় সংকেত, যখন ডেথ ক্রস হল বিক্রয় সংকেত
  2. সিসিআই সূচক প্রবণতার দিক নির্ধারণ করে শূন্যের উপরে সিসিআই একটি উত্থান বাজার নির্দেশ করে, যখন শূন্যের নিচে একটি হ্রাস বাজার
  3. রেট অফ চেঞ্জ সূচক পরিসরে সীমাবদ্ধ প্রবণতা ফিল্টার করে
    দাম সক্রিয় প্রবণতা আছে কিনা তা বিচার করার জন্য পরিবর্তন হার পরামিতি সেট করুন
  4. প্রবেশ ও প্রস্থান সংক্রান্ত নিয়ম লং এন্ট্রিঃ স্টোকাস্টিক গোল্ডেন ক্রস & CCI > 0 & সক্রিয় প্রবণতা সংক্ষিপ্ত এন্ট্রিঃ স্টোকাস্টিক ডেথ ক্রস & সিসিআই < 0 & সক্রিয় প্রবণতা স্টপ লস আউটঃ লং ও শর্ট উভয় পক্ষের জন্য 3% স্টপ লস

উপকারিতা বিশ্লেষণ

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

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

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

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

  1. সর্বোত্তম সমন্বয় খুঁজতে পরামিতি অপ্টিমাইজেশান
  2. কার্যকারিতা বাড়াতে আরো প্রবণতা নির্দেশক যুক্ত করুন
  3. স্টপ লস লঙ্ঘনের সম্ভাবনা হ্রাস করার জন্য ট্রেলিং স্টপ লস বা সময় ভিত্তিক স্টপ লস ব্যবহার করুন
  4. ঝুঁকি সম্পূর্ণ নিয়ন্ত্রণের জন্য সর্বোচ্চ ড্রডাউন মত ঝুঁকি পরিমাপ যোগ করুন

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

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


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

//@version=4
strategy("Stochastic CCI BF 🚀", overlay=false, initial_capital=10000, default_qty_type=strategy.percent_of_equity, default_qty_value=100, commission_type=strategy.commission.percent, commission_value=0.075)

/////////////// Time Frame ///////////////
testStartYear = input(2017, "Backtest Start Year") 
testStartMonth = input(1, "Backtest Start Month")
testStartDay = input(1, "Backtest Start Day")
testPeriodStart = timestamp(testStartYear,testStartMonth,testStartDay, 0, 0)

testStopYear = input(2019, "Backtest Stop Year")
testStopMonth = input(12, "Backtest Stop Month")
testStopDay = input(31, "Backtest Stop Day")
testPeriodStop = timestamp(testStopYear,testStopMonth,testStopDay, 0, 0)

testPeriod() => true

///////////// CCI ///////////// 
src = close
ccilength = input(13, minval=1, title="CCI Length")
c=cci(src, ccilength)

///////////// Stochastic ///////////// 
len = input(19, minval=1, title="RSI Length")
lenema = input(12, minval=1, title="RSI-EMA Length")
up = rma(max(change(src), 0), len)
down = rma(-min(change(src), 0), len)
rsi = down == 0 ? 100 : up == 0 ? 0 : 100 - (100 / (1 + up / down))
out = ema(rsi, lenema)

///////////// Rate Of Change ///////////// 
source = close
roclength = input(30, minval=1)
pcntChange = input(7.0, minval=1)
roc = 100 * (source - source[roclength]) / source[roclength]
emaroc = ema(roc, roclength / 2)
isMoving() => emaroc > (pcntChange / 2) or emaroc < (0 - (pcntChange / 2))

/////////////// Strategy ///////////////
long = out > out[1] and isMoving() and c > 0
short = out < out[1] and isMoving() and c < 0

last_long = 0.0
last_short = 0.0
last_long := long ? time : nz(last_long[1])
last_short := short ? time : nz(last_short[1])

long_signal = crossover(last_long, last_short)
short_signal = crossover(last_short, last_long)

last_open_long_signal = 0.0
last_open_short_signal = 0.0
last_open_long_signal := long_signal ? open : nz(last_open_long_signal[1])
last_open_short_signal := short_signal ? open : nz(last_open_short_signal[1])

last_long_signal = 0.0
last_short_signal = 0.0
last_long_signal := long_signal ? time : nz(last_long_signal[1])
last_short_signal := short_signal ? time : nz(last_short_signal[1])

in_long_signal = last_long_signal > last_short_signal
in_short_signal = last_short_signal > last_long_signal

last_high = 0.0
last_low = 0.0
last_high := not in_long_signal ? na : in_long_signal and (na(last_high[1]) or high > nz(last_high[1])) ? high : nz(last_high[1])
last_low := not in_short_signal ? na : in_short_signal and (na(last_low[1]) or low < nz(last_low[1])) ? low : nz(last_low[1])

sl_inp = input(3.0, title='Stop Loss %') / 100 

since_longEntry = barssince(last_open_long_signal != last_open_long_signal[1]) 
since_shortEntry = barssince(last_open_short_signal != last_open_short_signal[1]) 

slLong = in_long_signal ? strategy.position_avg_price * (1 - sl_inp) : na
slShort = strategy.position_avg_price * (1 + sl_inp)
long_sl = in_long_signal ? slLong : na
short_sl = in_short_signal ? slShort : na

/////////////// Execution ///////////////
if testPeriod()
    strategy.entry("L",  strategy.long, when=long_signal)
    strategy.entry("S", strategy.short, when=short_signal)
    strategy.exit("L Ex", "L", stop=long_sl, when=since_longEntry > 0)
    strategy.exit("S Ex", "S", stop=short_sl, when=since_shortEntry > 0)

/////////////// Plotting /////////////// 
bgcolor(long_signal ? color.lime : short_signal ? color.red : na, transp=30)
bgcolor(not isMoving() ? color.white : long ? color.lime : short ? color.red : na, transp=80)
plot(out, color = out > out[1] ? color.lime:color.red, linewidth = 2, title="Stoch")
plot(c, color = c > 0 ? color.lime:color.red, linewidth = 2, title="CCI")

আরো