
এই কৌশলটি সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল সরল
এই কৌশলটি প্রথমে EMA, SMA, RMA, WMA এবং VWMA সহ চলমান গড়ের প্রকারের উপর ভিত্তি করে সেট করা হয়। তারপরে চলমান গড় গণনার জন্য একটি সময়কাল সেট করা হয়, সাধারণত 10 থেকে 250 কে লাইন। বিভিন্ন মুদ্রা জোড়া অনুযায়ী, বিভিন্ন চলমান গড়ের প্রকার এবং সময়কালের সংখ্যা নির্বাচন করা সম্পূর্ণ ভিন্ন প্রভাব অর্জন করতে পারে।
এই কৌশলটি নিম্নরূপঃ
পজিশন গঠনের সময় মূল্যবৃদ্ধি এবং পজিশন খোলার সময় মূল্য হ্রাসের ইঙ্গিত হিসাবে বিবেচনা করা হয়।
এই কৌশলটির প্রধান সুবিধাগুলো হলঃ
এই কৌশলটির কিছু ঝুঁকিও রয়েছেঃ
প্রতিরোধ ও অপ্টিমাইজেশনের দিকঃ
এই কৌশলটি সামগ্রিকভাবে যৌক্তিকভাবে সহজ, দামের প্রবণতা এবং বিপরীত বিন্দুগুলি নির্ধারণের জন্য একটি চলমান গড় সূচক ব্যবহার করে। এটি প্যারামিটারগুলি সামঞ্জস্য করে খুব ভাল প্রভাব ফেলতে পারে, এটি একটি কার্যকর প্রবণতা ট্র্যাকিং কৌশল যা আরও উন্নত এবং প্রয়োগের জন্য উপযুক্ত। তবে ঝুঁকি নিয়ন্ত্রণে মনোযোগ দেওয়া উচিত, উপযুক্ত মুদ্রা জোড়া এবং প্যারামিটার নির্বাচন করুন যাতে এটি সর্বাধিক কার্যকর হয়।
/*backtest
start: 2023-12-01 00:00:00
end: 2023-12-31 23:59:59
period: 2h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
//Author @divonn1994
initial_balance = 100
strategy(title='Close v Open Moving Averages Strategy', shorttitle = 'Close v Open', overlay=true, pyramiding=0, default_qty_value=100, default_qty_type=strategy.percent_of_equity, precision=7, currency=currency.USD, commission_value=0.1, commission_type=strategy.commission.percent, initial_capital=initial_balance)
//Input for number of bars for moving average, Switch to choose moving average type, Display Options and Time Frame of trading----------------------------------------------------------------
bars = input.int(66, "Moving average length (number of bars)", minval=1, group='Strategy') //66 bars and VWMA for BTCUSD on 12 Hours.. 35 bars and VWMA for BTCUSD on 1 Day
strategy = input.string("VWMA", "Moving Average type", options = ["EMA", "SMA", "RMA", "WMA", "VWMA"], group='Strategy')
redOn = input.string("On", "Red Background Color On/Off", options = ["On", "Off"], group='Display')
greenOn = input.string("On", "Green Background Color On/Off", options = ["On", "Off"], group='Display')
maOn = input.string("On", "Moving Average Plot On/Off", options = ["On", "Off"], group='Display')
startMonth = input.int(title='Start Month 1-12 (set any start time to 0 for furthest date)', defval=1, minval=0, maxval=12, group='Beginning of Strategy')
startDate = input.int(title='Start Date 1-31 (set any start time to 0 for furthest date)', defval=1, minval=0, maxval=31, group='Beginning of Strategy')
startYear = input.int(title='Start Year 2000-2100 (set any start time to 0 for furthest date)', defval=2011, minval=2000, maxval=2100, group='Beginning of Strategy')
endMonth = input.int(title='End Month 1-12 (set any end time to 0 for today\'s date)', defval=0, minval=0, maxval=12, group='End of Strategy')
endDate = input.int(title='End Date 1-31 (set any end time to 0 for today\'s date)', defval=0, minval=0, maxval=31, group='End of Strategy')
endYear = input.int(title='End Year 2000-2100 (set any end time to 0 for today\'s date)', defval=0, minval=0, maxval=2100, group='End of Strategy')
//Strategy Calculations-----------------------------------------------------------------------------------------------------------------------------------------------------------------------
inDateRange = true
maMomentum = switch strategy
"EMA" => (ta.ema(close, bars) > ta.ema(open, bars)) ? 1 : -1
"SMA" => (ta.sma(close, bars) > ta.sma(open, bars)) ? 1 : -1
"RMA" => (ta.rma(close, bars) > ta.rma(open, bars)) ? 1 : -1
"WMA" => (ta.wma(close, bars) > ta.wma(open, bars)) ? 1 : -1
"VWMA" => (ta.vwma(close, bars) > ta.vwma(open, bars)) ? 1 : -1
=>
runtime.error("No matching MA type found.")
float(na)
openMA = switch strategy
"EMA" => ta.ema(open, bars)
"SMA" => ta.sma(open, bars)
"RMA" => ta.rma(open, bars)
"WMA" => ta.wma(open, bars)
"VWMA" => ta.vwma(open, bars)
=>
runtime.error("No matching MA type found.")
float(na)
closeMA = switch strategy
"EMA" => ta.ema(close, bars)
"SMA" => ta.sma(close, bars)
"RMA" => ta.rma(close, bars)
"WMA" => ta.wma(close, bars)
"VWMA" => ta.vwma(close, bars)
=>
runtime.error("No matching MA type found.")
float(na)
//Enter or Exit Positions--------------------------------------------------------------------------------------------------------------------------------------------------------------------
if ta.crossover(maMomentum, 0)
if inDateRange
strategy.entry('long', strategy.long, comment='long')
if ta.crossunder(maMomentum, 0)
if inDateRange
strategy.close('long')
//Plot Strategy Behavior---------------------------------------------------------------------------------------------------------------------------------------------------------------------
plot(series = maOn == "On" ? openMA : na, title = "Open moving Average", color = color.new(color.purple,0), linewidth=3, offset=1)
plot(series = maOn == "On" ? closeMA : na, title = "Close Moving Average", color = color.new(color.white,0), linewidth=2, offset=1)
bgcolor(color = inDateRange and (greenOn == "On") and maMomentum > 0 ? color.new(color.green,75) : inDateRange and (redOn == "On") and maMomentum <= 0 ? color.new(color.red,75) : na, offset=1)