В процессе загрузки ресурсов... загрузка...

Встроенная функция_переходный анализ и инструкции

Автор:Нинабадасс., Создано: 2022-03-23 08:56:29, Обновлено: 2022-03-24 16:54:30

Встроенная функция_переходный анализ и инструкции

Функция _Cross в столбце глобальных функций документации API используется для расчета перекрестного статуса двух линий показателей

  • Коды, такие как следующие, реализуются функцией:

    Следует отметить, что когдаarr1определяется как массив индикаторов скоростной линии, иarr2определяется как массив индикаторов медленной линии, значение, возвращаемое_Crossфункция является положительным числом, то есть, в соответствии с контекстом документацииa positive number is the upswing period, a negative number indicates the downswing period, and 0 means it is the same as the current price- Да. можно увидеть, что в это время,arr1пересекаетarr2в течение n циклов, а именно быстрая линия пересекает медленную линию, что указывает на золотой крест. Аналогичным образом, если_CrossФункция возвращает отрицательное число, это означает крест смерти.

    Если ` `arr1is defined as an array of slow line indicators, andarr2as an array of fast line indicators, the situation will be opposite. If the value returned by the_Кроссfunction is a positive number, it means death cross. If the value returned by theФункция "Кросс" - это отрицательное число, это золотое кресто.

// Return the number of upswing periods; a positive number represents the number of upswing periods, and a negative number represents the number of downswing periods, and 0 means it is the same as the current price  
$.Cross = function(arr1, arr2) {            // The number of parameters is 2. As you can see from the parameter names, these two parameters should be of array type. 
                                            // The array is like a line segment in the coordinate system where the X axis is the array index value and the Y axis is the index value. The function is to determine the intersection of two lines
    if (arr1.length !== arr2.length) {      // First, judge whether the lengths of the two compared arrays are equal 
        throw "array length not equal";     // If they are not equal, raise an error, for the unequal indicator lines cannot judge if crossed or not 
    }
    var n = 0;                              // Declare the variable n to record the cross-status; its initial value is 0, indicating not crossed
    for (var i = arr1.length-1; i >= 0; i--) {      // Traverse arr1,from the last element to the front 
        if (typeof(arr1[i]) !== 'number' || typeof(arr2[i]) !== 'number') { // when arr1 or arr2 is non-numeric type (namely invalid indicators), break the traversing loop 
            break;                                  // break the loop 
        }
        if (arr1[i] < arr2[i]) {                    // If arr1 < arr2, the n-- will record the comparative status of arr1 and arr2 from the beginning (that is, at the beginning, n will adjust automatically according to the comparative value of arr1[i] and arr2[i]; once the comparison relation between arr1[i] and arr2[i] opposite to n happens, it means the two lines crossed). 
            if (n > 0) {
                break;
            }
            n--;
        } else if (arr1[i] > arr2[i]) {             // If arr1 > arr2, then n++
            if (n < 0) {
                break;
            }
            n++;
        } else {                                    // arr1[i] == arr2[i], then break immediately 
            break;
        }
    }
    return n;                                       // Return n, indicating the number of periods with cross, 0 means equal indicator values
};
  • Мы симулируем массив данных и передаем его, чтобы увидеть результаты.

var arr1 = [1,2,3,4,5,6,8,8,9]     // Fast line indicator
var arr2 = [2,3,4,5,6,7,7,7,7]     // Slow line indicator
function main(){
    Log("_Cross(arr1, arr2) : ", _Cross(arr1, arr2))
    Log("_Cross(arr2, arr1) : ", _Cross(arr2, arr1))
}

img

Вы можете видеть результаты 3 и -3.

Пересечение расположено перед тремя K-линейными прутками.


Больше