API文档中全局函数栏中的_Cross函数用来计算两条指标线的交叉状态
需要注意的是,arr1
定义为快线指标数组,arr2
定义为慢线指标数组时,
可知,此时```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)) } “`
可以看到结果为3、-3。
图中可以看到,交叉的位置发生在三个K线柱之前。
alphaStrategy00X 没有交叉的时候,应该返回0吧?
小韭菜来也 要是来回交叉呢?
发明者量化-小小梦 好的,这个我们考虑下。
alphaStrategy00X 谢谢回复!我的意思是说,返回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)) } ``` 可以用这个设置一组不交叉的数组,跑下。 测试了不会返回0
发明者量化-小小梦 只检测 最近一次交叉, 看源码分析 可得知。