এই কৌশলটি সুপারট্রেন্ড এবং স্টোকআরএসআই দুটি সূচক ব্যবহার করে, সম্ভাব্য ক্রয় এবং বিক্রয় সংকেত সনাক্ত করার জন্য বিভিন্ন সময়কালের দামের প্রবণতা এবং ওভারব্রেড ওভারসোলের বিশ্লেষণ করে। এই কৌশলটি মূল প্রবণতার দিক অনুসরণ করে ট্রেড করার জন্য তৈরি করা হয়েছে, মূল মূল্যের দিকটি মাঝারি এবং দীর্ঘ লাইনে ক্যাপচার করে।
এই কৌশলটি 1 ঘন্টা এবং 4 ঘন্টা দুটি সময়কালের সুপারট্রেন্ড সূচক ব্যবহার করে দামের প্রবণতার দিকটি নির্ধারণ করে। যখন দুটি সময়কালের সুপারট্রেন্ড একই দিকে থাকে, তখন আমরা একটি শক্তিশালী দামের প্রবণতা বিবেচনা করতে পারি।
এছাড়াও, কৌশলটি স্টোকআরএসআই সূচকটি ব্যবহার করে নির্ধারণ করে যে অতিরিক্ত ক্রয় ও বিক্রয় রয়েছে কিনা। স্টোকআরএসআই সূচকটি আরএসআই এবং স্টোক্যাস্টিক ওসিলিয়েটর উভয় সূচকের সুবিধাগুলিকে একত্রিত করে। স্টোকআরএসআই সূচক লাইনটি অতিক্রম করার সময়, দামটি সম্ভবত oversold হতে পারে; যখন স্টোকআরএসআই সূচক লাইনটি অতিক্রম করার সময়, দামটি সম্ভবত oversold হতে পারে।
ডাবল সুপারট্রেন্ড যখন দামের প্রবণতার দিকটি নিশ্চিত করে, তখন যদি স্টোকআরএসআইও ওভারব্লড ওভারসোল দেখায়, তবে এটি একটি ভাল ক্রয় বা বিক্রয়ের সময়। সংকেতটি আরও যাচাই করার জন্য, কৌশলটি একটি রিট্র্যাকশন পিরিয়ডও সেট করে। স্টোকআরএসআই ওভারব্লড ওভারসোল সংকেত প্রদর্শন করার পরে, একটি নির্দিষ্ট সংখ্যক কে-লাইনকে ফিরে যেতে হবে, যদি এই সময়ের মধ্যে দামের গতিপথ স্টোকআরএসআইয়ের সংকেত নিশ্চিত করে তবে এটি ক্রয় বা বিক্রয়কে ট্রিগার করে।
সামগ্রিকভাবে, এই কৌশলটি সুপারট্রেন্ডের দ্বৈত টাইমফ্রেম ব্যবহার করে বড় প্রবণতা নির্ধারণ করে এবং স্টোকআরএসআই স্থানীয় সমন্বয় নির্ধারণের পদ্ধতি ব্যবহার করে মাঝারি এবং দীর্ঘ লাইনে ট্রেডিংয়ের প্রবণতা অনুসরণ করে।
অপ্টিমাইজেশান পদ্ধতিঃ
ডাবল চ্যানেল রান্নাঘর স্কিম কৌশলটি সুপারট্রেন্ডের মূল প্রবণতা এবং স্টোকআরএসআইয়ের স্থানীয় সামঞ্জস্যের মূল্যায়ন করার একটি নির্ভরযোগ্য প্রবণতা অনুসরণকারী কৌশল অর্জন করে। এই কৌশলটি মাঝারি-দীর্ঘ-লাইন পরিচালনার উপর ভিত্তি করে কার্যকরভাবে খুব ঘন ঘন ব্যবসায়ের ফলে প্রাপ্তি ক্ষতি এড়াতে পারে। প্যারামিটার অপ্টিমাইজেশন এবং সমন্বয় সূচক যাচাইয়ের মতো উপায়ে এই কৌশলটি স্থিতিশীল ইতিবাচক আয় অর্জন করতে পারে। তবে বিনিয়োগকারীদের এখনও গুরুত্বপূর্ণ মৌলিক পরিবর্তনগুলি লক্ষ্য করা উচিত এবং যান্ত্রিকভাবে সূচক সংকেত অনুসরণ করা এড়ানো উচিত। সামগ্রিকভাবে, এই কৌশলটি ইতিবাচক বিনিয়োগকারীদের জন্য একটি কার্যকর প্রযুক্তিগত বিশ্লেষণ পদ্ধতি সরবরাহ করে।
/*backtest
start: 2023-09-09 00:00:00
end: 2023-10-09 00:00:00
period: 4h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
// This source code is subject to the terms of the Mozilla Public License 2.0 at https://mozilla.org/MPL/2.0/
// © Baby_whale_to_moon
//@version=5
strategy('Kitchen [ilovealgotrading]', overlay=true, format=format.price, initial_capital = 1000)
// BACKTEST DATE
Start_Time = input(defval=timestamp('01 January 2017 13:30 +0000'), title='Start_Time', group = " ################# BACKTEST DATE ################ " )
End_Time = input(defval=timestamp('30 April 2024 19:30 +0000'), title='End_Time', group = " ################# BACKTEST DATE ################ " )
// supertrend
atrPeriod = input(10, 'ATR Length', group = " ################# Supertrend ################ ")
factor = input(3, 'Factor', group = " ################# Supertrend ################ ")
time1 = input.string(title='Short Time Period', defval='07 1h', options=['01 1m','02 3m','03 5m', '04 15m', '05 30m', '06 45m', '07 1h', '08 2h', '09 3h', '10 4h', '11 1D', '12 1W' ], group = " ################# Supertrend ################ ",tooltip = "this timeframe is the value of our short-time supertrend indicator")
time2 = input.string(title='Long Time Period', defval='10 4h', options=[ '01 1m','02 3m','03 5m', '04 15m', '05 30m', '06 45m', '07 1h', '08 2h', '09 3h', '10 4h', '11 1D', '12 1W' ], group = " ################# Supertrend ################ ",tooltip = "this timeframe is the value of our long-time supertrend indicator")
res(Resolution) =>
if Resolution == '00 Current'
timeframe.period
else
if Resolution == '01 1m'
'1'
else
if Resolution == '02 3m'
'3'
else
if Resolution == '03 5m'
'5'
else
if Resolution == '04 15m'
'15'
else
if Resolution == '05 30m'
'30'
else
if Resolution == '06 45m'
'45'
else
if Resolution == '07 1h'
'60'
else
if Resolution == '08 2h'
'120'
else
if Resolution == '09 3h'
'180'
else
if Resolution == '10 4h'
'240'
else
if Resolution == '11 1D'
'1D'
else
if Resolution == '12 1W'
'1W'
else
if Resolution == '13 1M'
'1M'
// supertrend Long time period
[supertrend2, direction2] = request.security(syminfo.tickerid, res(time2), ta.supertrend(factor, atrPeriod))
bodyMiddle4 = plot((open + close) / 2, display=display.none)
upTrend2 = plot(direction2 < 0 ? supertrend2 : na, 'Up Trend', color=color.new(color.green, 0), style=plot.style_linebr, linewidth=2)
downTrend2 = plot(direction2 < 0 ? na : supertrend2, 'Down Trend', color=color.new(color.red, 0), style=plot.style_linebr, linewidth=2)
// supertrend short time period
[supertrend1, direction1] = request.security(syminfo.tickerid, res(time1), ta.supertrend(factor, atrPeriod))
bodyMiddle = plot((open + close) / 2, display=display.none)
upTrend = plot(direction1 < 0 ? supertrend1 : na, 'Up Trend', color=color.new(color.yellow, 0), style=plot.style_linebr)
downTrend = plot(direction1 < 0 ? na : supertrend1, 'Down Trend', color=color.new(color.orange, 0), style=plot.style_linebr)
// Stochastic RSI
low_limit_stoch_rsi = input.float(title = 'Stoch Rsi Low Limit', step=0.5, defval=15, group = " ################# Stoch RSI ################ ", tooltip = "when Stock rsi value crossover Low Limit value we get Long")
up_limit_stoch_rsi = input.float(title = 'Stoch Rsi Up Limit', step=0.5, defval=85, group = " ################# Stoch RSI ################ ", tooltip = "when Stock rsi value crossunder Up Limit value we get Short")
stocrsi_back_length = input.int(20, 'Stoch Rsi retroactive length', minval=1, group = " ################# Stoch RSI ################ ", tooltip = "How many candles are left behind, even if there is a buy or sell signal, it will be valid now")
smoothK = input.int(3, 'Stochastic RSI K', minval=1, group = " ################# Stoch RSI ################ ")
lengthRSI = input.int(14, 'RSI Length', minval=1, group = " ################# Stoch RSI ################ ")
lengthStoch = input.int(14, 'Stochastic Length', minval=1, group = " ################# Stoch RSI ################ ")
src_rsi = input(close, title='RSI Source', group = " ################# Stoch RSI ################ ")
rsi1 = request.security(syminfo.tickerid, '240', ta.rsi(src_rsi, lengthRSI))
k = request.security(syminfo.tickerid, '240', ta.sma(ta.stoch(rsi1, rsi1, rsi1, lengthStoch), smoothK))
// Strategy settings
dollar = input.float(title='Dollar Cost Per Position ', defval=20000, group = " ################# Strategy Settings ################ ")
trade_direction = input.string(title='Trade_direction', group = " ################# Strategy Settings ################ ", options=['LONG', 'SHORT', 'BOTH'], defval='BOTH')
Long_message_open = input('Long Open', title = "Long Open Message", group = " ################# Strategy Settings ################ ", tooltip = "if you write your alert window this code {{strategy.order.alert_message}} .When trigger Long signal you will get dynamically what you pasted here for Long Open Message ")
Short_message_open = input('Short Open', title = "Short Open Message", group = " ################# Strategy Settings ################ ", tooltip = "if you write your alert window this code {{strategy.order.alert_message}} .When trigger Long signal you will get dynamically what you pasted here for Short Open Message ")
Long_message_close = input('Long Close', title = "Long Close Message", group = " ################# Strategy Settings ################ ", tooltip = "if you write your alert window this code {{strategy.order.alert_message}} .When trigger Long signal you will get dynamically what you pasted here for Long Close Message ")
Short_message_close = input('Short Close', title = "Short Close Message", group = " ################# Strategy Settings ################ ", tooltip = "if you write your alert window this code {{strategy.order.alert_message}} .When trigger Long signal you will get dynamically what you pasted here for Short Close Message ")
Time_interval = true
bgcolor(Time_interval ? color.rgb(255, 235, 59, 95) : na)
back_long = 0
back_short = 0
for i = 1 to stocrsi_back_length by 1
if ta.crossover(k, low_limit_stoch_rsi)[i] == true
back_long += i
back_long
if ta.crossunder(k, up_limit_stoch_rsi)[i] == true
back_short += i
back_short
// bgcolor(back_long>0?color.rgb(153, 246, 164, 54):na)
// bgcolor(back_short>0?color.rgb(246, 153, 153, 54):na)
buy_signal = false
sell_signal = false
if direction2 < 0 and direction1 < 0 and back_long > 0
buy_signal := true
buy_signal
if direction2 > 0 and direction1 > 0 and back_short > 0
sell_signal := true
sell_signal
//bgcolor(buy_signal ? color.new(color.lime,90) : na ,title="BUY bgcolor")
plotshape( buy_signal[1] == false and strategy.opentrades == 0 and Time_interval and buy_signal ? supertrend2 : na, title="Buy", text="Buy", location=location.absolute, style=shape.labelup, size=size.tiny, color=color.green, textcolor=color.white)
//bgcolor(sell_signal ? color.new(color.red,90) : na ,title="SELL bgcolor")
plotshape(sell_signal[1] == false and strategy.opentrades == 0 and Time_interval and sell_signal ? supertrend2 : na , title="Sell", text="Sell", location=location.absolute, style=shape.labeldown, size=size.tiny, color=color.red, textcolor=color.white)
// Strategy entries
if strategy.opentrades == 0 and Time_interval and buy_signal and ( trade_direction == 'LONG' or trade_direction == 'BOTH')
strategy.entry('Long_Open', strategy.long, qty=dollar / close, alert_message=Long_message_open)
if strategy.opentrades == 0 and Time_interval and sell_signal and ( trade_direction == 'SHORT' or trade_direction == 'BOTH')
strategy.entry('Short_Open', strategy.short, qty=dollar / close, alert_message=Short_message_open)
// Strategy Close
if close < supertrend1 and strategy.position_size > 0
strategy.exit('Long_Close',from_entry = "Long_Open", stop=close, qty_percent=100, alert_message=Long_message_close)
if close > supertrend1 and strategy.position_size < 0
strategy.exit('Short_Close',from_entry = "Short_Open", stop=close, qty_percent=100, alert_message=Short_message_close)