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


金字塔客服中心 - 专业程序化交易软件提供商金字塔软件高级功能研发区 → VBA策略回测时增加统计内容

   

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


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

主题:VBA策略回测时增加统计内容

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


加好友 发短信
等级:新手上路 帖子:43 积分:1 威望:0 精华:0 注册:2013/3/9 23:18:00
VBA策略回测时增加统计内容  发帖心情 Post By:2016/2/16 14:32:32 [只看该作者]

我想对某一交易信号的后续变化进行统计分析,比如在买入条件成立后,统计该信号后2、3、4、5根等K线的变化情况,并进行统计,请问用VBA怎么实现啊。

而卖出信号是卖出信号,不与上面的东西冲突。


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


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

请具体补充一下,你是需要在测评结束后对测评的结果再进一步加工呢,还是在VBA的测评过程中,取得某一个信号位置点,然后再去进一步统计?



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

金字塔-技术部

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

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

Email:service@weistock.com
 回到顶部
帅哥哟,离线,有人找我吗?
天涯doa
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:新手上路 帖子:43 积分:1 威望:0 精华:0 注册:2013/3/9 23:18:00
  发帖心情 Post By:2016/2/16 16:25:32 [只看该作者]

是在信号点出现后进行统计计算,然后在回测报告中给出结果

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


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

http://www.weistock.com/bbs/dispbbs.asp?boardid=5&Id=68896 以这里的范例4为例:

 

使用PEL策略的信号进行交易
For i = 0 to HistroyData.Count-1
if Formula.GetBufData("开多",i) = 1 And TestReport.Holding = 0 Then '开多
TestReport.Buy 1, HistroyData.Close(i)

在出现开多信号的控制语句中,你已经知道了HistroyData对象中的k线数据索引了,HistroyData.Close(i) 就是当前K线的收盘价 HistroyData.Close(i+1) 就是下跟K线的收盘价 
End if

if Formula.GetBufData("平多",i) = 1 And TestReport.Holding > 0 Then '平多
TestReport.Sell 0, HistroyData.Close(i)
End if


'显示测试时当前的资产
Application.msgout TestReport.ASSET

'为步进下一个数据做准备
TestReport.StepIt i
Next

 



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

金字塔-技术部

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

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

Email:service@weistock.com
 回到顶部
帅哥哟,离线,有人找我吗?
天涯doa
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:新手上路 帖子:43 积分:1 威望:0 精华:0 注册:2013/3/9 23:18:00
  发帖心情 Post By:2016/2/17 9:20:37 [只看该作者]

非常感谢! 还有一个问题 就是怎么添加多个测试数据 那个VBA的例子我看了 是一个一个添加的 想请教如何添加整个上证、深证里A股股票

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


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

TestReport.AddTestStock 函数前加入FOR循环指令即可。

遍历整个市场的品种参考

 

MarketData 对象

GetReportCount 得到指定市场的品种数量.例如:GetReportCount("SQ") 表示取上海期货交易所所有合约数量.如果调用失败返回-1.

GetReportDataByIndex 得到指定市场指定基于0索引的ReportData对象,该方法主要可以用来对整个市场的品种进行遍历.



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

金字塔-技术部

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

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

Email:service@weistock.com
 回到顶部