APIドキュメントの全局関数アレンジ内の_Cross関数は,二つの指針線の交差状態を計算するために使用される.
海外のメディアは,arr1
速行指標の行列として定義されます.arr2
遅い線指標の行列として定義されるとき,_Cross
この関数で返される値は正数です.正数为上穿周期, 负数表示下穿的周期, 0指当前价格一样
この時点でarr1
上へarr2
速線がスローラインを代表する黄金フォークを代表する.
同じように_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))
}
答えは,3−−3です.
図では,交差点が3つのK線柱の前に起こるのが示されています.
アルファ戦略00X交差点がない場合は 0 を返します.
小さい菜も横断線を横断する場合はどうでしょう?
発明者 量化 - 微かな夢じゃあ,これを考えてみましょう.
アルファ戦略00X返信ありがとうございます. 0に戻す方が合理的でしょうか?
発明者 量化 - 微かな夢`` 速行指針が表示される. 遅い線指標は,この線を表示します. この関数で, ログ (("_Cross ((arr1,arr2) ":", _Cross ((arr1,arr2)) ログ (_Cross ((arr2,arr1)): ", _Cross ((arr2,arr1)) ありがとうございました. `` この設定で,交差しない配列をセットして実行します. テストは0を返しません.
発明者 量化 - 微かな夢ソースコード分析でわかる.