pybacktest 的疑点

第(一)节“教程”原文,是用 ipython notebook 写成,程序代码是一些片段组成。

为了阅读方便,合并在一起。

本文转载于:http://blog.csdn.net/lawme/article/details/51773744

  1. import pybacktest
  2. import pandas as pd
  3. ohlc = pybacktest.load_from_yahoo('SPY')
  4. ohlc.tail()
  5. short_ma = 50
  6. long_ma = 200
  7. ms = pandas.rolling_mean(ohlc.C, short_ma)
  8. ml = pandas.rolling_mean(ohlc.C, long_ma)
  9. buy = cover = (ms > ml) & (ms.shift() < ml.shift())  # ma cross up
  10. sell = short = (ms < ml) & (ms.shift() > ml.shift())  # ma cross down
  11. print '>  Short MA\n%s\n' % ms.tail()
  12. print '>  Long MA\n%s\n' % ml.tail()
  13. print '>  Buy/Cover signals\n%s\n' % buy.tail()
  14. print '>  Short/Sell signals\n%s\n' % sell.tail()
  15. bt = pybacktest.Backtest(locals(), 'ma_cross')
  16. print filter(lambda x: not x.startswith('_'), dir(bt))
  17. print '\n>  bt.signals\n%s' % bt.signals.tail()
  18. print '\n>  bt.trades\n%s' % bt.trades.tail()
  19. print '\n>  bt.positions\n%s' % bt.positions.tail()
  20. print '\n>  bt.equity\n%s' % bt.equity.tail()
  21. print '\n>  bt.trade_price\n%s' % bt.trade_price.tail()
  22. bt.summary()
  23. figsize(10, 5)
  24. bt.plot_equity()
  25. bt.plot_trades()
  26. pandas.rolling_mean(ohlc.C, short_ma).plot(c='green')
  27. pandas.rolling_mean(ohlc.C, long_ma).plot(c='blue')
  28. legend(loc='upper left')
  29. bt.trdplot['2004':'2007']
  30. pandas.rolling_mean(ohlc.C['2004':'2007'], short_ma).plot(c='green')
  31. pandas.rolling_mean(ohlc.C['2004':'2007'], long_ma).plot(c='blue')

从源码和教程来看,pybacktest 用法的确简单。

但教程中有几句,没有看懂。例如以下2句:

  1. figsize(10, 5)
  2. legend(loc='upper left')

不知道这两个函数出自何处,且有时能通过“编译”,有时却不行。

原因后来找到了。因为代码是在ipython notebook中,

若有“魔术命令”%pylab inline 这两个函数可以直接调用。

该例程虽未显式使用%pylab inline,但可能notebook对它有默认设置。

更有趣的是,数据源只能直接取自yahoo,如:

  1. ohlc = pybacktest.load_from_yahoo('SPY')

如果把ohlc存成csv文件,然后再读入内存,并进行格式规整,如:

  1. ohlc.to_csv('SPY.csv')
  2. ohlc = pd.read_csv('SPY.csv')
  3. ohlc.index = ohlc['Date']
  4. del ohlc['Date']

这时,虽然数据格式完全一致,但程序会出错,运行失败。

问题的原因可能是,yahoo直接传回的DataFrame,包含属性tz,即time zone,

pybacktest的运算逻辑,需要处理tz这个属性。但是,从csv文件读出的DataFrame

没有tz这个属性,因此造成程序异常中断。

还有,程序运行得出的回测结果,是什么含意,没看懂。

Backtest('ma_cross', 2013-28-04 23:14:15 MSK) performance summary
=================================================================
backtest:
days: 6348
from: '1994-09-14 00:00:00'
to: '2012-01-31 00:00:00'
trades: 17
exposure:
holding periods:
max: 1476 days, 0:00:00
median: 354 days, 0:00:00
min: 7 days, 0:00:00
trades/month: 1.0625
performance:
PF: 4.017
RF: 6.1555
averages:
gain: 23.817
loss: -8.47
trade: 10.5224
payoff: 2.8119
profit: 178.88
winrate: 0.5882
risk/return profile:
UPI: 1.0656
WCDD (monte-carlo 0.99 quantile): 52.09
maxdd: 74.67
sharpe: 0.4485
sortino: 1.6792

回测框架pybacktest简介(二)的更多相关文章

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

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

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

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

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

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

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

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

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

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

  6. 量化框架zipline--分钟回测改写

    转自:http://www.cnblogs.com/dxf813/p/7845398.html 基于zipline的分钟回测改写,其中数据源为自定义,使用bcolz的ctable,该数据格式与pand ...

  7. WeQuant比特币交易策略回测记录

    程序参数 PARAMS = { "start_time": "2017-02-01 00:00:00", "end_time": " ...

  8. scrapy爬虫框架教程(二)-- 爬取豆瓣电影TOP250

    scrapy爬虫框架教程(二)-- 爬取豆瓣电影TOP250 前言 经过上一篇教程我们已经大致了解了Scrapy的基本情况,并写了一个简单的小demo.这次我会以爬取豆瓣电影TOP250为例进一步为大 ...

  9. 用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建二:配置MyBatis 并测试(1 构建目录环境和依赖)

    引言:在用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建一   的基础上 继续进行项目搭建 该部分的主要目的是测通MyBatis 及Spring-dao ...

随机推荐

  1. 分布式存储之MogileFS基于Nginx实现负载均衡(Nginx+MogileFS)

    MogileFS分布式文件系统特点: 1.具有raid的性能 2.不存在单点故障 3.简单的命名空间: 每个文件对应一个key:用于domain定义名称空间 4.不共享任何数据 5.传输中立,无特殊协 ...

  2. spring-data-jpa 介绍 复杂查询,包括多表关联,分页,排序等

    本篇进行Spring-data-jpa的介绍,几乎涵盖该框架的所有方面,在日常的开发当中,基本上能满足所有需求.这里不讲解JPA和Spring-data-jpa单独使用,所有的内容都是在和Spring ...

  3. 20155305乔磊2016-2017-2《Java程序设计》第九周学习总结

    20155305 2016-2017-2 <Java程序设计>第九周学习总结 教材学习内容总结 JDBC入门 JDBC简介 1.JDBC是java联机数据库的标准规范,它定义了一组标准类与 ...

  4. presto-cli通过hive查询hdfs

    1.  启动hive metastore 2. 启动hive thrift接口 参考:http://www.cnblogs.com/kisf/p/7497261.html 3. 下载presto se ...

  5. 20145105 《Java程序设计》第5周学习总结

    20145105 <Java程序设计>第5周学习总结 教材学习内容总结 第八章 异常处理 一.语法与继承架构 (一)使用try.catch 执行流程 尝试执行try区块中程序代码 如果出现 ...

  6. Window 常用系统变量

    转载:http://www.slyar.com/blog/envionment-variables.html 转载:http://blog.csdn.net/wuliusir/article/deta ...

  7. Using SQLXML Bulk Load in the .NET Environment

    http://msdn.microsoft.com/en-us/library/ms171878.aspx 1.首先创建一张表 CREATE TABLE Ord ( OrderID ,) PRIMAR ...

  8. about SpringBoot学习后记

    <SpringBoot实战>第一章节入门的名称为Spring风云再起 看起来Spring的功能确实受Java开发者喜爱 在SpringBoot中,继续将Spring框架做了另一次的封装使框 ...

  9. G_M_C_美食节

    美食节 题解:学习了动态加边,可以说是进一步理解了网络流.具体思路就是考虑每一道菜,如果这是该位厨师最后一次做,那么等待时间就是做这道菜的时间,如果是倒数第二次做,就要两倍时间(目前做了一次,后面还有 ...

  10. 使用IDEA创建基于Gradle构建的JavaWeb项目

    环境配置 jdk: 1.8 Gradle: 4.4.1 Tomcat: 9.0.0 One Step! 创建项目,初始化项目结构. 打开我们的IDEA,进入创建项目的界面,勾选Java,Web两个选项 ...