
এই কৌশলটি মূলত বাজারের প্রবণতা এবং ওঠানামা ক্যাপচার করার জন্য স্লাইডিং এভারেজ এবং বুলিন ব্যবহার করে। এই কৌশলটি তিনটি পৃথক মুভিং এভারেজ ব্যবহার করেঃ সরল মুভিং এভারেজ (এসএমএ), ভারযুক্ত মুভিং এভারেজ (ডাব্লুএমএ) এবং সূচকীয় মুভিং এভারেজ (ইএমএ) । একই সাথে, বুলিন ব্যবহার করে দামের চ্যানেল সেট করা হয়, যথাক্রমে ওপেন পজিশনের শান্তির সংকেত হিসাবে।
Marina Parfenova School Project Robot হল একটি ক্যাটাগরি ট্রেডিং কৌশল যা চলমান গড় এবং বুলিন বন্ডের উপর ভিত্তি করে। এটি বাজারের প্রবণতা ধরে লাভ অর্জনের চেষ্টা করে এবং বুলিন বন্ডের স্টপ লস লাইন নিয়ন্ত্রণ করে প্রত্যাহার করে। কৌশলগত লজিকটি সহজ এবং পরিষ্কার, প্রয়োগের ক্ষেত্রটি বিস্তৃত, প্যারামিটারগুলি বাজারের বৈশিষ্ট্য অনুসারে নমনীয়ভাবে সামঞ্জস্য করা যেতে পারে। তবে বাস্তব প্রয়োগের ক্ষেত্রে এখনও উদ্বেগজনক বাজার, চরম পরিস্থিতি, প্যারামিটার অপ্টিমাইজেশন ইত্যাদির বিষয়ে মনোযোগ দেওয়া প্রয়োজন এবং তহবিল পরিচালনা এবং পজিশন পরিচালনার নিয়মগুলি আরও বিশদ করা দরকার। সামগ্রিকভাবে, কৌশলটি একটি মৌলিক ক্যাটাগরি ট্রেডিং ফ্রেমওয়ার্কের মতো কাজ করতে পারে, যার ভিত্তিতে ক্রমাগত অপ্টিমাইজেশন এবং পরিবর্তন করা যেতে পারে, যাতে আরও স্থিতিশীল এবং উন্নত ট্রেডিং কার্যকারিতা অর্জন করা যায়।
/*backtest
start: 2024-03-01 00:00:00
end: 2024-03-31 23:59:59
period: 1h
basePeriod: 15m
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=5
strategy ("Marina Parfenova School Project Bot", overlay = true)
sma(price, n) =>
result = 0.0
for i = 0 to n - 1
result := result + price [i] / n
result
wma(price, n) =>
result = 0.0
sum_weight = 0.0
weight = 0.0
for i = 0 to n - 1
weight := n - 1
result := result + price [i]*weight
sum_weight := sum_weight + weight
result/sum_weight
ema(price, n) =>
result = 0.0
alpha = 2/(n + 1)
prevResult = price
if (na(result[1]) == false)
prevResult := result[1]
result := alpha * price + (1 - alpha) * prevResult
/// Настройки
n_slow = input.int(50, "Период медленной скользящей средней", step=5)
n_fast = input.int(4, "Период быстрой скользящей средней")
n_deviation = input.int(30, "Период среднеквадратического отклонения", step=5)
k_deviation_open = input.float(1.2, "Коэффициент ширины коридора покупки", step=0.1)
k_deviation_close = input.float(1.6, "Коэффициент ширины коридора продажи", step=0.1)
// ----- Линии индикаторов -----
// Медленная скользящая
sma = sma(close, n_slow)
plot(sma, color=#d3d3d3)
// Линии Боллинджера, обозначающие коридор цены
bollinger_open = k_deviation_open * ta.stdev(close, n_deviation)
open_short_line = sma + bollinger_open
plot(open_short_line, color=#ec8383)
open_long_line = sma - bollinger_open
plot(open_long_line, color=#6dd86d)
bollinger_close = k_deviation_close * ta.stdev(close, n_deviation)
close_short_line = sma + bollinger_close
plot(close_short_line, color=#e3e3e3)
close_long_line = sma - bollinger_close
plot(close_long_line, color=#e3e3e3)
// Быстрая скользящая
ema = ema(close, n_fast)
plot(ema, color = color.aqua, linewidth = 2)
// ----- Сигналы для запуска стратегии -----
// если ema пересекает линию open_short сверху вниз - сигнал на создание ордера в short
if(ema[1] >= open_short_line[1] and ema < open_short_line)
strategy.entry("short", strategy.short)
// если ema пересекает линию open_long снизу вверх - сигнал на создание ордера в long
if(ema[1] <= open_long_line[1] and ema > open_long_line)
strategy.entry("long", strategy.long)
// если свеча пересекает верхнюю линию коридора продажи - закрываем все long-ордера
if (high >= close_short_line)
strategy.close("long")
// если свеча пересекает нижнюю линию коридора продажи - закрываем все short-ордера
if (low <= close_long_line)
strategy.close("short")