केडीजे एक्सट्रीम रिवर्सल ट्रेंड ट्रैकिंग रणनीति: जे इंडिकेटर पर आधारित एक बहुआयामी मात्रात्मक ट्रेडिंग प्रणाली

KDJ J值 趋势跟踪 极值反转 EMA 技术指标 量化交易 动量策略 波动率过滤 风险管理
निर्माण तिथि: 2025-08-04 09:33:31 अंत में संशोधित करें: 2025-08-04 09:33:31
कॉपी: 4 क्लिक्स: 228
2
ध्यान केंद्रित करना
319
समर्थक

केडीजे एक्सट्रीम रिवर्सल ट्रेंड ट्रैकिंग रणनीति: जे इंडिकेटर पर आधारित एक बहुआयामी मात्रात्मक ट्रेडिंग प्रणाली केडीजे एक्सट्रीम रिवर्सल ट्रेंड ट्रैकिंग रणनीति: जे इंडिकेटर पर आधारित एक बहुआयामी मात्रात्मक ट्रेडिंग प्रणाली

रणनीति अवलोकन

KDJ चरम रिवर्स ट्रेंड ट्रैकिंग रणनीति एक मात्रात्मक ट्रेडिंग प्रणाली है जो गतिशीलता रिवर्स और ट्रेंड ट्रैकिंग अवधारणा को जोड़ती है। इस रणनीति का मुख्य उद्देश्य J सूचक के चरम क्षेत्र में ((0 या 100) के बाद पहले रिवर्स सिग्नल को पकड़ना है, और ईएमए 676 के माध्यम से प्रवृत्ति की दिशा को फ़िल्टर करना है ताकि यह सुनिश्चित किया जा सके कि व्यापार की दिशा मुख्य प्रवृत्ति के अनुरूप है। सिस्टम सटीक प्रवेश शर्तों, लचीली स्थिति प्रबंधन और सख्त जोखिम नियंत्रण तंत्र का उपयोग करता है।

रणनीति सिद्धांत

इस रणनीति का मूल तर्क केडीजे सूचक के जे-वैल्यू गुणों पर आधारित है, और प्रवृत्ति फ़िल्टरिंग के साथ सटीक प्रवेश प्राप्त करता है। इसके विशिष्ट सिद्धांत इस प्रकार हैंः

  1. J मान चरम पहचान: रणनीति निगरानी करता है कि क्या J का मान पूर्वनिर्धारित चरम सीमाओं तक पहुंचता है (डिफ़ॉल्ट ऊपरी सीमा 100, निचली सीमा 0), ये चरम सीमाएं आमतौर पर बाजार को ओवरबॉट या ओवरसोल्ड स्थिति में दर्शाती हैं।

  2. निरंतर परिवर्तन पैटर्न की पुष्टि: रणनीति के अनुसार, J मान के चरम पर पहुंचने के बाद, लगातार 3 K लाइनों में एकतरफा परिवर्तन होना चाहिए (लगातार ऊपर या नीचे) । यह पैटर्न संकेतक के मजबूत आंदोलन की पुष्टि कर सकता है।

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

  4. रुझान फ़िल्टर करें: रणनीति ईएमए 676 औसत रेखा का उपयोग करती है, केवल जब कीमत औसत रेखा से ऊपर होती है, तो अधिक संकेतों पर विचार करें, और औसत रेखा से नीचे होने पर एक शून्य संकेत पर विचार करें, यह सुनिश्चित करने के लिए कि व्यापार की दिशा समग्र प्रवृत्ति के अनुरूप है।

  5. गतिशील स्टॉप लॉसरणनीतिः स्टॉप-स्टॉप-लॉस को प्रवेश मूल्य के आधार पर प्रतिशत के रूप में गणना की जाती है, डिफ़ॉल्ट रूप से 3% स्टॉप और 2.2% स्टॉप-लॉस सेट किया जाता है, जो 1 से अधिक जोखिम-लाभ अनुपात के साथ ट्रेडिंग संरचना को प्राप्त करता है।

  6. बुद्धिमान गोदाम प्रबंधन: सिस्टम स्थिर अनुबंधों की संख्या और जोखिम-आधारित प्रतिशत दो तरह की स्थिति गणना प्रदान करता है, जो स्थिति के आकार को प्रत्येक लेनदेन के जोखिम के मोर्चे की गतिशीलता के आधार पर समायोजित करता है, जिससे धन उपयोग दक्षता में सुधार होता है।

रणनीतिक लाभ

कोड के गहन विश्लेषण के बाद, इस रणनीति के निम्नलिखित प्रमुख फायदे हैंः

  1. सटीक संकेत ट्रिगर: यह जटिल शर्त संकेत की विश्वसनीयता को काफी बढ़ाता है और झूठे ब्रेकडाउन को कम करता है, क्योंकि यह मांग करता है कि J मूल्य न केवल चरम पर पहुंचता है, बल्कि लगातार 3 K लाइनों के एकतरफा आंदोलन का अनुभव करता है, और फिर पहली पलटाव को पकड़ता है।

  2. ट्रेंड और रिवर्स का सही संयोजन: रणनीति ने ट्रेंड ट्रैकिंग (ईएमए 676 दिशा फ़िल्टर) और रिवर्स ट्रेडिंग (जे मूल्य में चरम मूल्य पर वापसी) के दो व्यापारिक विचारों को संयोजित किया है, जो बड़े रुझान की दिशा का सम्मान करते हैं और प्रवृत्ति में उच्च संभावना वाले वापसी के अवसरों को पकड़ते हैं।

  3. अनुकूलित जोखिम प्रबंधन: कोड में जोखिम प्रतिशत के आधार पर गतिशील स्थिति गणना को लागू किया गया है, जिससे प्रत्येक लेनदेन के लिए एक समान जोखिम है, जो बाजार में उतार-चढ़ाव के बावजूद स्थिर जोखिम नियंत्रण बनाए रखता है।

  4. स्पष्ट दृश्य प्रतिक्रियारणनीतिकः चार्ट पर प्रवेश संकेत, स्टॉप-स्टॉप-लॉस ट्रिगर और महत्वपूर्ण मूल्य रेखाओं को चित्रित किया गया है, जिससे व्यापारी प्रत्येक व्यापार के निष्पादन तर्क और परिणामों को सहजता से समझ सकते हैं।

  5. लचीला पैरामीटर विन्यासयह प्रणाली केडीजे गणना चक्र, ईएमए की लंबाई, चरम सीमा सेटिंग्स, स्टॉप-स्टॉप-लॉस अनुपात आदि सहित कई समायोज्य पैरामीटर प्रदान करती है, जो रणनीति को विभिन्न बाजार स्थितियों और ट्रेडिंग किस्मों के अनुकूल बनाती है।

  6. पूर्व चेतावनी तंत्र: कोड में संकेतों के करीब आने के लिए पूर्व चेतावनी की शर्तें डिज़ाइन की गई हैं, जैसे कि जब J मान चरम सीमा क्षेत्र के करीब है या प्रवेश संकेत बनने वाला है, तो व्यापारियों को पहले से तैयार रहने के लिए सूचित किया जा सकता है, जिससे संचालन की दक्षता बढ़ जाती है।

रणनीतिक जोखिम

हालांकि इस रणनीति को अच्छी तरह से डिजाइन किया गया है, लेकिन इसके साथ निम्नलिखित संभावित जोखिम भी हैं:

  1. चरम स्थितियों में नुकसान रोकना: बाजार में उतार-चढ़ाव या चरम उतार-चढ़ाव के दौरान, पूर्वनिर्धारित प्रतिशत रोकना अपेक्षित मूल्य के अनुसार निष्पादित नहीं किया जा सकता है, जिससे वास्तविक नुकसान अपेक्षित से अधिक हो जाता है। समाधान एक आउटफील्ड रोकथाम तंत्र को पेश करना है, या इन-फील्ड स्थितियों का उपयोग करने पर विचार करना है।

  2. औसत रेखा के पीछे का जोखिम:EMA676 एक लंबी अवधि की औसत रेखा के रूप में काफी पिछड़ापन है, जो प्रवृत्ति में बदलाव की शुरुआत में गलत दिशा निर्देश दे सकता है। संकेत की गुणवत्ता को अनुकूलित करने के लिए बहु-चक्र विश्लेषण के साथ संयोजन या अल्पकालिक प्रवृत्ति की पुष्टि करने वाले संकेतकों को जोड़ने की सिफारिश की जाती है।

  3. पैरामीटर अनुकूलन अति-फिट: वर्तमान पैरामीटर (जैसे कि केडीजे चक्र 60, चरम मूल्य 1000) ऐतिहासिक डेटा के अनुकूलन के आधार पर प्राप्त किया जा सकता है, अति-अनुरूपता का जोखिम है। पूर्व-अनुमानित परीक्षण और विभिन्न चक्र परीक्षणों के माध्यम से पैरामीटर की स्थिरता को सत्यापित करने की सिफारिश की जाती है।

  4. J मान गणना विचलननीतिः कस्टम bcwsma फ़ंक्शन का उपयोग करके केडीजे मानों की गणना करें, जो विभिन्न प्लेटफार्मों पर मानक केडीजे गणना से भिन्न हो सकते हैं, जिसके कारण रिट्रेसमेंट रीयल-टाइम सिग्नल के साथ असंगत हो सकता है। रीयल-टाइम से पहले गणना विधि की स्थिरता की पुष्टि की जानी चाहिए।

  5. कम तरलता वाले बाजार जोखिम: कम व्यापार की मात्रा वाले बाजारों में, स्टॉप-स्टॉप-लॉस स्लाइड्स बड़े हो सकते हैं, जो रणनीति के वास्तविक प्रदर्शन को प्रभावित करते हैं। उच्च तरलता वाले बाजारों या प्रमुख व्यापारिक किस्मों पर रणनीति को लागू करने की सिफारिश की जाती है।

  6. संकेत आवृत्ति अस्थिर: चरम मूल्य पर आधारित सिग्नल अलग-अलग बाजार वातावरण में आवृत्ति में भिन्न हो सकते हैं, जिससे धन उपयोगिता में अस्थिरता हो सकती है। ट्रेडिंग आवृत्ति को सुचारू करने के लिए सहायक ट्रेडिंग सिग्नल या बहु-समय फ्रेम पुष्टिकरण तंत्र को जोड़ने पर विचार किया जा सकता है।

रणनीति अनुकूलन दिशा

इस रणनीति के लिए निम्नलिखित अनुकूलन दिशाओं पर विचार किया जा सकता हैः

  1. गतिशील चरम सेटिंग: वर्तमान रणनीतियों का उपयोग स्थिर चरम सीमाओं के ऊपरी और निचले स्तर पर किया जाता है। 100 और 0। ऐतिहासिक उतार-चढ़ाव के आधार पर चरम सीमाओं को गतिशील रूप से समायोजित करने पर विचार किया जा सकता है, विभिन्न उतार-चढ़ाव के वातावरण में अनुकूलित किया जा सकता है, उदाहरण के लिए, कम उतार-चढ़ाव के दौरान उचित रूप से सीमित सीमाओं को संकीर्ण करना, उच्च उतार-चढ़ाव के दौरान चरम सीमाओं की सीमाओं का विस्तार करना।

  2. बहु-समय फ़्रेम पुष्टि: अधिक उन्नत समय सीमा की पुष्टि करने वाले संकेतों को पेश करना, जैसे कि सूर्य के प्रकाश के स्तर के लिए जे मान भी चरम सीमा क्षेत्र में हैं, या 3 मिनट और 15 मिनट की अवधि के लिए सिग्नल एकजुटता की पुष्टि करना, सिग्नल की गुणवत्ता में सुधार करना।

  3. स्मार्ट रोकथाम: गतिशील स्टॉप रणनीति को लागू करें, जैसे कि बैचों में बकाया या एटीआर (वास्तविक अस्थिरता) के आधार पर स्टॉप की गणना, या ट्रैक स्टॉप का उपयोग करें जब लाभप्रदता एक निश्चित स्तर तक पहुंच जाती है, जिससे ट्रेंड लाभ को अधिकतम किया जा सके।

  4. बाजार परिवेश फ़िल्टर: अस्थिरता फ़िल्टर शर्तों को बढ़ाएं, अत्यधिक अस्थिरता या बहुत कम अस्थिरता वाले बाजार की स्थिति में व्यापार को निलंबित करें, या स्थिति के आकार को समायोजित करें ताकि रणनीति के लिए उपयुक्त बाजार की स्थिति में व्यापार से बचा जा सके।

  5. सिग्नल तीव्रता श्रेणी: J मूल्य रिवर्स आयाम, K लाइन आकृति, और मात्रा की पुष्टि के आधार पर, सिग्नल की ताकत को वर्गीकृत करें, और सिग्नल की ताकत की गतिशीलता के आधार पर स्थिति का आकार समायोजित करें, मजबूत सिग्नल स्थिति को बढ़ाता है, कमजोर सिग्नल स्थिति को कम करता है।

  6. मशीन लर्निंग अनुकूलन: मशीन सीखने एल्गोरिदम को स्वचालित रूप से पैरामीटर के संयोजन को अनुकूलित करने के लिए, या ऐतिहासिक संकेतों की विशेषता निकालने के लिए, प्रत्येक संकेत की सफलता की संभावना का आकलन करने के लिए एक पूर्वानुमान मॉडल बनाने के लिए, रणनीति की अनुकूलनशीलता और स्थिरता को बढ़ाने के लिए।

संक्षेप

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

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

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

रणनीति स्रोत कोड
//@version=6
strategy("J值极值趋势跟随策略", overlay = true, 
         default_qty_type = strategy.percent_of_equity, default_qty_value = 10,  // 降低每笔交易的仓位大小
         initial_capital = 10000, 
         margin_long = 20, margin_short = 20)  // 设置合理的保证金要求

// === 策略说明:J值极值趋势跟随策略 ===
// 主图:显示J值连续下降后反弹的买点和连续上升后回调的卖点
// 副图:显示J线走势、中轴线、极值区域
// 方向过滤:676均线,价格在上方只做多,下方只做空
// 止盈止损:基于百分比波动,默认1%止盈1%止损

// === 输入参数 ===
lengthK = input.int(60, title = "K period")
lengthD = input.int(3, title = "D period")
smoothK = input.int(3, title = "Smooth K")
emaLength = input.int(576, title = "趋势EMA周期", inline="ema")
extremeHigh = input.float(100, title = "J值极值上限", minval = 80, maxval = 120)
extremeLow = input.float(0, title = "J值极值下限", minval = -20, maxval = 20)

// === 止盈止损参数(改为百分比) ===
takeProfitPercent = input.float(3, title = "止盈百分比", minval = 0.1, step = 0.1)
stopLossPercent = input.float(2.2, title = "止损百分比", minval = 0.1, step = 0.1)

// === 风险控制参数 ===
useFixedPositionSize = input.bool(true, title = "使用固定合约数量")
fixedPositionSize = input.float(1.0, title = "固定合约数量", minval = 0.1, step = 0.1)
riskPerTrade = input.float(1.0, title = "每笔交易风险百分比", minval = 0.1, maxval = 10, step = 0.1)

// === KDJ计算(使用与bitcoinwisdom一致的算法) ===
// 自定义加权移动平均函数(与bitcoinwisdom一致)
bcwsma(s, l, m) => 
    var _bcwsma = 0.0
    _bcwsma := (m*s + (l-m)*nz(_bcwsma[1])) / l
    _bcwsma

highestHigh = ta.highest(high, lengthK)
lowestLow = ta.lowest(low, lengthK)
rsv = (close - lowestLow) / (highestHigh - lowestLow) * 100
K = bcwsma(rsv, smoothK, 1)
D = bcwsma(K, lengthD, 1)
J = 3 * K - 2 * D

// === 676均线方向判断 ===
ema676 = ta.ema(close, emaLength)
trendUp = close > ema676    // 价格在676均线上方
trendDown = close < ema676  // 价格在676均线下方

// === 检测J值连续下降和上升 ===
// 检测连续3根下降:J < J[1] < J[2] < J[3]
jContinuousDown = J < J[1] and J[1] < J[2] and J[2] < J[3]

// 检测连续3根上升:J > J[1] > J[2] > J[3]
jContinuousUp = J > J[1] and J[1] > J[2] and J[2] > J[3]

// === 检测反弹和回调(必须在极值区域内) ===
// 反弹:当前J值上升,且之前连续下降,且J值在极值下限以下
jBounce = J > J[1] and jContinuousDown[1] and J[1] <= extremeLow

// 回调:当前J值下降,且之前连续上升,且J值在极值上限以上
jPullback = J < J[1] and jContinuousUp[1] and J[1] >= extremeHigh

// === 开仓信号(带方向过滤) ===
// 买点:J值连续下降后反弹 + 价格在676均线上方
longEntry = jBounce and trendUp

// 卖点:J值连续上升后回调 + 价格在676均线下方
shortEntry = jPullback and trendDown

// === 记录开仓价格和止盈止损价格 ===
var float entryPrice = na
var float tpPrice = na
var float slPrice = na

// === 计算仓位大小 ===
// 基于风险百分比的仓位计算需要考虑止损百分比
positionSize = useFixedPositionSize ? fixedPositionSize : (strategy.equity * (riskPerTrade / 100)) / (close * stopLossPercent / 100)

// === 止盈止损信号变量 ===
var bool longTakeProfitHit = false
var bool longStopLossHit = false
var bool shortTakeProfitHit = false
var bool shortStopLossHit = false

// === 警报信号指示器 ===
// 多单入场信号将触发
longSignalComing = J <= extremeLow and jContinuousDown and trendUp
// 空单入场信号将触发
shortSignalComing = J >= extremeHigh and jContinuousUp and trendDown
// J值接近极值区域
jNearExtremeLow = J <= extremeLow + 5 and J > extremeLow
jNearExtremeHigh = J >= extremeHigh - 5 and J < extremeHigh

// === 策略执行 ===
if (longEntry and strategy.position_size == 0)
    entryPrice := close
    // 计算基于百分比的止盈止损价格
    tpPrice := entryPrice * (1 + takeProfitPercent / 100)
    slPrice := entryPrice * (1 - stopLossPercent / 100)
    strategy.entry("多单", strategy.long, qty=positionSize)
    // 重置止盈止损信号
    longTakeProfitHit := false
    longStopLossHit := false

if (shortEntry and strategy.position_size == 0)
    entryPrice := close
    // 计算基于百分比的止盈止损价格
    tpPrice := entryPrice * (1 - takeProfitPercent / 100)
    slPrice := entryPrice * (1 + stopLossPercent / 100)
    strategy.entry("空单", strategy.short, qty=positionSize)
    // 重置止盈止损信号
    shortTakeProfitHit := false
    shortStopLossHit := false

// === 手动检查止盈止损条件 ===
// 多单止盈止损
longTPHit = strategy.position_size > 0 and high >= tpPrice and not longTakeProfitHit
longSLHit = strategy.position_size > 0 and low <= slPrice and not longStopLossHit

if (longTPHit)
    strategy.close("多单", comment="止盈")
    longTakeProfitHit := true
    
if (longSLHit)
    strategy.close("多单", comment="止损")
    longStopLossHit := true

// 空单止盈止损
shortTPHit = strategy.position_size < 0 and low <= tpPrice and not shortTakeProfitHit
shortSLHit = strategy.position_size < 0 and high >= slPrice and not shortStopLossHit

if (shortTPHit)
    strategy.close("空单", comment="止盈")
    shortTakeProfitHit := true
    
if (shortSLHit)
    strategy.close("空单", comment="止损")
    shortStopLossHit := true

// === 在主图绘制676均线 ===
plot(ema676, title="676 EMA", color=color.blue, linewidth=2)

// === 在主图标注开仓信号 ===
plotshape(longEntry, title="多单入场", location=location.belowbar, color=color.lime, style=shape.triangleup, size=size.small, text="多单", force_overlay=true)
plotshape(shortEntry, title="空单入场", location=location.abovebar, color=color.red, style=shape.triangledown, size=size.small, text="空单", force_overlay=true)

// === 添加止盈止损信号 ===
// 多单止盈信号
plotshape(longTPHit, title="多单止盈", location=location.abovebar, 
         color=color.green, style=shape.circle, size=size.normal, text="止盈", force_overlay=true)

// 多单止损信号
plotshape(longSLHit, title="多单止损", location=location.abovebar, 
         color=color.red, style=shape.xcross, size=size.normal, text="止损", force_overlay=true)

// 空单止盈信号
plotshape(shortTPHit, title="空单止盈", location=location.belowbar, 
         color=color.green, style=shape.circle, size=size.normal, text="止盈", force_overlay=true)

// 空单止损信号
plotshape(shortSLHit, title="空单止损", location=location.belowbar, 
         color=color.red, style=shape.xcross, size=size.normal, text="止损", force_overlay=true)



// === 绘制止盈止损线 ===
plot(strategy.position_size != 0 ? tpPrice : na, title="止盈", color=color.green, style=plot.style_line, linewidth=1)
plot(strategy.position_size != 0 ? slPrice : na, title="止损", color=color.red, style=plot.style_line, linewidth=1)
plot(strategy.position_size != 0 ? entryPrice : na, title="入场价", color=color.yellow, style=plot.style_line, linewidth=1)

// === 设置警报条件(使用常量字符串) ===
// 基础信号警报
alertcondition(longEntry, title="多单入场信号", message="J值极值策略: 多单入场信号触发")
alertcondition(shortEntry, title="空单入场信号", message="J值极值策略: 空单入场信号触发")
alertcondition(longTPHit, title="多单止盈触发", message="J值极值策略: 多单止盈触发")
alertcondition(longSLHit, title="多单止损触发", message="J值极值策略: 多单止损触发")
alertcondition(shortTPHit, title="空单止盈触发", message="J值极值策略: 空单止盈触发")
alertcondition(shortSLHit, title="空单止损触发", message="J值极值策略: 空单止损触发")


// === 添加交易详情标签 ===
if (longTPHit)
    label.new(bar_index, high, text="多单止盈 +" + str.tostring(takeProfitPercent) + "%", 
              style=label.style_label_down, color=color.green, textcolor=color.white)

if (longSLHit)
    label.new(bar_index, low, text="多单止损 -" + str.tostring(stopLossPercent) + "%", 
              style=label.style_label_up, color=color.red, textcolor=color.white)

if (shortTPHit)
    label.new(bar_index, low, text="空单止盈 +" + str.tostring(takeProfitPercent) + "%", 
              style=label.style_label_up, color=color.green, textcolor=color.white)

if (shortSLHit)
    label.new(bar_index, high, text="空单止损 -" + str.tostring(stopLossPercent) + "%", 
              style=label.style_label_down, color=color.red, textcolor=color.white)