首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >alphalens教程1--整理好你的数据

alphalens教程1--整理好你的数据

作者头像
钱塘小甲子
发布2019-01-28 15:43:37
发布2019-01-28 15:43:37
5.3K00
代码可运行
举报
运行总次数:0
代码可运行

很久以前研究过这个,周末下大雨,整理一下子IDE里面的工程文件,发现了当时的测试demo,于是决定再来感受一下。

alphalens是quantopian下的三大quant利器这里,剩下两个是大名鼎鼎的zipline和pyfolio。alphalens是用于因子回测的,使用很方便,但是,最大的一个特点就是,函数的名称真是长啊!

安装就不说了,似乎pip就可以了。

万事开头难,中间也难,结尾更难。很多事确实是这样。

alphalens第一个难点就是把要测试的因子相关的数据整理成alphalens需要的那样。我们从alphalens的一个数据标准化函数说起。alphalens.get_clean_factor_and_forward_returns

函数定义如下:

代码语言:javascript
代码运行次数:0
运行
复制
def get_clean_factor_and_forward_returns(factor,
                                         prices,
                                         groupby=None,
                                         by_group=False,
                                         quantiles=5,
                                         bins=None,
                                         periods=(1, 5, 10),
                                         filter_zscore=20,
                                         groupby_labels=None):

我们来解释一下参数:

factor : pd.Series - MultiIndex

一个MultiIndex Series类型的数据,index分别是日期与资产名称,值是当天的alpha值。

prices : pd.DataFrame

通常是一个列数很多的dataframe的数据结构,如下图所示,列名是股票代码,index是日期。

groupby : pd.Series - MultiIndex or dict

groupby是一个MultiIndex 的series或者一个dict,通常用dict更加直观,而且这两者也是可以相互转换的。dict的key是股票的代码,值是所属行业的分类名词,不一定是数字也可以是别的。

还有一点,如果传入的是dict则默认测试周期中,行业的属性不变,如果使用Series则可以改变。

by_group : bool

如果是True,那么就按行业分类计算.

quantiles : int or sequence[float]

因子分层的设置,可以直接设置一个整数,把标的池均分成几个等分,也可以用一个列表,用来分不同的分层比例,例如 [0, .10, .5, .90, 1.] or [.05, .5, .95]

bins : int or sequence[float]

与quantiles一样,用于分层设置,不过是value策略。所以,两者直接只能选一个,另外一个必须设置为None

periods : sequence[int]

调仓周期设置

filter_zscore : int or float

设置收益率异常值的阈值为多少倍标准差

groupby_labels : dict

与groupby相互联系,例如之前是按照行业分类,而每个行业用数字表示,这里则可以在把数字映射到具体的行业。

所以,我们需要准备好上面这些输入的数据。

最后,我们来看一下这个函数的返回值。

返回值是pd.DataFrame - MultiIndex,包含每个调仓周期的收益率,因子值,所属group(这里是行业),以及分层的次序。

如果,我们整好数据,然后使用了这个函数获得返回值,那么,技术性难题已经解决了80%了。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017年06月25日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档