72s: अनुकूलनशील पतवार चलती औसत+

लेखक:चाओझांग, दिनांकः 2022-05-26 17:17:37
टैगःएचएमएएटीआर

शुरुआती व्यापारियों के लिए एक चुनौतीपूर्ण मुद्दा यह है कि बाजार की स्थितियों को अलग करना है, चाहे वर्तमान बाजार मुनाफे को ढेर करने का सबसे अच्छा अवसर दे रहा हो, जितनी जल्दी हो सके, कम से कम समय में, या नहीं।

इंट्राडे पर, हमने देखा है कि बड़े बैंकों द्वारा कुछ बड़े कार्यों को कुछ हद तक परिभाषित किया जा सकता है या एचएमए 200 द्वारा चारों ओर घूम रहा है। मैं मूल्य गतिशीलता (मुख्य आंदोलन और मामूली शोर को अलग करना) के अनुरूप दृश्य बनाने के बारे में सोच रहा हूं ताकि यह स्पष्ट संकेत मिल सके कि यह कब शुरू होता है। इसलिए यह एक नज़र में देखना आसान होगा कि ताकत वास्तव में कब शुरू होती है, कम अव्यवस्थित चार्ट के साथ।

यह अनुकूली एचएमए नई पाइन स्क्रिप्ट की सुविधा का उपयोग कर रहा है जो अब कई पाइन कार्यों के लिए गतिशील लंबाई तर्कों का समर्थन करता है. (पढ़ेंःhttps://www.tradingview.com/blog/en/pine...). यह सीधे अंतर्निहित एचएमए () का समर्थन नहीं करता है, लेकिन शुक्र है कि हम निर्माण के लिए इसके डब्ल्यूएमए () सूत्र का उपयोग कर सकते हैं. (नोटः मैंने अपने डब्ल्यूएमए की लंबाई पर गोल के बजाय सादे इंट ((() का उपयोग करके यहां पहले से ही लोकप्रिय एचएमए सूत्र को थोड़ा संशोधित किया है, क्योंकि मुझे लगता है कि यह सटीक रूप से मेल खाता है ट्रेडिंगव्यू में अंतर्निहित एचएमए)).

आप चुन सकते हैं कि अनुकूलन एचएमए अवधि किस पहलू को अनुकूलित करेगी।

इस अध्ययन में मैं इसे दो विकल्पों के साथ प्रस्तुत करता हूंः वॉल्यूम और अस्थिरता। यह जल्दी या धीमी गति से आगे बढ़ेगा यह इस बात पर निर्भर करता है कि पहलू वर्तमान में किस स्थिति में है। अर्थातः जब वॉल्यूम आम तौर पर कम होता है या अस्थिर रीडिंग नहीं होती है, तो कीमत बहुत अधिक नहीं चलेगी, इसलिए अनुकूलन एमए गतिशील रूप से लुकबैक अवधि को लम्बा खींचकर धीमा हो जाएगा, और इसके विपरीत, और इसी तरह।

अनुकूली में रंग-चिह्न ऊपर बताई गई स्थिति के समान है। इसके अतिरिक्त, मैं इसे ट्रेंड-शक्ति या साइडवे / चॉप्पी स्थितियों को मापने में मदद करने के लिए एमए की ढलान गणना के साथ भी जोड़ता हूं।

इस तरह जब हम इसे गतिशील समर्थन/प्रतिरोध के रूप में उपयोग करते हैं तो यह अधिक दृश्य-विश्वसनीय होगा।

दूसरा, और अधिक महत्वपूर्ण, यह हमें व्यापारियों को बेहतर संभावना जानकारी के साथ मदद कर सकता है कि क्या एक व्यापार को बनाने के लायक होना चाहिए या नहीं। अर्थातः यदि मध्य समय में बाजार बहुत अधिक आंदोलन नहीं देगा, तो कोई भी लाभ भी उतना ही होगा। ज्यादातर मामलों में, हम अपने सिक्के को बाद के लिए बेहतर रख सकते हैं या इसे कहीं और रख सकते हैं।

कैसे इस्तेमाल करें: बेहतर गतिशील समर्थन/प्रतिरोध और अधिक स्पष्ट ब्रेकआउट पुष्टि के अलावा, एमए निम्नानुसार रंगित है: पीला: बाजार समेकन या फ्लैट में है. यह साइडवे, चंचल, या अपेक्षाकृत छोटे आंदोलनों में हो. यदि यह एक ट्रेंडिंग बाजार में दिखाई देता है, तो यह एक प्रारंभिक संकेत हो सकता है कि वर्तमान प्रवृत्ति अपनी दिशा बदलने के बारे में हो सकती है, या किसी अन्य पक्ष में कीमत के टूटने की पुष्टि कर सकती है। हल्का हरा या हल्का लालः यह बताता है कि क्या एक प्रवृत्ति बन रही है लेकिन अभी भी अपेक्षाकृत कमजोर है (या कमजोर हो रही है), क्योंकि इसके पास समर्थन करने के लिए मात्रा या अस्थिरता नहीं है। गहरे हरे या गहरे लालः यह वह जगह है जहां हम कुछ अच्छे और मजबूत मूल्य आंदोलन की उम्मीद कर सकते हैं। यदि यह पर्याप्त मजबूत है, तो कई बार यह एक नई दीर्घकालिक प्रमुख प्रवृत्ति की शुरुआत का संकेत देता है।

सेटिंग्सः चार्जर: चुनें कि आपके एचएमए को किस पहलू में प्लग करना चाहिए, इस प्रकार यह इसके अनुकूल होगा। न्यूनतम अवधि, अधिकतम अवधिः 172 - 233 केवल इंट्राडे के लिए स्थिर एचएमए 200 से बाहर निकलने के लिए मेरी अपनी सेटिंग है। मुझे लगता है कि मेरी ट्रेडिंग शैली में लगभग किसी भी जोड़ी में 15m tf में सबसे अच्छा है, और कुछ शेयरों के लिए 15m से 1H तक। यह पारंपरिक ईएमए 200 के साथ भी अच्छी तरह से काम करता है, कभी-कभी जैसे कि वे कुछ हद तक हाथ में काम करते हैं जहां कीमत को जाना चाहिए। लेकिन आप, निश्चित रूप से, अन्य रेंज के साथ प्रयोग कर सकते हैं, व्यापक या संकीर्ण। खासकर यदि आपके पास पहले से ही एक स्थापित रणनीति है जिसका पालन करना है। जैसा कि आप के साथ कर सकते हैंः समेकन क्षेत्र की सीमाः यह ढलान गणना के साथ करना है. संख्या बड़ा मतलब है कि अपने एमए की जरूरत है एक बड़ी डिग्री बाजार को परिभाषित करने के लिए फ्लैट (पीला) क्षेत्र से बाहर है. यह उपयोगी हो सकता है यदि आवश्यक हो तो फ़िल्टर को हल्का करने के लिए या इसके विपरीत. पृष्ठभूमि का रंगः बाजार की स्थितियों में अंतर को उजागर करने में मदद करने के लिए सिर्फ एक और रंग।

अलर्टः दो अलर्ट हैंः वॉल्यूम ब्रेकः जब वॉल्यूम औसत से ऊपर टूट रहा हो और अस्थिरता मीटर: जब बाजार अधिक संभावना है कि अपने बड़े घुमावदार ब्रश के क्षण के बारे में है।

उपयोगः बहुत बहुत अच्छा खरीदें प्रविष्टि अगर बड़ा ऊपर आंदोलन पकड़ने के लिएः

  1. मूल्य एमए से ऊपर है. (यह सबसे अच्छा है जब कीमत भी एमए से बहुत दूर नहीं है, या आप भी मदद करने के लिए दूरी थरथरानवाला का भी उपयोग कर सकते हैं)
  2. एचएमए का रंग गहरे हरे रंग का है, जिसका अर्थ है कि यह आपके चुने हुए पहलू के साथ चार्जिंग प्लग पर है।
  3. आरएसआई 50 से ऊपर है। यह अतिरिक्त पुष्टि के रूप में मदद करता है।

स्पष्ट बिक्री प्रवेश संकेत ऊपर के समान है, बस विपरीत है।

बैकटेस्ट

img


/*backtest
start: 2022-04-25 00:00:00
end: 2022-05-24 23:59:00
period: 15m
basePeriod: 5m
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/
// 2020 © io72signals / Antorio Bergasdito

//@version=4
study("72s: Adaptive Hull Moving Average+", shorttitle="72s: Adaptive HMA+", overlay=true)

//Optional Inputs
charger     = input("Volatility", title="Choose which charger to adapt to:", options=["Volatility", "Volume"])
src         = input(close, title="Source:")
minLength   = input(172, title="Minimum period:")
maxLength   = input(233, title="Maximum period:")
adaptPct    = 0.03141 //input(3.141, minval = 0, maxval = 100, title="Adapting Percentage:") / 100.0

flat        = input(17, title="Consolidation area is when slope below:")

showMinor   = input(true, title="Show minor xHMA+", group="Minor Adaptive HMA+ Period")
minorMin    = input(89, title="Minimum:", group="Minor Adaptive HMA+ Period", inline="mHMA+")
minorMax    = input(121, title="Maximum:", group="Minor Adaptive HMA+ Period", inline="mHMA+")

showZone    = input(false, title="Show Adaptive HMA+ Distance Zone", group="DISTANCE ZONE")
mult        = input(2.7, title="Distance (Envelope) Multiplier", step=.1, group="DISTANCE ZONE") 

showSignals = input(true, title="Show Possible Signals", group="OTHER")
useBg       = input(true, title="Background color to differentiate movement", group="OTHER")

//Source to adapt to
highVolatility = atr(14) > atr(46)                  //Volatility Meter. Change it to match to your strat/pair/tf if needs.

rsivol  = rsi(volume,14)                            //RSI Volume Osc:
osc     = hma(rsivol,10)                            //Basically it's almost the same as: vol > ma(volume,20)
volBreak = osc > 49                                 //but smoothed using weight to filter noise or catch earlier signs.    

//Dynamics 
var float dynamicLength = avg(minLength,maxLength)
var float minorLength   = avg(minorMin,minorMax)
plugged = charger=="Volume"? volBreak : highVolatility
dynamicLength   := iff(plugged, max(minLength, dynamicLength * (1 - adaptPct)), min(maxLength, dynamicLength * (1 + adaptPct)))
minorLength     := iff(plugged, max(minorMin, minorLength * (1 - adaptPct)), min(minorMax, minorLength * (1 + adaptPct)))

//Slope calculation to determine whether market is in trend, or in consolidation or choppy, or might about to change current trend
slope_period = 34, range = 25, pi = atan(1) * 4
highestHigh = highest(slope_period), lowestLow = lowest(slope_period)
slope_range = range / (highestHigh - lowestLow) * lowestLow
calcslope(_ma)=>
    dt = (_ma[2] - _ma) / src * slope_range  
    c = sqrt(1 + dt * dt)
    xAngle = round(180 * acos(1 / c) / pi)
    maAngle = iff(dt > 0, -xAngle, xAngle)
    maAngle

//MA coloring to mark market dynamics 
dynColor(_ma,_col1a,_col1b, _col2a, _col2b, _col0) =>
    slope = calcslope(_ma)
    slope >= flat ? plugged? _col1a : _col1b :
     slope < flat and slope > -flat ? _col0 : 
     slope <= -flat ? plugged? _col2a : _col2b : _col0

//Adaptive HMA 
xhma(_src,_length) => _return = wma(2 * wma(_src, _length / 2) - wma(_src, _length), floor(sqrt(_length))) 

dynamicHMA  = xhma(src,int(dynamicLength))      //<--Batman - Our main xHMA+
minorHMA    = xhma(src,int(minorLength))        //<--Robin  - Faster minor xHMA+ (Optional). Can be use to assist for 
                                                //            faster entry, slower exit point, or pullbacks info too.

//Plot
plot(dynamicHMA, "Dynamic HMA+", dynColor(dynamicHMA, #6fbf73, #c0f5ae, #eb4d5c, #f2b1d4, color.yellow), 3)
plot(showMinor? minorHMA:na, "minor HMA+", dynColor(minorHMA, #6fbf73, #c0f5ae, #eb4d5c, #f2b1d4, color.yellow), 1)

//Backgroud coloring
notgreat = calcslope(dynamicHMA) < flat and calcslope(dynamicHMA) > -flat
bgcolor(useBg? plugged? na : notgreat? #757779: #afb4b9 : na)

// Comparative study
// staticHMA = hma(close, 200)
// plot(staticHMA,  "Static HMA")
// plotchar(dynamicLength, "dynamicLengthgth", "", location.top) //check output the calculated Dynamic Length in the Data Window.

//{ DISTANCE ZONE
// Envelope the main DynamicHMA with ATR band, just one way to approximate current price distance to MA. Other usages/methods may vary.
upperTL = dynamicHMA + mult * atr(40)        ,  lowerTL = dynamicHMA - mult * atr(40)           //<--Half distance zone
topTL = dynamicHMA + (mult*2) * atr(40)      ,  botTL = dynamicHMA - (mult*2) * atr(40)         //<--One distance zone
stopupperTL = dynamicHMA + (mult/2) * atr(40),  stoplowerTL = dynamicHMA - (mult/2) * atr(40)   //<--Half of the half. If need ie. tighter SL or trailing

// Plotting Distance Zone
plot(showZone?upperTL:na, color=color.green, transp=72)
plot(showZone?lowerTL:na, color=color.red,   transp=72)
plot(showZone?topTL:na, color=color.gray, transp=72)
plot(showZone?botTL:na, color=color.gray, transp=72)
sutl = plot(showZone?stopupperTL:na, color=color.white, transp=100)
sltl = plot(showZone?stoplowerTL:na, color=color.white, transp=100)
colZone = showZone? color.purple:color.new(color.white,100)
fill(sutl, sltl, color=colZone, transp=90)
//}

//{ SIGNALS
_slope = calcslope(dynamicHMA)

// Entry Base; When HMA+ turn to a darker color and market is out from low volatility. 
// Remember to also considering price distance to MA and strength (ie. RSI)
_upSig = _slope >=  flat and plugged
_dnSig = _slope <= -flat and plugged
buy  = _upSig and not _upSig[1] 
sell = _dnSig and not _dnSig[1] 

// Possible Exits. These only based on faster xHMA+
_upExit = _slope>=flat  and (not plugged) and close<minorHMA 
_dnExit = _slope<=-flat and (not plugged) and close>minorHMA 
fastExits  = (_upExit and not _upExit[1]) or (_dnExit and not _dnExit[1])

// Caution Sign. When Price crossed most outer distance zone. Could also be a good TP spot if your already in profit
_topWarn    = high>topTL
_botWarn    = low<botTL
warningSigns = (_topWarn and not _topWarn[1]) or (_botWarn and not _botWarn[1])

// Plot 'em up
atrPos = 0.72 * atr(5)
plotchar(showSignals and buy?  dynamicHMA-atrPos: na, color=color.green, location=location.absolute, char="⬆", size = size.tiny)
plotchar(showSignals and sell? dynamicHMA+atrPos: na, color=color.red,   location=location.absolute, char="⬇", size = size.tiny)
plotchar(showSignals and fastExits? _upExit? minorHMA+atrPos: _dnExit? minorHMA-atrPos: na: na, 
     color=_upExit?color.green:_dnExit?color.red: na, location=location.absolute, char="ⓧ", size=size.tiny)
plotchar(showSignals and warningSigns? _topWarn? high+atrPos: _botWarn? low-atrPos: na: na, 
     color=color.orange, location=location.absolute, char="⚠", size=size.tiny)
//} 

//{ ALERTS
// Previous alerts:
// alertcondition(highVolatility and not notgreat, "72s: Volatility Meter", "Market is on the move")
// alertcondition(volBreak[1] and volBreak and not notgreat, "72s: Volume Break", "Volume has just break above average")

// New Alert: 
// Delete what alert you don't need:
if buy 
    alert("Possible Buy Signal at" + tostring(close), alert.freq_once_per_bar_close)
if sell
    alert("Possible Sell Signal at" + tostring(close), alert.freq_once_per_bar_close)
    
if fastExits and _upExit
    alert("Price has just crossed down minor xHMA+ at" + tostring(close), alert.freq_once_per_bar_close)
if fastExits and _dnExit
    alert("Price has just crossed up minor xHMA+ at" + tostring(close), alert.freq_once_per_bar_close)
    
if warningSigns and _topWarn
    alert("Price has just crossed above top xHMA+ zone", alert.freq_once_per_bar_close)
if warningSigns and _botWarn
    alert("Price has just crossed below bottom xHMA+ zone", alert.freq_once_per_bar_close)
//}
    




if buy
    strategy.entry("Enter Long", strategy.long)
else if sell
    strategy.entry("Enter Short", strategy.short)

संबंधित

अधिक