转自:http://www.cnblogs.com/dxf813/p/7845398.html

基于zipline的分钟回测改写,其中数据源为自定义,使用bcolz的ctable,该数据格式与pandas的DataFrame很好兼容,并且bcolz文件压缩率很好。
以下主要记录此次改写回测整个过程中涉及类和方法,没有附带代码。

一,自定义分钟回测数据源BcolzBacktestMinData类
  def zk_get_min_data 取获得多只股票某个时间点前的N个指定字段的值
  def zk_get_value 获得股票的指定时间的某个字段的值
  def zk_get_traded_dt 获得离传入时间最近的交易时间点
  def zk_get_row_data 获得某只股票某个时间的k线数据
  def zk_get_all_data 回测初始时将所用数据全部缓存提供给以上函查询

以下为原有zipline代码改写部分:

一、TradingAlgorithm(回测主类)
  类中的函数改写:
  导入方法:from zipline.algorithm import TradingAlgorithm
  
  1、def order 下单函数
  2、def _create_clock 返回此次回测所有的时间点
  3、def _create_generator 产生每个时间点回测结果
  4、data_portal 属性实例化后重新赋值
  5、def _create_benchmark_source 获得基准收益
  6、def __convert_order_params_for_blotter 判断下单参数是否合理
  7、def _calculate_order_value_amount 计算下单的数量
  8、def _can_order_asset 判断该股票是否可交易

以下为上述5个加粗的函数或属性的重写内容(剩余3个变动较少):

一、order 此函数主要改写内容

  last_price 针对非限价单下单,使用当前价格成交通过zk_get_value获得
  更改下单数量:中国股市买入有基本单位1手=100股

二、_create_clock 函数返回一个MinuteSimulationClock对象

  导入路径:from zipline.gens.sim_engine import MinuteSimulationClock

  改写MinuteSimulationClock内容:
    def __init__ 去除分钟时间点的计算
    def __iter__ 返回已去除掉股市中午休息时间的各分钟时间点

 

三、_create_generator函数返回一个AlgorithmSimulator对象(self.trading_client)的transform()

  导入路径:from zipline.gens.tradesimulation import AlgorithmSimulator

  改写AlgorithmSimulator内容:
    def _create_bar_data:返回BarData对象 既回测代码中的data对象
      继续重写BarData类
      导入路径:from zipline.protocol import BarData
      内容:
        def __init__ 不变
        def current 截取zk_get_all_data的返回结果
        def history 调用data_portal的get_history_window函数
        def _get_current_minute 获得回测时当前的时间点
        def __getitem__ 调用zk_get_row_data执行返回的结果
        def __get__ 不变
        def current_dt 不变

四、data_portal属性为一个DataPortal对象

  导入路径:from zipline.data.data_portal import DataPortal

  改写DataPortal内容:
    def get_history_window data.history 调用的函数
    def get_backtest_date 自定义函数:将回测的结束日期传入,为了取出该回测所需要的所有数据并缓存
    equity_minute_reader 实例化时传入的BcolzMinuteBarReader对象

      导入路径:from zipline.data.minute_bars import BcolzMinuteBarReader

      继续重写BcolzMinuteBarReader类(该类主要功能为读取分钟k线数据)内容:
        def get_value 调用zk_get_value      
        def_get_metadata 此函数原方法为通过指定的bcloz文件路径来读取数据,我已用自定义的数据源取代,所以此处不再做处理
        def get_last_traded_dt 调用zk_get_traded_dt

五、_create_benchmark_source函数返回一个BenchmarkSource对象

  导入路径:from zipline.sources.benchmark_source import BenchmarkSource

  改写BenchmarkSource内容:
    def __init__ 改写分钟收益的数据序列
    由于我只拿到每天的收益率,而此处zipline默认会让每天收益的数据填充到每分钟上转为分钟的收益序列,这意味着每分钟都会有该天的盈利或亏损(根据后续zipline计算收益的算法)
    这就导致了复利。根据界面显示需要我们也只需要计算出每天的收益即可,没有计算每分钟的收益,因此我将每天的收益率只填充到开始的第一个时间点,后续的全部填充0

量化框架zipline--分钟回测改写的更多相关文章

  1. 量化投资策略:常见的几种Python回测框架(库)

    量化投资策略:常见的几种Python回测框架(库) 原文地址:http://blog.csdn.net/lawme/article/details/51454237 本文章为转载文章.这段时间在研究量 ...

  2. OnePy--构建属于自己的量化回测框架

    本文主要记录我构建量化回测系统的学习历程. 被遗弃的项目:Chandlercjy/OnePy_Old 新更新中的项目:Chandlercjy/OnePy 目录 1. 那究竟应该学习哪种编程语言比较好呢 ...

  3. 手把手教你用Python搭建自己的量化回测框架【均值回归策略】

    手把手教你用Python搭建自己的量化回测框架[均值回归策略] 引言 大部分量化策略都可以归类为均值回归与动量策略.事实上,只有当股票价格是均值回归或趋势的,交易策略才能盈利.否则,价格是随机游走的, ...

  4. 量化投资学习笔记01——初识Pyalgotrade量化交易回测框架

    年初学习量化投资,一开始想自己从头写,还是受了C/C++的影响.结果困在了计算回测数据那里,结果老也不对,就暂时放下了.最近试了一下python的各个量化投资框架,发现一个能用的——pyalgotra ...

  5. FMZ发明者量化平台回测机制说明

    原文连接:https://www.fmz.com/digest-topic/4009 大部分策略在实盘之前都需要回测进行验证,FMZ支持部分品种数字货币现货.期货和永续合约,以及商品期货所有品种.但发 ...

  6. 量化投资:第8节 A股市场的回测

    作者: 阿布 阿布量化版权所有 未经允许 禁止转载 abu量化系统github地址(欢迎+star) 本节ipython notebook 之前的小节回测示例都是使用美股,本节示例A股市场的回测. 买 ...

  7. 量化交易回测系统---RQalpha、qstrade学习笔记

    一.RQalpha github 地址  https://github.com/ricequant/rqalpha 1.运行test.py文件,显示 No module named 'logbook. ...

  8. 回测框架pybacktest简介(一)

    pybacktest 教程 本教程让你快速了解 pybacktest's 的功能.为此,我们回测精典交易策略移动平均线MA交叉. MA快线上穿慢线时,买进做多 MA快线下穿慢线时,卖出做空 进场规则, ...

  9. 回测框架pybacktest简介(二)

    pybacktest 的疑点 第(一)节“教程”原文,是用 ipython notebook 写成,程序代码是一些片段组成. 为了阅读方便,合并在一起. 本文转载于:http://blog.csdn. ...

随机推荐

  1. java--补全诗句代码

    代码效果: 代码: import java.util.Scanner; /* 补全诗句 */ public class game1 { public static void main(String[] ...

  2. 在 Scale Up 中使用 Health Check - 每天5分钟玩转 Docker 容器技术(145)

    对于多副本应用,当执行 Scale Up 操作时,新副本会作为 backend 被添加到 Service 的负责均衡中,与已有副本一起处理客户的请求.考虑到应用启动通常都需要一个准备阶段,比如加载缓存 ...

  3. mybatis动态insert,update

    1. 动态update UPDATE ui.user_question_section_xref <set> reviewer = #{0}, score = #{1} , last_up ...

  4. 走近webpack(2)--css打包及压缩js

    前面的文章介绍了webpack的devServer以及多入口多出口文件的配置,咱们继续往下学. 在开始学习接下来的知识之前,我们先回顾一下,前文提到了webpack的简单配置方法,但是只详细说了下入口 ...

  5. 笔记:Spring Cloud Hystrix 服务容错保护

    由于每个单元都在不同的进程中运行,依赖通过远程调用的方式执行,这样就有可能因为网络原因或是依赖服务自身问题出现调用故障或延迟,而这些问题会直接导致调用方的对外服务也出现延迟,若此时调用方的请求不断增加 ...

  6. 笔记:MyBatis 动态SQL

    有时候,静态的SQL语句并不能满足应用程序的需求.我们可以根据一些条件,来动态地构建SQL语句.例如,在Web应用程序中,有可能有一些搜索界面,需要输入一个或多个选项,然后根据这些已选择的条件去执行检 ...

  7. 笔记:Hibernate 拦截器和事件

    Hibernate 在执行持久化的过程中,应用程序通常无法参与其中,通过事件框架,Hibernate 允许应用程序能响应特定的内部事件,从而允许实现某些通用的功能,或者对 Hibernate 进行扩展 ...

  8. ImageLoader 笔记

    BitmapFactory 我们不能够通过构造函数创建Bitmap对象.如果需要将图片转成Bitmap对象加载到内存中,就需要使用BitmapFactory类.BitmapFactory跟据图片数据源 ...

  9. Repository个人实践

    1.背景 最近,有空了,想着把之前一些乱七八糟的小项目给整理一下,尤其是涉及到Repository.UoW几处.为此,专门查阅了博客园中几个大神 关于Repository的实践,到最后都感觉依然莫衷一 ...

  10. curl 获取外网IP

    #curl http://members.3322.org/dyndns/getip121.204.134.10