ML系列——主成分策略【附源码】

栏目: 数据库 · 发布时间: 5年前

内容简介:本文由BigQuant《量化研究每周精选》原创推出,版权归BigQuant所有,转载请注明出处。

ML系列——PCA特征组合

PCA方法简介

这个方法使用股票的历史量价数据,在N个股票的横截面上向前追溯M天。在原始的Avellaneda的论文中,他假设所有的横截面都是完全一致的,然而在实践中,这个假设是不靠谱的,比如沪深300的成分股会随着时间的变化而变化。

我们定义股票在任意给定的时间点上 t0 ,往前追溯M+1天的收益率矩阵:

ML系列——主成分策略【附源码】

其中 Sit 代表股票i在时间t上的复权价格, Δt=1/252 。因为股票收益的波动性,我们还需要将其进行标准化。

ML系列——主成分策略【附源码】

其中:

ML系列——主成分策略【附源码】

我们的经验相关系数矩阵定义如下:

ML系列——主成分策略【附源码】

在选用沪深300股票池的情况下, ρ 的维度是300x300,往往我们有用的数据量要远远小于我们需要估计的参数,在我们沪深300的具体例子里,参数数量是45150。事实上,如果我们考虑用每日收益数据,非常长的数据长度在实际中不一定有意义,市场的波动、股票的相关系数都在变动,那么其中一个选择就是使用滑动数据窗口。

一般比较常用的方法是对相关矩阵进行建模,我们对后验相关矩阵进行SVD分解得到特征值和特征向量,并按照如下顺序排列:

ML系列——主成分策略【附源码】

我们的特征向量也按照上述顺序排列:

ML系列——主成分策略【附源码】

我们来看下针对2017年沪深300的pca分解,来看下特征数量与方差解释程度的关系:

ML系列——主成分策略【附源码】

我们可以看到前三个特征向量解释了超过80%的变异方差。

我们称上述这些 λ1,⋯,λm,m

ML系列——主成分策略【附源码】

于是,每一个特征组合的收益率为:

ML系列——主成分策略【附源码】

们来分别看下前两个特征向量的组合构成,首先是第一个特征组合:

ML系列——主成分策略【附源码】

第二个特征组合:

ML系列——主成分策略【附源码】

根据论文的解释,特征组合之间的收益是不相关。每一只股票收益都可以被分解并投射到m个特征因子和残差上,于是PCA提供了一种很自然的方式构建风险因子。很容易,我们可以证明相关举证可以分解为一个秩为m的矩阵以及一个满秩的对角矩阵:

ML系列——主成分策略【附源码】

其中 δij 是Kronecker delta,

ML系列——主成分策略【附源码】

这意味着我们只需要少量显著的特征向量再加上一个对角的“噪音”矩阵就可以解释市场的总体方差。

策略实现逻辑

现在来介绍下我们的PCA策略实现逻辑。

因为PCA是非监督学习,主要是做特征的“映射”,所以我们不需要太长的历史数据,我们选取2016年到2017年底共两年的沪深300股票 前复权 数据。同时我们采用滚动训练的方式去训练我们的PCA,每次选取6个月的训练数据来训练模型,然后应用在后六个月的测试数据上,大致思路如下图所示:

ML系列——主成分策略【附源码】 每个训练期,我们都会更新指数列表,因为数据成分可能在这个期间内发生变化。然后我们还注意到历史越长的数据实际上对未来的影响关系越来越弱,所以我们会对股票收益率进行指数加权,以突出最近的数据权重。

最后就是在每个训练周期内,如何去选取特征向量的数量了,因为我们观察到在不同时间周期内,主成分数量对解释变异程度存在比较大的差异。所以我们采取动态调整的方式,我们选取70%的方差变异解释率作为阈值,每次只选取刚好大于70%的特征向量的数量,这样也有助于防止对噪音的拟合。还有一个小细节的就是我们发现在某些情况下,特征向量的绝对值会非常大,这导致我们的特征组合拥有难以置信的组合杠杆,所以我们也对单只股票最大杠杆率做了最高3倍的限制,最终的组合权重是这些被选特征组合的加权,所以总杠杆不会这么高,但是注意,我们最终的特征组合仍然是一个 多空组合

下图是我们在训练期上的表现: ML系列——主成分策略【附源码】

总结

本教程在很大程度上是对论文的复现,在实现的过程中也发现并总结了如下一些问题:

1.PCA对数据非常敏感,数据加权、数据长度的选取以及缺失数据的处理都会极大得影响模型结果。

2.特征向量解释称组合权重,在逻辑上存在一定的问题,并且我们的处理方式是全额投资,然而如果特征向量存在加总和为负的情况,也就是特征组合是一个净空头头寸,那么将无法用全额投资的方式去分配权重。

3.论文的假设少量的特征向量选取有助于获得超过基准组合,这个在理论上没有依据。

4.特征向量如果作为风险因子,同样会存在上述我说的敏感性问题。

参考文献

《Statistical Arbitrage in the U.S. Equities Market, Marco Avellaneda∗† and Jeong-Hyun Lee∗》

策略完整代码:《 ML系列——主成分策略

本文由BigQuant《量化研究每周精选》原创推出,版权归BigQuant所有,转载请注明出处。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C语言编程:一本全面的C语言入门教程(第三版)

C语言编程:一本全面的C语言入门教程(第三版)

(美)Stephen Kochan / 张小潘 / 电子社博文视点资讯有限公司 / 2006年 / 59.00元

本书是极负盛名的C语言入门经典教材,其第一版发行至今已有20年的历史。本书内容详实全面,由浅入深,示例丰富,并在每个章节后面附有部分习题,非常适合读者自学使用。除此之外,《C语言编程》一书对于C语言标准的最新进展、C语言常见开发工具以及管理C语言大型项目等重要方面,也进行了深入浅出的说明。一起来看看 《C语言编程:一本全面的C语言入门教程(第三版)》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具