এটি একটি গবেষণা সূচক যা ইউটিউব চ্যানেলে দেখা কৌশলটিতে প্রবেশগুলি দেখায় তাই এটি আমার অন্তর্গত নয়। আমি বলতে পারি না যে এটি কার কারণ এটি বিজ্ঞাপন দেওয়ার জন্য হাউস বিধিগুলির বিরুদ্ধে তবে আপনি এটি ইউটিউবে সন্ধান করলে এটি খুঁজে পেতে পারেন। ওসিলেটর এবং ইমার ডিফল্ট মানগুলি প্রস্তাবিত হিসাবে সামঞ্জস্য করা হয়েছে। তিনি বলেছেন যে তিনি 5 মিনিটের সময়সীমার মধ্যে সেরা ফলাফল পেয়েছেন তবে আমি জিনিসগুলিকে যতটা সম্ভব পরিবর্তনযোগ্য করার চেষ্টা করেছি যাতে আপনি পছন্দ করেন সেটিংসের সাথে গোলমাল করতে পারেন এবং বিভিন্ন সময়সীমার জন্য আপনার নিজস্ব কৌশল তৈরি করতে পারেন। সাধারণ মোমবাতি চার্টগুলির সাথে ব্যবহার করার পরামর্শ দেওয়া হয়েছে। নীচের নীল রেখাটি নির্দেশ করে যে এডিএক্স
এন্ট্রি কৌশল নিজেই বেশ সহজ সরল। প্রবেশের নিয়ম নিম্নরূপ, স্ক্রিপ্ট স্বয়ংক্রিয়ভাবে এই সব চেক করবে এবং আপনি কিনতে বা বিক্রয় সংকেত দিতে হবেঃ প্রস্তাবিত সময়সীমাঃ ৫ মিনিট
দীর্ঘ প্রবেশের জন্যঃ
সংক্ষিপ্ত প্রবেশের জন্যঃ
এটি আমার প্রথম সূচক। যদি আপনি কোন আপডেট চান তাহলে আমাকে জানান। আমি নিশ্চিত নই যে আমি সবকিছু যোগ করতে পারব কিনা কিন্তু আমি তবুও চেষ্টা করব।
পরিবর্তিতঃ সংকেতগুলি 2 মোমবাতি পর্যন্ত পরীক্ষা করবে যদি RSI সংকেত দেখানোর জন্য সেট মানের নীচে বা উপরে থাকে। এটি কারণ কখনও কখনও প্রবেশ সংকেতটি সঠিক তবে প্রতিক্রিয়াটি কিছুটা দেরি হতে পারে।
ব্যাকটেস্ট
/*backtest start: 2022-04-25 00:00:00 end: 2022-05-24 23:59:00 period: 5m basePeriod: 1m exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}] */ //@version=5 indicator(title='EMA RSI ADX Scalping Alerts', shorttitle="ERA Scalper", overlay=true) //Define MA Inputs and group them maType = input.string(title="MA Type", options=["EMA", "SMA", "WMA", "VWMA", "HMA", "RMA", "DEMA", "TEMA", "LSMA", "ZLSMA"], defval="EMA", group='MA Settings') emaSource = input.source(title='MA Source', defval=close, group='MA Settings') emaLength = input.int(title='MA Length', defval=50, minval=1, maxval=999, group='MA Settings') //Other Moving Avarage Calculations e1 = ta.ema(emaSource, emaLength) e2 = ta.ema(e1, emaLength) dema = 2 * e1 - e2 ema1 = ta.ema(emaSource, emaLength) ema2 = ta.ema(ema1, emaLength) ema3 = ta.ema(ema2, emaLength) tema = 3 * (ema1 - ema2) + ema3 lsmaOffset = input.int(title="LSMA Offset", defval=0, minval=0, maxval=100, tooltip='Only used if you choose the LSMA and ZLSMA(Zero Lag LSMA) Option between MA Types', group='MA Settings') lsma = ta.linreg(emaSource, emaLength, lsmaOffset) lsma2 = ta.linreg(lsma, emaLength, lsmaOffset) eq = lsma-lsma2 zlsma = lsma+eq // Switch between different MA Types emaValue = switch maType "EMA" => ta.ema(emaSource, emaLength) "SMA" => ta.sma(emaSource, emaLength) "WMA" => ta.wma(emaSource, emaLength) "VWMA" => ta.vwma(emaSource, emaLength) "HMA" => ta.hma(emaSource, emaLength) "RMA" => ta.rma(emaSource, emaLength) "DEMA" => dema "TEMA" => tema "LSMA" => lsma "ZLSMA" => zlsma => runtime.error("No matching MA type found.") float(na) //Define RSI inputs and group them rsiSource = input.source(title='RSI Source', defval=close, group='RSI Settings') rsiLength = input.int(title='RSI Length', defval=3, minval=0, maxval=100, group='RSI Settings') rsiValuee = ta.rsi(rsiSource, rsiLength) rsiOverbought = input.int(title='RSI Overbought Level', defval=80, group='RSI Settings') rsiOversold = input.int(title='RSI Oversold Level', defval=20, group='RSI Settings') //Define overbought and oversold conditions isRsiOB = rsiValuee >= rsiOverbought isRsiOS = rsiValuee <= rsiOversold //ADX Inputs and calculation of the value adxlen = input.int(5, title='ADX Smoothing', group='ADX Settings') dilen = input.int(5, title='DI Length', group='ADX Settings') dirmov(len) => up = ta.change(high) down = -ta.change(low) plusDM = na(up) ? na : up > down and up > 0 ? up : 0 minusDM = na(down) ? na : down > up and down > 0 ? down : 0 truerange = ta.rma(ta.tr, len) plus = fixnan(100 * ta.rma(plusDM, len) / truerange) minus = fixnan(100 * ta.rma(minusDM, len) / truerange) [plus, minus] adx(dilen, adxlen) => [plus, minus] = dirmov(dilen) sum = plus + minus adx = 100 * ta.rma(math.abs(plus - minus) / (sum == 0 ? 1 : sum), adxlen) adx sig = adx(dilen, adxlen) //Define the input and value where it is considered that there is a trend going on adxLimit = input.int(title='Trend Ready Limit', defval=30, minval=0, maxval=100, group='ADX Settings') trendReady = sig > adxLimit //Draw trend ready at the bottom of the chart for better viewing so that you can change the value based on what you see easier plotADX = input(title='Draw Trend Ready On Chart', defval=false) readyFold = plotADX and sig > adxLimit plotchar(series=readyFold, title='Trend Ready', location=location.bottom, color=color.new(color.blue, 0), size=size.small, char='_') //Plot the EMA on chart enableEmaRule = input(title='Enable MA Rule', defval=true) //Define the signal conditions and choice to add or leave out MA Rule if you wish so alertLong = enableEmaRule ? low > emaValue and (rsiValuee <= rsiOversold or rsiValuee[1] <= rsiOversold or rsiValuee[2] <= rsiOversold) and sig > adxLimit and close > high[1] : (rsiValuee <= rsiOversold or rsiValuee[1] <= rsiOversold or rsiValuee[2] <= rsiOversold) and sig > adxLimit and close > high[1] alertShort = enableEmaRule ? high < emaValue and (rsiValuee >= rsiOverbought or rsiValuee[1] >= rsiOverbought or rsiValuee[2] >= rsiOverbought) and sig > adxLimit and close < low[1] : (rsiValuee >= rsiOverbought or rsiValuee[1] >= rsiOverbought or rsiValuee[2] >= rsiOverbought) and sig > adxLimit and close < low[1] plot(enableEmaRule ? emaValue : na, color=color.new(color.red, 0), title='MA') //Buy and Sell Shapes on Chart plotshape(alertLong, title='Buy', location=location.belowbar, color=color.new(color.green, 0), size=size.small, style=shape.triangleup, text='Buy') plotshape(alertShort, title='Sell', location=location.abovebar, color=color.new(color.red, 0), size=size.small, style=shape.triangledown, text='Sell') //Alerts alertcondition(title='Buy Alert', condition=alertLong, message='Long Conditions are Met') alertcondition(title='Sell Alert', condition=alertShort, message='Short Conditions are Met') alertcondition(title='Buy / Sell Alert', condition=alertLong or alertShort, message='Conditions Met for Buy or Short') if alertLong strategy.entry("Enter Long", strategy.long) else if alertShort strategy.entry("Enter Short", strategy.short)