এই কৌশলটি মূলত দুটি সূচক - স্টোকাস্টিক মম্পটম ইনডেক্স (এসএমআই) এবং আপেক্ষিক শক্তি সূচক (আরএসআই) এর উপর ভিত্তি করে। এটি অক্জিলিয়ারী বিচার শর্ত হিসাবে রঙ ফিল্টার এবং মোমবাতি শরীরের ফিল্টারও অন্তর্ভুক্ত করে। এই কৌশলটি ফিল্টার শর্তগুলির সাথে সংযুক্ত এসএমআই এবং আরএসআই থেকে কেনা এবং বিক্রয় সংকেতের উপর ভিত্তি করে ট্রেডিং সংকেত তৈরি করে। এই কৌশলটি কার্যকরভাবে বাজারে স্বল্পমেয়াদী ট্রেডিং সুযোগগুলি আবিষ্কার করতে পারে।
এই কৌশলটি বিচারের জন্য এসএমআই এবং আরএসআই সূচকগুলির উপর নির্ভর করে। এসএমআই মূলত স্টকটি ওভারবয়ড বা ওভারসেলড কিনা তা বিচার করে, যখন আরএসআই স্টকটির আপেক্ষিক শক্তি নির্ধারণ করে। যখন উভয় সূচক একই সময়ে কেনার সংকেত দেয়, তখন একটি কেনার ক্রিয়া শুরু হবে। নির্দিষ্ট যুক্তিটি নিম্নরূপঃ
এছাড়াও, এই কৌশলটির একটি দ্বৈত সংকেত মোড রয়েছে। এই মোডে কোনও বাণিজ্য শুরু করতে এসএমআই এবং আরএসআই উভয় সংকেত প্রয়োজন। এটি কার্যকরভাবে মিথ্যা সংকেতগুলি হ্রাস করতে পারে।
এছাড়াও, রঙ ফিল্টার এবং মোমবাতি শরীর ফিল্টার অন্তর্ভুক্ত করা হয়। এই ফিল্টারগুলির জন্য তুলনামূলকভাবে বড় মোমবাতি শরীরের প্রয়োজন এবং শেষ মোমবাতি খোলা তুলনায় উচ্চতর বন্ধ। এটি আরও মিথ্যা ব্রেকআউট ট্রেডিং এড়াতে পারে।
এই কৌশলটি এসএমআই এবং আরএসআই উভয় সূচক থেকে সংকেত একীভূত করে এবং দ্বৈত নিশ্চিতকরণের মাধ্যমে ট্রেডিং অর্ডার উত্পন্ন করে। মিথ্যা ব্রেকআউটগুলি ফিল্টার করতে রঙ ফিল্টার এবং মোমবাতি শরীরের ফিল্টারও বাস্তবায়িত হয়। কৌশলটির সহজ এবং পরিষ্কার লজিকাল প্রবাহ রয়েছে এবং বেশিরভাগ পরামিতি কাস্টমাইজযোগ্য। পরামিতিগুলি যথাযথভাবে টিউন করে আরও ভাল রিটার্ন অর্জন করা যায়।
/*backtest start: 2023-12-04 00:00:00 end: 2023-12-06 19:00:00 period: 5m basePeriod: 1m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //Noro //2018 //@version=2 strategy(title = "Noro's Stochastic Strategy v1.3", shorttitle = "Stochastic str 1.3", overlay = false, default_qty_type = strategy.percent_of_equity, default_qty_value = 100, pyramiding = 0) //Settings needlong = input(true, defval = true, title = "Long") needshort = input(true, defval = true, title = "Short") usemar = input(false, defval = false, title = "Use Martingale") capital = input(100, defval = 100, minval = 1, maxval = 10000, title = "Capital, %") usesmi = input(true, defval = true, title = "Use SMI Strategy") usersi = input(true, defval = true, title = "Use RSI Strategy") usecol = input(true, defval = true, title = "Use Color-Filter") usebod = input(true, defval = true, title = "Use Body-Filter") a = input(2, defval = 2, minval = 2, maxval = 50, title = "SMI Percent K Length") b = input(2, defval = 2, minval = 2, maxval = 50, title = "SMI Percent D Length") limitsmi = input(50, defval = 50, minval = 1, maxval = 100, title = "SMI Limit") periodrsi = input(2, defval = 2, minval = 2, maxval = 50, title = "RSI Period") limitrsi = input(10, defval = 10, minval = 1, maxval = 50, title = "RSI Limit") double = input(false, defval = false, title = "SMI+RSI Mode") showbg = input(false, defval = false, title = "Show background") fromyear = input(2018, defval = 2018, minval = 1900, maxval = 2100, title = "From Year") toyear = input(2100, defval = 2100, minval = 1900, maxval = 2100, title = "To Year") frommonth = input(01, defval = 01, minval = 01, maxval = 12, title = "From Month") tomonth = input(12, defval = 12, minval = 01, maxval = 12, title = "To Month") fromday = input(01, defval = 01, minval = 01, maxval = 31, title = "From day") today = input(31, defval = 31, minval = 01, maxval = 31, title = "To day") //Fast RSI fastup = rma(max(change(close), 0), periodrsi) fastdown = rma(-min(change(close), 0), periodrsi) fastrsi = fastdown == 0 ? 100 : fastup == 0 ? 0 : 100 - (100 / (1 + fastup / fastdown)) //Stochastic Momentum Index ll = lowest (low, a) hh = highest (high, a) diff = hh - ll rdiff = close - (hh+ll)/2 //avgrel = ema(ema(rdiff,b),b) //avgdiff = ema(ema(diff,b),b) avgrel = sma(sma(rdiff,b),b) avgdiff = sma(sma(diff,b),b) SMI = avgdiff != 0 ? (avgrel/(avgdiff/2)*100) : 0 SMIsignal = ema(SMI,b) //Lines plot(SMI, color = blue, linewidth = 3, title = "Stochastic Momentum Index") plot(SMIsignal, color = red, linewidth = 3, title = "SMI Signal Line") plot(limitsmi, color = black, title = "Over Bought") plot(-1 * limitsmi, color = black, title = "Over Sold") plot(0, color = blue, title = "Zero Line") //Color-Filter gb = close > open or usecol == false rb = close < open or usecol == false //Body Filter nbody = abs(close - open) abody = sma(nbody, 10) body = nbody > abody / 3 or usebod == false //Signals up1 = SMI < -1 * limitsmi and rb and body and usesmi dn1 = SMI > limitsmi and gb and body and usesmi up2 = fastrsi < limitrsi and rb and body and usersi dn2 = fastrsi > 100 - limitrsi and gb and body and usersi exit = ((strategy.position_size > 0 and close > open) or (strategy.position_size < 0 and close < open)) and body //Background redb = (SMI > limitsmi and usesmi) or (fastrsi > 100 - limitrsi and usersi) limeb = (SMI < -1 * limitsmi and usesmi) or (fastrsi < limitrsi and usersi) col = showbg == false ? na : redb ? red : limeb ? lime : na bgcolor(col, transp = 50) //Trading profit = exit ? ((strategy.position_size > 0 and close > strategy.position_avg_price) or (strategy.position_size < 0 and close < strategy.position_avg_price)) ? 1 : -1 : profit[1] mult = usemar ? exit ? profit == -1 ? mult[1] * 2 : 1 : mult[1] : 1 lot = strategy.position_size == 0 ? strategy.equity / close * capital / 100 * mult : lot[1] signalup = ((up1 or up2) and double == false) or (up1 and up2 and double) if signalup if strategy.position_size < 0 strategy.close_all() strategy.entry("long", strategy.long, needlong == false ? 0 : lot, when=(time > timestamp(fromyear, frommonth, fromday, 00, 00) and time < timestamp(toyear, tomonth, today, 23, 59))) signaldn = ((dn1 or dn2) and double == false) or (dn1 and dn2 and double) if signaldn if strategy.position_size > 0 strategy.close_all() strategy.entry("Short", strategy.short, needshort == false ? 0 : lot, when=(time > timestamp(fromyear, frommonth, fromday, 00, 00) and time < timestamp(toyear, tomonth, today, 23, 59))) if time > timestamp(toyear, tomonth, today, 23, 59) or exit strategy.close_all()