公式系统 - TradeBlazer公式基础 - Bar数据
Bar数据
在介绍Bar数据之前,首先,我们需要讨论一下TradeBlazer公式的计算方法,针对上面介绍的各种公式类型,包含公式应用,在公式进行计算时,都是建立在基本数据源(Bar数据)之上,我们这里所谓的Bar数据,是指商品在不同周期下形成的序列数据,在单独的每个Bar上面包含开盘价、收盘价、最高价、最低价、成交量及时间。期货等品种还有持仓量等数据。
所有的Bar按照不同周期组合,并按照时间从先到后进行排列,由此形成为序列数据,整个序列称之为Bar数据。
以下列出所有的Bar数据系统函数:
函数名 | 简写 | 描述 |
Date | D | 当前Bar的日期。 |
Time | T | 当前Bar的时间。 |
Open | O | 当前Bar的开盘价。 |
High | H | 当前Bar的最高价,Tick时为当时的委卖价。 |
Low | L | 当前Bar的最低价,Tick时为当时的委买价。 |
Close | C | 当前Bar的收盘价。 |
Vol | V | 当前Bar的成交量。 |
OpenInt | 无 | 当前Bar的持仓量。 |
CurrentBar | 无 | 当前Bar的索引值,从0开始计数。 |
BarStatus | 无 | 当前Bar的状态值,0表示为第一个Bar,1表示为中间的普通Bar,2表示最后一个Bar。 |
计算方法
TradeBlazer公式在计算时按照Bar数据的Bar数目,从第一个Bar到最后一个Bar,依次进行计算,如果公式中出现了调用Bar数据函数的,则取出当前Bar的相应值,进行运算。如下图箭头所示,公式执行从上至下,Bar从左到右执行。
例如,现在有如下语句需要执行,Bar数据如下表所示:
Value1 = Close - Open;
CurrentBar | Date | Time | Open | High | Low | Close | Vol | OpenInt | Value1 |
0 | 2005/04/04 | 15:00 | 2970 | 2979 | 2951 | 2974 | 18 | 78 | 4 |
1 | 2005/04/05 | 15:00 | 2960 | 2960 | 2946 | 2960 | 14 | 76 | 0 |
2 | 2005/04/06 | 15:00 | 2951 | 2980 | 2951 | 2963 | 30 | 74 | 12 |
3 | 2005/04/07 | 15:00 | 3048 | 3048 | 2968 | 2995 | 120 | 84 | -53 |
4 | 2005/04/08 | 15:00 | 2985 | 2987 | 2985 | 2987 | 10 | 80 | 2 |
... | ... | ... | ... | ... | ... | ... | ... | ... | ... |
如上表所示,从CurrentBar = 0 开始,依次计算每个Bar进行计算;
在公式的编写中,经常会遇到当前Bar的数据和上一个Bar,上N个Bar数据进行比较,计算的情况,针对这种情况,TradeBlazer公式提供了一种处理机制:回溯。即对数据的向前引用,比如,获取上一个Bar的收盘价:Close[1],获取10天前的成交量:Vol[10]。以下提供一个简单的例子来说明如何进行回溯处理。
假定有如下语句:
If (Close > Close[1]) { Buy(1,Close); }
以上公式执行一个简单的操作,当前Bar的收盘价大于上一个Bar的收盘价,即执行按照当前收盘价买入1手的动作。根据上表的数据,公式将在CurrentBar为2和3的时候调用Buy指令。
如果您足够仔细的话,您会发现:对于上面的一段公式的执行,有一个小小的问题,当第一次计算公式时,即CurrentBar = 0时,这个时候需要获取上一个Bar的数据,但是当前Bar已经是第一个Bar,这个时候就存在着问题,如何来获取此时的Close[1]呢,TradeBlazer公式将默认Close[1]为无效值,即系统函数中的InvalidNumeric,Close > Close[1]的表达式计算结果是一个Bool值,其结果也是一个无效值,对于Bool值,我们将False作为其无效值。因此,第一个Bar计算时,Buy指令不会被执行。
对于技术分析这类公式来说,假定Bar数据的总数共有100,相同的代码将从CurrentBar = 0到CurrentBar = 99 共执行100遍,分别输出公式中的结果值。