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. #ifdef和#if defined的差别

    注意两者都有个define的作用,区别在于使用方式上.前者的通常用法是:#ifdef  XXX .... #else .... #endif 只能在两者中选择是否有定义.对于后者,常用法是: #if ...

  2. flask 上下文管理 &源码剖析

    基本流程概述 - 与django相比是两种不同的实现方式. - django/tornado是通过传参数形式实现 - 而flask是通过上下文管理, 两种都可以实现,只不实现的方式不一样罢了. - 上 ...

  3. C++中定义NULL的头文件

    NULL不是C语言基本类型,其定义在stddef.h文件中,作为最基本的语言依赖宏存在.但是随着C/C++的发展,很多文件只要涉及了系统或者标准操作都会将NULL作为标准宏声明或者包含.所以几乎包含任 ...

  4. c++第二十三天

    p124~p126: 算数运算符 1.形如+ -(一元) * / % + -(二元)为算数运算符. 2.所有算数运算符都满足左结合律. 3.算数运算符的运算对象和求值结果都是右值. 4.在表达式求值之 ...

  5. 前端学习笔记之HTML/CSS 速写神器 Emmet

    HTML/CSS 速写神器:Emmet 在前端开发的过程中,一个最繁琐的工作就是写 HTML.CSS 代码.数量繁多的标签.属性.尖括号.标签闭合等,让前端们甚是苦恼.于是,我向大家推荐 Emmet, ...

  6. 课堂练习——Hash 20162305

    课堂练习--Hash 20162305 课堂练习要求 利用除留余数法为下列关键字集合的存储设计hash函数,并画出分别用开放寻址法和拉链法解决冲突得到的空间存储状态(散列因子取0.75) 关键字集合: ...

  7. [微信开发] - 从最新的appid,appsecret读取配置信息

    设置好form表单,填写参数传入Java后端做为实例bean,接着存储倒数据库. 当微信端接口配置提交时,Java接口从数据库获取最新的配置信息,可以根据increaseID,也可以设置时间段, 这里 ...

  8. UVa 11732 strcmp()函数(左孩子右兄弟表示法)

    #include<iostream> #include<algorithm> #include<string> #include<cstring> #i ...

  9. springboot 日期类型处理

    1. 日期类型输出参数处理 默认日期格式只支持:2017-07-01T10:10:01 修改为2017-07-01 10:10:01 只需要修改配置文件即可: spring: jackson: dat ...

  10. QWebEngineView_CssVariables

    1.测试代码,参考网址:http://blog.sina.com.cn/s/blog_1508519340102wgq0.html 2.测试下来,结果: 2.1.Qt5.6开始,没有 WebKit了. ...