अंतर्निहित फ़ंक्शन_क्रॉस विश्लेषण और उपयोग की व्याख्या

लेखक:छोटे सपने, बनाया गयाः 2017-10-11 19:50:44, अद्यतन किया गयाः 2021-11-05 16:15:56

अंतर्निहित फ़ंक्शन_क्रॉस विश्लेषण और उपयोग की व्याख्या

एपीआई दस्तावेज में वैश्विक फ़ंक्शन ऐरे में_Cross फ़ंक्शन का उपयोग दो सूचक लाइनों के पार की स्थिति की गणना करने के लिए किया जाता है

  • फ़ंक्शन का कार्यान्वयन निम्न कोड के समान हैः

    यह ध्यान देने योग्य है किarr1यह एक त्वरित लाइन सूचकांक सरणी के रूप में परिभाषित है।arr2एक धीमी रेखा सूचकांक सरणी के रूप में परिभाषित,_Crossफ़ंक्शन एक सकारात्मक मान लौटाता है, यानी दस्तावेज़ के अनुसार正数为上穿周期, 负数表示下穿的周期, 0指当前价格一样इस समय,arr1ऊपर जाओarr2अब तक n चक्र हो चुके हैं, इस समय तेज लाइन पर धीमी लाइन का प्रतिनिधित्व करने वाला स्वर्ण कांटा है। वैसे ही_Crossयदि फ़ंक्शन नकारात्मक संख्या देता है, तो यह एक मृत कांटा है।

    यदि परिभाषितarr1यह एक बहुत ही अच्छा तरीका है।arr2फास्टलाइन के लिए, इसके विपरीत है।_Crossफ़ंक्शन का लौटाया गया मान एक धनात्मक संख्या है जो एक मृत कांटा का प्रतिनिधित्व करता है।_Crossफ़ंक्शन का लौटाया गया मान ऋणात्मक है, जो कि सोने के कांटे का प्रतिनिधित्व करता है।

// 返回上穿的周期数,正数为上穿周数,负数表示下穿的周数,0指当前价格一样
$.Cross = function(arr1, arr2) {            // 参数个数为2个,从参数名可以看出,这两个参数应该都是数组类型,数组就
                                            // 好比是在X轴为数组索引值,Y轴为指标值的坐标系中的线段,该函数就是判断两条线的 交叉情况 
    if (arr1.length !== arr2.length) {      // 首先要判断比较的两个数组长度是否相等
        throw "array length not equal";     // 如果不相等抛出错误,对于不相等的指标线无法判断相交
    }
    var n = 0;                              // 声明变量n用来记录交叉状态,初始0,未相交 
    for (var i = arr1.length-1; i >= 0; i--) {      // 遍历数组arr1,遍历顺序为从最后一个元素向前遍历
        if (typeof(arr1[i]) !== 'number' || typeof(arr2[i]) !== 'number') { // 当arr1或者arr2任何一个数组为非数值类型(即无效指标)时,跳出遍历循环
            break;                                  // 跳出循环
        }
        if (arr1[i] < arr2[i]) {                    // 如果arr1小于arr2则n--,会记录开始时arr1、arr2的相对状态,(即开始时n会根据arr1[i]、arr2[i]相对大小自行调整,一旦出现另一种和n状态相反的arr1[i]、arr2[i]大小关系,即发生了两条线交叉。)
            if (n > 0) {
                break;
            }
            n--;
        } else if (arr1[i] > arr2[i]) {             // 如果arr1大于arr2则n++
            if (n < 0) {
                break;
            }
            n++;
        } else {                                    // arr1[i] == arr2[i],则立即跳出
            break;
        }
    }
    return n;                                       // 返回n值,代表已经交叉了多少周期,0即指标值相等
};
  • हम इस पैरामीटर में डेटा के एक सेट का अनुकरण करते हैं और देखते हैं कि क्या होता है।

var arr1 = [1,2,3,4,5,6,8,8,9]     // 快线指标
var arr2 = [2,3,4,5,6,7,7,7,7]     // 慢线指标
function main(){
    Log("_Cross(arr1, arr2) : ", _Cross(arr1, arr2))
    Log("_Cross(arr2, arr1) : ", _Cross(arr2, arr1))
}

img

आप देख सकते हैं कि परिणाम 3 है, -3 है।

img

जैसा कि चित्र में देखा जा सकता है, क्रॉसिंग की स्थिति तीन K-लाइन कॉलम से पहले होती है।


अधिक

अल्फास्ट्रैटेजी00एक्सजब कोई क्रॉस नहीं होता है, तो यह 0 लौटाता है, है ना?

और एक छोटा सा पालक भी।और अगर हम वापस आते हैं तो?

छोटे सपनेठीक है, हम इस पर विचार करते हैं।

अल्फास्ट्रैटेजी00एक्सधन्यवाद जवाब के लिए! मेरा मतलब है, 0 वापस करना उचित है, है ना?

छोटे सपने`` var arr1 = [1,2,3,4,5,6,8,8,9] // त्वरित संकेतक var arr2 = [2,3,4,5,6,7,7,7] // धीमी रेखा संकेतक function main (() { Log (("_Cross ((arr1, arr2) ": ", _Cross ((arr1, arr2)) Log (("_Cross ((arr2, arr1) ": ", _Cross ((arr2, arr1)) } `` आप इस सेट का उपयोग कर सकते हैं एक गैर-क्रॉसिंग सरणी सेट करने के लिए, और चलाने के लिए. परीक्षण किया गया है और 0 नहीं लौटाता है.

छोटे सपनेकेवल हाल के क्रॉसिंग का पता लगाने के लिए, स्रोत विश्लेषण देखें।