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


金字塔客服中心 - 专业程序化交易软件提供商金字塔软件高级功能研发区 → 用VBA写的EMA函数,好像不行啊,请老大提示一下啊:

   

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


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

主题:用VBA写的EMA函数,好像不行啊,请老大提示一下啊:

帅哥,在线噢!
admin
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:7302 积分:32559 威望:1000 精华:45 注册:2003/12/30 16:34:32
  发帖心情 Post By:2010/7/7 23:10:09 [显示全部帖子]

等我有空帮你改改吧,你的逻辑有严重问题


 回到顶部
帅哥,在线噢!
admin
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:7302 积分:32559 威望:1000 精华:45 注册:2003/12/30 16:34:32
  发帖心情 Post By:2010/7/8 0:39:54 [显示全部帖子]

有个问题你没说清楚,Ema2是你的自定义函数,还是你做的VBA的一个另外的函数,如果是VBA的函数,那么你需要说明Ema2的N是什么?周期?

 回到顶部
帅哥,在线噢!
admin
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:7302 积分:32559 威望:1000 精华:45 注册:2003/12/30 16:34:32
  发帖心情 Post By:2010/7/8 12:19:36 [显示全部帖子]

CYC是表示取第周期的值, N是EMA函数里的N

Function EMA3(Formula,CYC,N)
    Set History=Formula.ParentGrid.GetHistoryData()
 Y=History.Close(0)
 For i=1 To CYC
  Y=(2*History.Close(i)+(N-1)*Y)/(N+1)
 Next
 Ema3=Y
End Function

 

如果创建一个自定义函数EMA2

Function EMA2(Formula,N)
    EMA2 = EMA3(formula,formula.indexdata,n)
End Function

 

公式里这些调用测试

aa:ema(close,30);
bb:ema2(30);

 

与系统EMA结果完全一致

[此贴子已经被作者于2010-7-8 12:21:46编辑过]

 回到顶部