引言:
邢不行的系列帖子“量化小讲堂”,通过实际案例教初学者使用python进行量化投资,了解行业研究方向,希望能对大家有帮助。
【历史文章汇总】请点击此处
【必读文章】EOS期现套利,一周时间,15%无风险收益
个人微信:coinquant,有问题欢迎交流。
文中用到的A股数据可在www.yucezhe.com下载,这里可以下载到所有股票、从上市日起的交易数据、财务数据、分钟数据、分笔数据、逐笔数据等。
平均趋向指标(ADX)策略在A股的实证
上一期量化小讲堂向大家介绍了简易波动指标(EMV)策略在A股的实证效果。本期将以平均趋向指标(ADX)策略为例,实证检验一下该策略在A股的实际效果。
—策略简介—
【平均趋向指标(ADX)】是由美国技术分析大师威尔斯•威尔德(Wells Wilder)所创造的,是一种中长期股市技术分析方法。ADX属于趋向指标DMI指标的一种,而DMI主要是通过分析股票价格在涨跌过程中买卖双方力量均衡点的变化情况,即多空双方的力量的变化受价格波动的影响而发生由均衡到失衡的循环过程,从而提供对趋势判断依据的一种技术指标。
在大多数指标中,绝大部分都是以每一日的收盘价的走势及涨跌幅的累计数来计算出不同的分析数据,其不足之处在于忽略了每一日的高低之间的波动幅度。而DMI指标则是把每日的高低波动的幅度因素计算在内,从而更加准确的反应行情的走势及更好的预测行情未来的发展变化,因此可以作为择时的判断依据。
本文采用的ADX策略的具体规则为:
第一步:若股票当日相对前日重心上移并且创新高,将最高点的价差记为hd;若重心下移并且创新低,将最低价的价差记为ld。即先计算当天最高价减去前一天最高价(记为a)和前一天的最低价减去当天最低价(记为b),如果a>0并且a>b,则hd=a,否则hd取0;同理,如果b>0且b>a,则ld=b,否则ld取0。
第二步:计算真实涨跌幅TR【TR是A、B、C绝对值中的数值最大者】,先分别计算以下三项:
A、当日的最高价减去当日的最低价。
B、当日的最高价减去前一日的收盘价。
C、当日的最低价减去前一日的收盘价。
第三步:计算pdi和mdi,pdi(+DI)为一段时间内hd的和/真实涨跌的和;mdi(-DI)为一段时间内ld的和/真实涨跌的和
第四步:当pdi上穿mdi,买入,信号为1;当pdi下穿mdi,卖空,信号为-1
—实战—
为了检验ADX策略在A股的实际效果,本文将该策略在所有A股都运行一遍。由于策略用不同的参数回测结果也不一样,因此对每只股票回测时都遍历一遍参数,选择使超额收益率最大的参数作为该股票的最优参数。具体步骤如下:
一、遍历数据文件夹中所有股票文件的文件名,得到股票代码列表
用python提取股票历史数据文件夹下每个股票对应的文件名(即股票代码)并存放到一个列表里,这样就得到了所有A股的代码列表。
接着遍历股票代码的列表,读取每只股票的历史数据。
二、计算股票的后复权价格
在读取某只股票的历史数据后,为了回测结果的可靠性,本文重新计算了复权后的开盘价、收盘价、最高价和最低价,后面计算指标值和涨跌幅都以复权后的数据为基础。有些上市不久的股票由于时间太短可能不具有代表性,因此本文在运行策略之前会先判断该股票上市至今的交易天数,剔除掉上市不到1年半的股票。
三、遍历参数进行回测
接着就是计算ADX策略的各项指标并给出每天的信号了,在计算指标时本文用到参数范围是n取10到30,步长为2。即遍历该范围内的所有参数,每一参数都会输出对应的每天的信号,根据买卖信号,可以得到每天的仓位,进而可以得到资金曲线及相关的回测指标(相关内容可参考量化小讲堂http://bbs.pinggu.org/thread-4745852-1-1.html)。在得到所有参数的回测结果后,根据超额收益率大小进行排序,选择使超额收益最大的参数作为该股票的最优参数,并将相应数据存入csv文件。
四、最后,在遍历完所有A股后,我们可以得到每只股票在最优参数下使用ADX策略的回测结果,并和股票的年化收益及最大回撤做了一下对比。
本文希望通过对ADX策略的实际操作,向大家介绍pandas的以下几个功能的运用:
1. 滚动求和函数rolling_sum()函数的用法
2. 时间序列超前滞后函数shift()函数的用法
3. 空值填充函数fillna()函数的用法
—程序—
要运行策略,需要所有A股的历史交易数据,在www.yucezhe.com可以下载到所有股票历史至今的数据。如下图所示,每一行是每一天的数据:
数据有以下的字段:
【code】股票的代码,上证股票以sh开头,深证股票以sz开头
【date】交易日期
【open】开盘价
【high】最高价
【low】最低价
【close】收盘价
【change】涨跌幅,复权之后的真实涨跌幅,保证准确
【volume】成交量
【money】成交额
【traded_market_value】流通市值
【market_value】总市值
【turnover】换手率,成交量/流通股本
【adjust_price】后复权价,复权开始时间为股票上市日,精确到小数点后10位
【report_date】最近一期财务报告实际发布的日期
【report_type】最近一期财务报告的类型,3-31对应一季报,6-30对应半年报。 9-30对应三季报,12-31对应年报
【PE_TTM】最近12个月市盈率,股价 / 最近12个月归属母公司的每股收益TTM
【PS_TTM】最近12个月市销率, 股价 / 最近12个月每股营业收入
【PC_TTM】最近12个月市现率, 股价 / 最近12个月每股经营现金流
【PB】市净率,股价 / 最近期财报每股净资产
下面是代码的截图,代码里面有详细的注释,有问题可以留言,附件中有程序的源码,回复即可下载。
这是最后回测结果的部分截图:
运行该策略的一共有2607只股票,其中,策略年化收益大于股票本身年化收益的有2056只个股,占比大概为78.9%,而年化收益除以最大回撤绝对值能超过股票本身的有2346只个股,大概占90%。可以看出,ADX指标的效果还可以。大家有其他一些技术指标也可以尝试一下,看看效果如何,只需要将第一部分信号产生方式改成自己的策略逻辑就可以了。
对本文研究有自己的想法的朋友,欢迎在评论区留言。关于文中的代码、数据,以及下期《量化小讲堂》想了解的内容,也可以加我个人微信coinquant交流。
如果你想入门量化,但是始终找不到方向,可以加入我的知识星球。我会在里面解答你的问题,分享我的感悟,不论是投资、技术,还是职业选择、思维方式。
-- 学习和成长从来都不是一个人的事 --