
इस रणनीति के आधार पर व्यापार के संकेतों का न्याय करने के लिए कीमतों और उच्च कीमतों के क्रॉसिंग. जब कीमतों में उच्च कीमतों में उच्च कीमतों में उच्च कीमतों में अधिक और जब कीमतों में उच्च कीमतों में उच्च कीमतों में कम। कीमतों के डेटा को चिकना करने के लिए और व्यापार के शोर को कम करने के लिए चलती औसत का उपयोग करें। चलती औसत प्रकार और पैरामीटर को कॉन्फ़िगर किया जा सकता है। यह भी कॉन्फ़िगर किया जा सकता है कि क्या लॉकिंग लाभ के लिए स्टॉप लॉस को सक्षम किया जाए।
इनपुट पैरामीटर के आधार पर यह तय करें कि क्या वैकल्पिक चक्र परिशुद्धता का उपयोग किया जाना चाहिए (useRes) यदि उपयोग किया जाता है, तो स्ट्रैटरेस के आधार पर चक्र सेट करें
इनपुट पैरामीटर के आधार पर यह तय करें कि क्या चलती औसत का उपयोग किया जाना चाहिए (useMA) । यदि उपयोग किया जाता है, तो आधार प्रकार के अनुसार चलती औसत प्रकार का चयन करें, आधार लेंस अवधि की लंबाई निर्धारित करता है ।
खुलने की कीमतों और बंद होने की कीमतों की श्रृंखला प्राप्त करें। यदि चलती औसत का उपयोग किया जाता है, तो चयनित चलती औसत प्रकार और पैरामीटर को चिकना करें।
ओपन सीरीज़ की वर्तमान कीमतों की तुलना करें। यदि एक्स ओपन सीरीज़ से अधिक है, तो ट्रेंड स्टेट बहु-हेड है, अन्यथा यह खाली है।
जब कीमतें खुली और खुली, तो चलती औसत के माध्यम से कई सिग्नल उत्पन्न होते हैं, और जब कीमतें खुली और खुली होती हैं, तो कम संकेत उत्पन्न होते हैं।
मल्टी हेड या खाली हेड स्थिति में प्रवेश करें। यदि स्टॉप लॉस ट्रैकिंग सक्षम है, तो स्टॉप लॉस पॉइंट और पलायन दूरी सेट करें।
दो अलग-अलग श्रृंखलाओं का उपयोग करके ट्रेडिंग सिग्नल का आकलन करें, एक एकल डेटा श्रृंखला की सीमाओं से बचें।
चलती औसत तकनीक का उपयोग करके, प्रमुख रुझानों को लॉक करने के लिए अल्पकालिक बाजार के शोर को फ़िल्टर किया जा सकता है।
चलती औसत के प्रकार को अनुकूलित करें और पैरामीटर को अनुकूलित करें।
जोखिम को नियंत्रित करने और मुनाफे को लॉक करने के लिए ट्रैकिंग स्टॉप का उपयोग करने का विकल्प।
रणनीति अनुकूलन के लिए बहुत जगह है, विभिन्न किस्मों और बाजार की परिस्थितियों के लिए पैरामीटर को समायोजित किया जा सकता है।
सिंगल ट्रेडिंग सिग्नल स्रोत, सिग्नल दुर्लभ, पर्ची खोना आसान।
चलती औसत के साथ समस्याएं हैं, जो अल्पकालिक अवसरों को याद कर सकती हैं।
अनुचित ट्रैक स्टॉप सेटिंग्स जो बहुत जल्दी या बहुत अधिक स्टॉप को रोक सकती हैं
गलत पैरामीटर सेटिंग के कारण वर्चुअल लेनदेन बहुत बार हो सकता है और वास्तविक डिस्क को प्रभावित कर सकता है।
विभिन्न किस्मों और बाजार की परिस्थितियों में पैरामीटर को समायोजित करने की आवश्यकता होती है, अनुकूलन में अधिक कठिनाई होती है।
सिग्नल स्रोतों को समृद्ध करने के लिए अन्य मापदंडों को जोड़कर या मशीन लर्निंग मॉडल को पेश करके। चलती औसत प्रकार और पैरामीटर को अनुकूलित करें ताकि इष्टतम स्मूद प्रभाव हो। सावधानीपूर्वक स्टॉप-लॉस सेट करें और अधिक लाभ प्राप्त करने के लिए उचित रूप से ढीला करें। पैरामीटर की विश्वसनीयता सुनिश्चित करने के लिए पर्याप्त फीडबैक और अनुकूलन करें।
अन्य तकनीकी संकेतक जैसे कि ब्रिन बैंड, केडी आदि को जोड़ना, जो व्यापारिक संकेतों को समृद्ध करता है।
सिग्नल निर्णय के लिए मशीन लर्निंग मॉडल को लागू करना।
चलती औसत को अनुकूलित करें और सबसे अच्छा संयोजन खोजें।
स्टॉप लॉस पैरामीटर को ट्रैक करने के लिए अनुकूलित करें, स्टॉप लॉस आयाम और मुनाफे को संतुलित करें।
पैरामीटर ऑप्टिमाइज़ेशन फ़ंक्शन जोड़ा गया है, जो स्वचालित रूप से इष्टतम पैरामीटर ढूंढता है
विभिन्न किस्मों के लिए विशेष पैरामीटर टेम्पलेट्स विकसित करना।
क्वांटिटेटिव फीडबैक फ्रेमवर्क और रैपिड इरेक्शन रणनीति विकसित करना।
इस रणनीति के आधार पर कीमतों और उच्च कीमतों के क्रॉसिंग के लिए व्यापार संकेत निर्णय, चलती औसत प्रौद्योगिकी फ़िल्टर शोर का उपयोग. यह कई प्रभावों को प्राप्त करने के लिए मापदंडों को लचीला रूप से कॉन्फ़िगर कर सकता है. इसके कुछ फायदे हैं, लेकिन कुछ समस्याएं भी हैं, जैसे कि कम संख्या में सिग्नल, देरी आदि। अधिक सूचक संयोजन निर्णय, मशीन सीखने के तरीके आदि को पेश करके अनुकूलित किया जा सकता है। एक मजबूत व्यापार रणनीति बनाई जा सकती है।
/*backtest
start: 2022-10-17 00:00:00
end: 2023-10-17 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/
//@version=2
//strategy(title = "Open Close Cross Strategy", shorttitle = "OCC Strategy", overlay = true, pyramiding = 0, default_qty_type = strategy.percent_of_equity, default_qty_value = 10)
// Revision: 1
// Author: @JayRogers
//
// Description:
// - Strategy based around Open-Close Crossovers.
// Setup:
// - I have generally found that setting the strategy resolution to 3-4x that of the chart you are viewing
// tends to yield the best results, regardless of which MA option you may choose (if any)
// - Don't aim for perfection. Just aim to get a reasonably snug fit with the O-C band, with good runs of
// green and red.
// - Option to either use basic open and close series data, or pick your poison with a wide array of MA types.
// - Optional trailing stop for damage mitigation if desired (can be toggled on/off)
// - Positions get taken automagically following a crossover - which is why it's better to set the resolution
// of the script greater than that of your chart, so that the trades get taken sooner rather than later.
// - If you make use of the trailing stops, be sure to take your time tweaking the values. Cutting it too fine
// will cost you profits but keep you safer, while letting them loose could lead to more drawdown than you
// can handle.
// === INPUTS ===
useRes = input(defval = true, title = "Use Alternate Resolution? ( recommended )")
stratRes = input(defval = "120", title = "Set Resolution ( should not be lower than chart )")
useMA = input(defval = true, title = "Use MA? ( otherwise use simple Open/Close data )")
basisType = input(defval = "DEMA", title = "MA Type: SMA, EMA, DEMA, TEMA, WMA, VWMA, SMMA, HullMA, LSMA, ALMA ( case sensitive )")
basisLen = input(defval = 14, title = "MA Period", minval = 1)
offsetSigma = input(defval = 6, title = "Offset for LSMA / Sigma for ALMA", minval = 0)
offsetALMA = input(defval = 0.85, title = "Offset for ALMA", minval = 0, step = 0.01)
useStop = input(defval = true, title = "Use Trailing Stop?")
slPoints = input(defval = 200, title = "Stop Loss Trail Points", minval = 1)
slOffset = input(defval = 400, title = "Stop Loss Trail Offset", minval = 1)
// === /INPUTS ===
// === BASE FUNCTIONS ===
// Returns MA input selection variant, default to SMA if blank or typo.
variant(type, src, len, offSig, offALMA) =>
v1 = sma(src, len) // Simple
v2 = ema(src, len) // Exponential
v3 = 2 * v2 - ema(v2, len) // Double Exponential
v4 = 3 * (v2 - ema(v2, len)) + ema(ema(v2, len), len) // Triple Exponential
v5 = wma(src, len) // Weighted
v6 = vwma(src, len) // Volume Weighted
v7 = na(v5[1]) ? sma(src, len) : (v5[1] * (len - 1) + src) / len // Smoothed
v8 = wma(2 * wma(src, len / 2) - wma(src, len), round(sqrt(len))) // Hull
v9 = linreg(src, len, offSig) // Least Squares
v10 = alma(src, len, offALMA, offSig) // Arnaud Legoux
type=="EMA"?v2 : type=="DEMA"?v3 : type=="TEMA"?v4 : type=="WMA"?v5 : type=="VWMA"?v6 : type=="SMMA"?v7 : type=="HullMA"?v8 : type=="LSMA"?v9 : type=="ALMA"?v10 : v1
// security wrapper for repeat calls
reso(exp, use, res) => use ? request.security(syminfo.tickerid, res, exp) : exp
// === /BASE FUNCTIONS ===
// === SERIES SETUP ===
// open/close
//closeSeries = useMA ? reso(variant(basisType, close, basisLen, offsetSigma, offsetALMA), useRes, stratRes) : reso(close, useRes, stratRes)
openSeries = useMA ? reso(variant(basisType, open, basisLen, offsetSigma, offsetALMA), useRes, stratRes) : reso(open, useRes, stratRes)
x = openSeries[1]
trendState = x > openSeries ? true : x < openSeries ? false : trendState[1]
// === /SERIES ===
// === PLOTTING ===
barcolor(color = x > openSeries ? #006600 : #990000, title = "Bar Colours")
// channel outline
closePlot = plot(x, title = "Close Line", color = #009900, linewidth = 2, style = line, transp = 90)
openPlot = plot(openSeries, title = "Open Line", color = #CC0000, linewidth = 2, style = line, transp = 90)
// channel fill
closePlotU = plot(trendState ? x : na, transp = 100, editable = false)
openPlotU = plot(trendState ? openSeries : na, transp = 100, editable = false)
closePlotD = plot(trendState ? na : x, transp = 100, editable = false)
openPlotD = plot(trendState ? na : openSeries, transp = 100, editable = false)
fill(openPlotU, closePlotU, title = "Up Trend Fill", color = #009900, transp = 40)
fill(openPlotD, closePlotD, title = "Down Trend Fill", color = #CC0000, transp = 40)
// === /PLOTTING ===
// === STRATEGY ===
// conditions
longCond = crossover(openSeries, x)
shortCond = crossunder(openSeries, x)
// entries and base exit
strategy.entry("long", true, when = longCond)
strategy.entry("short", false, when = shortCond)
// if we're using the trailing stop
//if (useStop)
// strategy.exit("XL", from_entry = "long", trail_points = slPoints, trail_offset = slOffset)
// strategy.exit("XS", from_entry = "short", trail_points = slPoints, trail_offset = slOffset)
// not sure needed, but just incase..
//strategy.exit("XL", from_entry = "long", when = shortCond)
//strategy.exit("XS", from_entry = "short", when = longCond)
// === /STRATEGY ===