以文本方式查看主题 - 金字塔客服中心 - 专业程序化交易软件提供商 (http://weistock.com/bbs/index.asp) -- 公式模型编写问题提交 (http://weistock.com/bbs/list.asp?boardid=4) ---- 如何找出数组中与其他值之差<0.02的次数最多的那个值? (http://weistock.com/bbs/dispbbs.asp?boardid=4&id=66999) |
-- 作者:yanxc -- 发布时间:2014/7/5 14:05:03 -- 如何找出数组中与其他值之差<0.02的次数最多的那个值? 斜率:=(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 -- 发布时间:2014/7/5 14:06:15 -- 这样写 好象不行
斜率:=(H-ref(H,1))/ref(H1,1); variable:ss=0,kk=0; 斜率差:=0.002;
|
-- 作者:yanxc -- 发布时间:2014/7/6 15:08:22 -- 看看 |
-- 作者:jinzhe -- 发布时间:2014/7/7 9:27:09 -- 我记得我写的时候是没用数组的,你自己加的?
|
-- 作者:yanxc -- 发布时间:2014/7/7 15:33:49 -- 对。你没有用数组。 但你的写法不对,你是找出哪一个值距离其他值都在0.002之内。 而实际情况是很多时候没有一个值符合要求。只能找出最接近要求的那一个数值,才行…… |
-- 作者:jinzhe -- 发布时间:2014/7/7 15:47:22 -- 对于这种情况,已经超过你给的定义了,所以不能再往后写了, 你发帖到高级区问问 |
-- 作者:yanxc -- 发布时间:2014/7/7 17:46:07 -- 以下是引用jinzhe在2014/7/7 15:47:22的发言:
对于这种情况,已经超过你给的定义了,所以不能再往后写了, 你发帖到高级区问问 倒是没超过我给的定义 一直就这么说的…… |
-- 作者:jinzhe -- 发布时间:2014/7/8 11:03:44 --
ss:=0;kk:=1;tt:=0; if x1<>ss then begin if x2=ss and x2<>0 then begin if x2>ss then begin if x3=ss and x3<>0 then begin if x3>ss then begin if x4=ss and x4<>0 then begin if x4>ss then begin if x5=ss and x5<>0 then begin if x5>ss then begin
|
-- 作者:yanxc -- 发布时间:2014/7/8 14:00:23 -- 非常感谢。比较接近了,我把各差加上 abs 后不少算对。 |