यह रणनीति मुख्य रूप से बाजार के रुझानों और अस्थिरता को पकड़ने के लिए चलती औसत और बोलिंगर बैंड का उपयोग करती है। यह तीन अलग-अलग प्रकार के चलती औसत का उपयोग करती हैः सरल चलती औसत (एसएमए), भारित चलती औसत (डब्ल्यूएमए), और घातीय चलती औसत (ईएमए) । साथ ही, यह मूल्य चैनलों को निर्धारित करने के लिए बोलिंगर बैंड का उपयोग करता है, जिसमें ऊपरी और निचले बैंड उद्घाटन और समापन पदों के लिए संकेत के रूप में कार्य करते हैं। जब कीमत ऊपरी बोलिंगर बैंड के माध्यम से टूटती है, तो यह एक छोटी स्थिति खोलती है; जब यह निचले बैंड के माध्यम से टूटती है, तो यह एक लंबी स्थिति खोलती है। यह व्यापक बोलिंगर बैंड को स्टॉप-लॉस स्तर के रूप में भी निर्धारित करती है, जब कीमत इन बैंडों का उल्लंघन करती है, तो बंद हो जाती है। कुल मिलाकर, यह रणनीति तेजी से रुझानों को स्थापित करने का प्रयास करती है और जब नुकसान बढ़ता है तो जोखिमों को निर्णायक रूप से कम करती है, जिसका उद्देश्य स्थिर रि
मरीना पार्फेनोवा स्कूल प्रोजेक्ट बॉट एक मात्रात्मक ट्रेडिंग रणनीति है जो चलती औसत और बोलिंगर बैंड पर आधारित है। यह बोलिंगर बैंड स्टॉप-लॉस लाइनों के माध्यम से ड्रॉडाउन को नियंत्रित करते हुए बाजार के रुझानों को कैप्चर करके लाभ कमाने का प्रयास करता है। रणनीति तर्क सरल और सीधा है, जिसमें अनुप्रयोगों की एक विस्तृत श्रृंखला है, और मापदंडों को बाजार की विशेषताओं के अनुसार लचीले ढंग से समायोजित किया जा सकता है। हालांकि, व्यावहारिक अनुप्रयोग में, अभी भी साइडवेज बाजारों, चरम परिस्थितियों, मापदंड अनुकूलन आदि जैसे मुद्दों पर ध्यान देने की आवश्यकता है, और पूंजी और स्थिति प्रबंधन नियमों के आगे परिष्करण की आवश्यकता है। कुल मिलाकर, यह रणनीति एक बुनियादी मात्रात्मक ट्रेडिंग ढांचे के रूप में कार्य कर सकती है, जिसे लगातार अनुकूलित और अधिक मजबूत ट्रेडिंग परिणाम प्राप्त करने के लिए बेहतर बनाया जा सकता है।
/*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")