请 [注册] 或 [登录]  | 返回主站

量化交易吧 /  量化平台 帖子:3366801 新帖:11

【API解析】策略运行频率(附隔固定时间运行方法)

我们棒棒哒发表于:5 月 10 日 03:06回复(1)

Img
量化平台不同于程序化交易软件, 许多地方都是用户可以自己定义的。

  • 在策略中数据频率和运行频率是两个不同的概念:
    运行频率可以理解为函数的调用频率,也就是您多久去看一眼K线图。

    数据频率可以理解为K线的级别,1m的K线,5m的K线或者日线。

    这两者之间并没有必然关系,可以在日级别的策略中提取5m的数据,也可以在分钟级别的策略中调用日K数据

  • 运行频率:从整个策略层面上讲,平台有三种不同粒度的频率,分别为(天,分钟,tick),频率的选择对策略的主要影响有:

1. 天级别:

(1).run_daily设置time='every_bar'时,设置的函数会在每天开盘时运行(具体开盘时间点和参考标的有关,默认为09:30)一次。

(2).handle_data的执行时间为09:30时执行一次。

(3).限价单挂单时的撮合发生在16:00,可能对资金使用有影响,所以不建议在天级别的策略中使用限价单。

2. 分钟级别

(1).run_daily设置time='every_bar'时,设置的函数会交易时间段的每个分钟运行一次。(交易时间段由参考标的决定,默认为股票的交易时间段)

(2).handle_data在股票的交易时间段中每分钟执行一次。

(3).限价单在每个bar都会撮合一次,账户信息等实时变动。

3. tick级别

(1).run_daily不能设置time='every_bar',如果设置,该函数不生效。

(2).handle_data不生效,应该使用handle_tick替代。

(3).handle_tick每个tick事件产生时都会被执行一遍,
比如一共订阅了两个标的A和B,在'09:31:23'这个点,A和B都产生了一条tick,那么handle_tick将被执行两次,handle_data(context,tick)中的tick对象将分别是A和B的current_tick。

(4).tick级别的策略暂不支持限价单。


当然,上边所提到的是平台提供的最基础的策略频率,大家也可以根据上述策略的最小粒度选择高于当前粒度的频率进行回测,最常用的就是定时器了。

自定义运行频率示例

一般来讲,自定义运行频率可以使用三种方法,一种就是通过定时器去判断执行次数,在一定的执行次数下再执行后边需要执行的代码;第二种是判断时间,当当前时间的分钟是某个数字的倍数时再运行,比如现在是09:50,50是10的倍数,执行,否则跳过;第三种是直接设置多个定时运行。

eg1. 定时器:

  def initialize(context): #这里选择策略频率为分钟,所以func函数每分钟都会执行一次run_daily(my_func, 'every_bar',reference_security='AG9999.XSGE')
    g.run_num = -1  #初始化计数器,不要在盘中开启策略

  def my_func(context):g.run_num  = 1if g.run_num!=15:  #如果这次运行的次数不是15,打断此次运行return       else:
        g.run_num=0  #条件满足,计数器归零,继续后边的代码print '后边的代码将每隔15分钟运行一次'

Img

eg2. 时间判断:

def initialize(context):run_daily(run_15m, 'every_bar',reference_security='AG1901.XSGE')def run_15m(context):if context.current_dt.minute != 0: #如果当前分钟不能整除15,打断此次运行returnprint '下边的代码每15m运行一次'

Img

eg3. 多个定时运行:

def initialize(context):run_time(30)#每30分钟运行一次def run_time(x):datas = get_price('000300.XSHG',count=240,frequency='1m').index.tolist()[:-1]#剔除15:00  times = [str(t)[-8:] for t in datas]  #提取交易时间times.insert(0,'09:30:00')  for t in times[::x]:
        run_daily(run_min, t)  #对某个函数设置多个运行时间点def run_min(context):'''需要运行的函数或代码放在这里'''print 'run'

Img

大于天级别的,我们可以借助run_monthly(每月运行一次)和run_weekdly(每周运行一次)去执行某个函数,也可以参考eg1的方法固定每X个交易日运行一次。


PS: 关于定时运行
常用的有几种运行方法:

  1. handle_data(context, data) :不需要设置,也并非必须,当定义了程序就会去调用它。一般用于股票策略(也可用于股指期货)。

  2. handle_tck(context, data) : 不需要进行设置,tick级别策略的专用函数,当定义了程序就会去调用它,每个tick时间发生时运行一次。

  3. run_daily(func,time,reference_security) :
    在初始化中进行设置,和handle_data二选一,非必须,在初始化中进行调用,func是函数名;

    time可以选择一个具体时间,也可以选择为'every_bar',当time='every_bar'时,设置的函数会在每个bar(分钟级策略为每分钟,天级别策略为每天开盘,tick级策略不运行)执行一次。

    reference_security为可选参数,代表交易时间的参考标的,当time='every_bar'时,运行时间受此影响(默认为股票交易时间)

    当然,调用run_daily时必须定义一个函数名和run_daily第一个参数相同的函数,且这个函数只接受一个参数:context

数据获取的粒度直接查看API文档说明就可以了,选择自己需要的frequency或者unit参数,数据获取函数API, 获取bar数据请使用get_bars。


全部回复

0/140

量化课程

    移动端课程