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


金字塔客服中心 - 专业程序化交易软件提供商金字塔软件金字塔软件问题提交 → 跨周期时用全局变量数据库传递数据有个小bug

   

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


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

主题:跨周期时用全局变量数据库传递数据有个小bug

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


加好友 发短信
等级:论坛游侠 帖子:514 积分:2695 威望:0 精华:0 注册:2011/3/4 18:24:01
跨周期时用全局变量数据库传递数据有个小bug  发帖心情 Post By:2012/6/10 19:22:03 [只看该作者]

公式1 运行在日线下,若干数据用EXTGBDATASET存入全局变量;

公式2 运行在1分钟下,用EXTGBDATA读取公式1存入的全局变量;

 

为了驱动公式1运行,我在公式2里加一句  zvol:="公式1.vol##day";  (假设这个数据我刚好也用得上)

 

此时公式2得到从公式1传递过来的全局变量数据,是慢了一天的数值,查了我好久……

终于发现,非得在公式2里再加一句 jclose:="公式1.close#day"; (即只用1个#号)才能得到准确日期的数据传递。

 

我取昨天vol,是为了驱动公式1运行起来,既然跑起来了,不应该在乎我是借取昨天数据还是借取今天数据驱动起来的,公式1都应该跟公式2的运行日期准确对应。

 

我这样传递数据有特殊原因,上面只是举例说明,跨周期的时间指针有个小bug, 特此向老大们报告下。

[此贴子已经被作者于2012-6-10 19:25:20编辑过]

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


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

你把你完整可表现此问题的公式发来我们测试一下看看吧


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

金字塔-技术部

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

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

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


加好友 发短信
等级:论坛游侠 帖子:514 积分:2695 威望:0 精华:0 注册:2011/3/4 18:24:01
  发帖心情 Post By:2012/6/10 19:41:23 [只看该作者]

给你现成编一个。

公式1:

 

EXTGBDATASET('日开盘价',open);

 

 

公式2:

zvol:="公式1.vol##day";

oo:EXTGBDATA('日开盘价');

 

 

这样你就可以测试到了。

王峰同志是老板吗?这么勤奋,周日也值班,值得嘉奖!

[此贴子已经被作者于2012-6-10 19:44:45编辑过]

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


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

 zvol:="公式1.vol##day"; 

 

本身你加了2个#,就是引用的前一个数据,这就是金字塔的跨周期指标调用规范啊



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

金字塔-技术部

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

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

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


加好友 发短信
等级:论坛游侠 帖子:514 积分:2695 威望:0 精华:0 注册:2011/3/4 18:24:01
  发帖心情 Post By:2012/6/11 8:40:20 [只看该作者]

我说的是 '日开盘价' 这个数据也慢了1天。


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


加好友 发短信 大哥
等级:超级版主 帖子:2837 积分:13237 威望:0 精华:2 注册:2010/7/14 17:31:54
  发帖心情 Post By:2012/6/11 9:09:33 [只看该作者]

2个# 代表取 被调用周期的之前的一个数据
1个# 代表取 被调用的周期的数据


这个是金字塔的语法规则 不是BUG


金字塔—专业程序化交易量化投资平台

客户服务部

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

欢迎您参加我公司的技术培训,具体培训需求请发邮件到

service@weistock.com

您的宝贵建议或者投诉,请发往邮箱:weiwei@weistock.com

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


加好友 发短信
等级:论坛游侠 帖子:514 积分:2695 威望:0 精华:0 注册:2011/3/4 18:24:01
  发帖心情 Post By:2012/6/11 10:48:36 [只看该作者]

哈哈,你肯定是熬夜没睡好,辛苦了!

看清楚了,你不要看zvol,只看oo;

 

公式1:

EXTGBDATASET('日开盘价',open);

 

公式2:

zvol1:="公式1.vol#day";

zvol2:="公式1.vol##day";

oo:EXTGBDATA('日开盘价');

 

 

以上情况下,oo的数值是错误的。

改一下公式后:

 

公式1:

EXTGBDATASET('日开盘价',open);

 

公式2:

zvol2:="公式1.vol##day";

zvol1:="公式1.vol#day";

oo:EXTGBDATA('日开盘价');

 

这个时候oo是正确的。

 


 回到顶部