इचिमोकू ब्रेकआउट रणनीति

लेखक:चाओझांग, दिनांक: 2023-10-13 16:48:22
टैगः

अवलोकन

इचिमोकू ब्रेकआउट रणनीति चलती औसत की अवधारणा का उपयोग करती है और प्रवृत्ति की दिशा निर्धारित करने के लिए इचिमोकू लाइनों और मूल्य के बीच संबंध का उपयोग करती है। यह प्रवृत्ति के बाद की रणनीति से संबंधित है। यह तब लंबा हो जाता है जब कीमत लाइनों के ऊपर टूट जाती है और जब कीमत लाइनों के नीचे टूट जाती है, तो यह प्रवृत्ति का पालन करती है।

सिद्धांत विश्लेषण

इस रणनीति का मूल Ichimoku रेखाओं के सिद्धांत पर आधारित है। यह का उपयोग करता हैdonchian()यह एक निश्चित अवधि के दौरान उच्चतम उच्च और निम्नतम निम्न के औसत की गणना करने के लिए एक संतुलन रेखा के रूप में कार्य करता है। यह तब न्याय करता है कि क्या व्यापार संकेत उत्पन्न करने के लिए मूल्य इस रेखा को तोड़ता है।

विशेष रूप से, रणनीति पहले टेनकन लाइन की गणना करती है (TS) का उपयोग करकेTenजब कीमत रेखा के ऊपर टूटती है, तो इसे एक प्रवृत्ति आंदोलन माना जाता है और एक लंबा संकेत उत्पन्न होता है। जब कीमत रेखा के नीचे टूटती है, तो इसे प्रवृत्ति उलट माना जाता है और एक छोटा संकेत उत्पन्न होता है।

इसके अतिरिक्त, रणनीति में किजुन लाइन की गणना की गई है (KS) का उपयोग करकेKijअवधि के साथTSयह गलत संकेतों से बचने के लिए एक फ़िल्टर के रूप में कार्य करता है।TSऊपर के क्रॉसKSएक लंबा संकेत ट्रिगर किया जाएगा।

कोड ट्रेंड दिशा निर्णय में सहायता के लिए इचिमोकू क्लाउड को भी प्लॉट करता है। चिको लाइन को एक सहायक शर्त के रूप में मूल्य के साथ इसके संबंध को निर्धारित करने के लिए गणना की जाती है।

लाभ विश्लेषण

  • प्रवृत्ति निर्धारित करने के लिए चलती औसत का उपयोग करता है, सरल और समझने में आसान है
  • Ichimoku Cloud सटीकता में सुधार के लिए अतिरिक्त संदर्भ प्रदान करता है
  • चिकू लाइन अतिरिक्त स्थिति के रूप में संकेतों को फ़िल्टर करती है
  • विभिन्न पैरामीटर संयोजनों के साथ उपलब्ध लचीला समायोजन

जोखिम विश्लेषण

  • चलती औसत रणनीति मापदंडों के प्रति संवेदनशील है, विभिन्न अवधि विभिन्न परिणाम दे सकती है
  • शुद्ध रुझान के बाद रुझान बनाम सीमा का न्याय करने में असमर्थ, नुकसान के जोखिम मौजूद हैं
  • समेकन अवधि का खराब प्रबंधन, गलत संकेतों के लिए प्रवण
  • बादल का निर्णय अस्थिर, भ्रामक हो सकता है

प्रवृत्ति की ताकत के लिए एमएसीडी जैसे गति संकेतक के साथ संयोजन पर विचार करें। स्थिरता में सुधार के लिए कई चलती औसत प्रणाली को अपनाएं। या जोखिम को नियंत्रित करने के लिए स्टॉप लॉस को शामिल करें।

अनुकूलन दिशाएँ

  • प्रवृत्ति शक्ति निर्धारित करने के लिए गति संकेतक जोड़ें
  • कई चलती औसत प्रणाली पर विचार करें, जैसे स्वर्ण क्रॉस
  • सीमाओं का पता लगाने के लिए चैनल और अस्थिरता संकेतक जोड़ें
  • सबसे अच्छा अवधि संयोजन खोजने के लिए मापदंडों का अनुकूलन
  • प्रति व्यापार हानि को सीमित करने के लिए स्टॉप लॉस रणनीति शामिल करें

निष्कर्ष

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


/*backtest
start: 2023-01-01 00:00:00
end: 2023-10-12 00:00:00
period: 1d
basePeriod: 1h
exchanges: [{"eid":"Futures_Binance","currency":"BTC_USDT"}]
*/

//@version=4

strategy(title="Ichimoku Crypto Breakout", shorttitle="Ichimoku Breakout", overlay=true)

Ten = input(18, minval=1, title="Tenkan")
Kij = input(52, minval=1, title="Kijun")
LeadSpan = input(104, minval=1, title="Senkou B")
Displace = input(52, minval=1, title="Senkou A")
SpanOffset = input(52, minval=1, title="Span Offset")

sts = input(true, title="Show Tenkan")
sks = input(true, title="Show Kijun")
ssa = input(true, title="Show Span A")
ssb = input(true, title="Show Span B")

source = close

//Script for Ichimoku Indicator
donchian(len) => avg(lowest(len), highest(len))
TS = donchian(Ten)
KS = donchian(Kij)
SpanA = avg(TS, KS)
SpanB = donchian(LeadSpan)

CloudTop = max(TS, KS)

Chikou = source[Displace]
SpanAA = avg(TS, KS)[SpanOffset]
SpanBB = donchian(LeadSpan)[SpanOffset]

//Kumo Breakout (Long)
SpanA_Top = SpanAA >= SpanBB ? 1 : 0
SpanB_Top = SpanBB >= SpanAA ? 1 : 0

SpanA_Top2 = SpanA >= SpanB ? 1 : 0
SpanB_Top2 = SpanB >= SpanA ? 1 : 0

SpanA1 = SpanA_Top2 ? SpanA : na
SpanA2 = SpanA_Top2 ? SpanB : na

SpanB1 = SpanB_Top2 ? SpanA : na
SpanB2 = SpanB_Top2 ? SpanB : na

//plot for Tenkan and Kijun (Current Timeframe)
p1= plot(sts and TS ? TS : na, title="Tenkan", linewidth = 2, color = gray)
p2 = plot(sks and KS ? KS : na, title="Kijun", linewidth = 2, color = black)
p5 = plot(close, title="Chikou", linewidth = 2, offset=-Displace, color = orange)

//Plot for Kumo Cloud (Dynamic Color)
p3 = plot(ssa and SpanA ? SpanA : na, title="SpanA", linewidth=2, offset=Displace, color=green)
p4 = plot(ssb and SpanB ? SpanB : na, title="SpanB", linewidth=2, offset=Displace, color=red)

p8 = plot(ssa and SpanA1 ? SpanA1 : na, title="Span A1 above", style=linebr, linewidth=1, offset=Displace, color=green)
p9 = plot(ssa and SpanA2 ? SpanA2 : na, title="Span A2 above", style=linebr, linewidth=1, offset=Displace, color=green)
p10 = plot(ssb and SpanB1 ? SpanB1 : na, title="Span B1 above", style=linebr, linewidth=1, offset=Displace, color=red)
p11 = plot(ssb and SpanB2 ? SpanB2 : na, title="Span B2 above", style=linebr, linewidth=1, offset=Displace, color=red)

fill(p8, p9, color = lime, transp=70, title="Kumo Cloud Up")
fill (p10, p11, color=red, transp=70, title="Kumo Cloud Down")

LongSpan = (SpanA_Top and source[1] < SpanAA[1] and source > SpanAA) or (SpanB_Top and source[1] < SpanBB[1] and source > SpanBB) ? 1 : 0
cupSpan = LongSpan  == 1 ? LongSpan : 0

//Kumo Breakout (Long)
//plotarrow(cupSpan, title="Kumo Breakout Long", colorup=green, maxheight=50)

//Kumo Breakout (Long) Alerts
Long_Breakout = (SpanA_Top ==1 and crossover(source, SpanAA)) or (SpanB_Top ==1 and crossover(source, SpanBB))
//Long_Breakout = ((SpanA_Top ==1 and crossover(KS, SpanAA)) or (SpanB_Top ==1 and crossover(KS, SpanBB))) and TS >= KS
//alertcondition(Long_Breakout, title="Kumo Breakout Long", message="Kumo Long")

//Kumo Breakout (Short)
ShortSpan = (SpanB_Top and source[1] > SpanAA[1] and source < SpanAA) or (SpanA_Top and source[1] > SpanBB[1] and source < SpanBB) ? 1 : 0
cdnSpan = ShortSpan == 1 ? ShortSpan : 0

//Kumo Breakout (Short)
//plotarrow(cdnSpan*-1, title="Kumo Breakout Short", colordown=red, maxheight=50)

//Kumo Breakout (Short) Alerts
Short_Breakout = (SpanA_Top ==1 and crossunder(source, SpanBB)) or (SpanB_Top ==1 and crossunder(source, SpanAA))
//alertcondition(Short_Breakout, title="Kumo Breakout Short", message="Kumo Short")

//Kumo Twist
Kumo_Twist_Long = SpanA[1] < SpanB[1] and SpanA > SpanB ? 1 : 0
Kumo_Twist_Short = SpanA[1] > SpanB[1] and SpanA < SpanB ? 1 : 0

cupD = Kumo_Twist_Long == 1 ? Kumo_Twist_Long : 0
cdnD = Kumo_Twist_Short == 1 ? Kumo_Twist_Short : 0

//Kumo Twist (Long/Short)
//plotarrow(cupD, title="Kumo Twist Long", colorup=green, maxheight=50)
//plotarrow(cdnD*-1, title="Kumo Twist Short", colordown=red, maxheight=50)

//Kumo Twist (Long/Short) Alerts
KumoTwistLong_Cross = crossover(SpanA, SpanB)
//alertcondition(KumoTwistLong_Cross, title="Kumo Twist Long", message="Kumo Twist Long")
KumoTwistShort_Cross = crossunder(SpanA, SpanB)
//alertcondition(KumoTwistShort_Cross, title="Kumo Twist Short", message="Kumo Twist Short")

//Kumo Twist (Long/Short) - Bar Color
BarColor = Kumo_Twist_Long ? green : Kumo_Twist_Short ? red : na
barcolor(BarColor)

//Chikou above/below Price
Chikou_Above = close > Chikou
Chikou_Below = close < Chikou

//Kumo Twist (Long/Short) - Plot Character on location of Chikou to Price & Price to Kumo
//plotchar(Kumo_Twist_Long and Chikou_Above, title="Kumo Twist Long and Chikou above Price", char="A", location=location.abovebar, color=green)
//plotchar(Kumo_Twist_Long and Chikou_Below, title="Kumo Twist Long and Chikou below Price", char="B", location=location.abovebar, color=red)
//plotchar(Kumo_Twist_Short and Chikou_Above, title="Kumo Twist Short and Chikou above Price", char="A", location=location.belowbar, color=green)
//plotchar(Kumo_Twist_Short and Chikou_Below, title="Kumo Twist Short and Chikou below Price", char="B", location=location.belowbar, color=red)

//Base and Conversion Line Cross
//long = cross(TS, KS) and TS>KS

long = (cross(TS, SpanA) or cross(TS, SpanB)) and TS>SpanA and TS>SpanB and TS>=KS
short = cross(TS, KS) and KS >= TS

strategy.entry("long", strategy.long, when=Long_Breakout)
strategy.entry("short", strategy.short, when=Short_Breakout)
//strategy.exit("bracket", when=short)

अधिक