以文本方式查看主题 - 金字塔客服中心 - 专业程序化交易软件提供商 (http://weistock.com/bbs/index.asp) -- 高级功能研发区 (http://weistock.com/bbs/list.asp?boardid=5) ---- 用VBA写的EMA函数,好像不行啊,请老大提示一下啊: (http://weistock.com/bbs/dispbbs.asp?boardid=5&id=2060) |
-- 作者:msedu -- 发布时间:2010/7/7 18:51:31 -- 用VBA写的EMA函数,好像不行啊,请老大提示一下啊: Function Ema2(Formula,N) \'-------------------------------- Set History=Formula.ParentGrid.GetHistoryData() \'----------------------------- \'如果有效数据不足,则返回值为:0,并退出函数 If History.Count<N Then Ema2=0 Exit Function End If \'-------------------------------- If N>=1 THEN Y=(2*History.Close(N-1)+(N-1)*Ema2(N-1))/(N+1) Else Y=0 End If \'返回值 Ema2=Y End Function |
-- 作者:msedu -- 发布时间:2010/7/7 22:30:52 -- “后台下单模板”,可用于各种模型。不会写后台模型的塔友,以后不用写了,复制此模板即OK 又写了一个,还是不对呢!
\'自定义Ema函数 |
-- 作者:admin -- 发布时间:2010/7/7 23:10:09 -- 等我有空帮你改改吧,你的逻辑有严重问题 |
-- 作者:admin -- 发布时间:2010/7/8 0:39:54 -- 有个问题你没说清楚,Ema2是你的自定义函数,还是你做的VBA的一个另外的函数,如果是VBA的函数,那么你需要说明Ema2的N是什么?周期? |
-- 作者:msedu -- 发布时间:2010/7/8 10:19:10 -- 呵呵,老大,是这样的呢,我本来是要在VBA里写一个EMA,供其他Function使用的,但是我先在自定义函数里写一个,试验一下,N,是就是周期,没错呢,:-)
呵呵,快帮帮忙呀,:-) |
-- 作者:admin -- 发布时间:2010/7/8 12:19:36 -- CYC是表示取第周期的值, N是EMA函数里的N Function EMA3(Formula,CYC,N)
如果创建一个自定义函数EMA2 Function EMA2(Formula,N)
公式里这些调用测试 aa:ema(close,30);
与系统EMA结果完全一致 [此贴子已经被作者于2010-7-8 12:21:46编辑过]
|
-- 作者:msedu -- 发布时间:2010/7/8 13:22:20 -- 明白了,理解完全错误啊。。。 谢谢老大啊,俺,又学了一招,:-) |
-- 作者:圆周工作室 -- 发布时间:2010/10/13 17:21:13 -- 感谢 admin
本来让错误搞的一头雾水,看完才明白原来所有数据都要从头遍历一遍
以前只是像MA计算一样,只是用固定周期的数据,得出的结果很不一致,现在一致了
|