欢迎使用金字塔普通技术服务论坛,您可以在相关区域发表技术支持贴。
我司技术服务人员将优先处理 VIP客服论坛 服务贴,普通区问题处理速度慢,请耐心等待。谢谢您对我们的支持与理解。


金字塔客服中心 - 专业程序化交易软件提供商金字塔软件高级功能研发区 → 如何找出数组中与其他值之差<0.02的次数最多的那个值?

   

欢迎使用金字塔普通技术服务论坛,您可以在相关区域发表技术支持贴。
我司技术服务人员将优先处理 VIP客服论坛 服务贴,普通区问题处理速度慢,请耐心等待。谢谢您对我们的支持与理解。    


  共有3237人关注过本帖树形打印复制链接

主题:如何找出数组中与其他值之差<0.02的次数最多的那个值?

帅哥哟,离线,有人找我吗?
yanxc
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小飞侠 帖子:2046 积分:2707 威望:0 精华:1 注册:2011/6/14 14:49:49
如何找出数组中与其他值之差<0.02的次数最多的那个值?  发帖心情 Post By:2014/7/7 15:34:52 [只看该作者]


斜率:=(H-ref(H,1))/ref(H1,1);

前N天的斜率形成一个长度为N的数组,比如按IF日线,就是0.0060, 0.0042, 0.0048, 0.0018, -0.0022, 0.0066

 

现在想遍历数组中每个值与其它值的差,然后找出差<0.002的次数最多的那个值。

比如0.0048,就和其中3个数的差都小于0.002,因此就选出0.0060, 0.0042, 0.0048, 0.0066这4个次数都为3的值,求得它们的平均数为当前斜率。

而0.0018, -0.0022因为骗离其它值太远,就被抛弃了。

 

现在有简单的函数或算法,来实现这个目标吗?


 回到顶部
帅哥哟,离线,有人找我吗?
yanxc
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:小飞侠 帖子:2046 积分:2707 威望:0 精华:1 注册:2011/6/14 14:49:49
  发帖心情 Post By:2014/7/7 15:35:03 [只看该作者]

这样写 好象不行

 

斜率:=(H-ref(H,1))/ref(H1,1);

variable:ss=0,kk=0;
variable:A[5]=0;
hh:=斜率;
A[1]:=ref(hh,1);
A[2]:=ref(hh,2);
A[3]:=ref(hh,3);
A[4]:=ref(hh,4);
A[5]:=ref(hh,5);

斜率差:=0.002;
if count((hh-A)<=斜率差,6)>=4 then begin
      ss:=ss+hh;
      kk:=kk+1;
      end
if count((A[1]-A)<=斜率差,6)>=4 then begin
      ss:=ss+A[1];
      kk:=kk+1;
      end
if count((A[2]-A)<=斜率差,6)>=4 then begin
      ss:=ss+A[2];
      kk:=kk+1;
      end
if count((A[3]-A)<=斜率差,6)>=4 then begin
      ss:=ss+A[3];
      kk:=kk+1;
      end
if count((A[4]-A)<=斜率差,6)>=4 then begin
      ss:=ss+A[4];
      kk:=kk+1;
      end
if count((A[5]-A)<=斜率差,6)>=4 then begin
      ss:=ss+A[5];
      kk:=kk+1;
      end


当前斜率:ss/kk,colorgreen;


 回到顶部
帅哥哟,离线,有人找我吗?
王锋
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:罗宾汉 帖子:11808 积分:20695 威望:0 精华:10 注册:2009/8/18 8:15:13
  发帖心情 Post By:2014/7/7 18:04:35 [只看该作者]

你的需求过于复杂, 无法用简单的函数实现.

建议你还是多学习金字塔的单步跟踪调试吧, 逻辑复杂,殊无法帮你编写



金字塔—专业程序化软件提供商

金字塔-技术部

-----------------------------------------------------------------------------------------------------

工作时间:周一至周五 08:30 - 17:30   周末及法定节假日休息

Email:service@weistock.com
 回到顶部