以茅台和五粮液研究配对交易策略

2023-11-22 03:20

本文主要是介绍以茅台和五粮液研究配对交易策略,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

“”"
以茅台和五粮液研究配对交易策略
以茅台和五粮液近4年的行情,分析出两者之间的线性关系,根据y=ax+b+ζ公式,计算出ζ值,ζ趋向于零,表示y和x具有稳定性,ζ过大或者ζ过小,都具有套利机会,ζ都具有回归到零的机会。

“”"
#抓取茅台和五粮液近4年的行情

mt=ts.get_k_data('600519',start='2015-01-01',end='2019-12-31',ktype='D')[['date','close']]
wly=ts.get_k_data('000858',start='2015-01-01',end='2019-12-31',ktype='D')['close']
data=pd.concat([mt,wly],axis=1)
data.set_index('date',inplace=True)
data.index=pd.to_datetime(data.index)
data.columns=(['600519','000858'])#简单地看看两者的价格走势
data.plot(figsize=(10,6))

在这里插入图片描述

#计算出方差和协方差的矩阵 ,计算相关性,并显示出来

data.corr(method='pearson')
plt.figure(figsize=(10,8))
plt.title('Stock Correlation')
plt.plot(data['600519'],data['000858'],'.')
plt.xlabel('600519')
plt.ylabel('000858')
data.dropna(inplace=True)

#从图上可以看出,两者具有很强的相关性。

在这里插入图片描述

#根据y=ax+b+ζ公式,计算ζ值(spread),寻找套利空间,通过图显示出来

[slope,intercept]=np.polyfit(data.iloc[:,0],data.iloc[:,1],1).round(2)
data['spread']=data.iloc[:,1]-slope*data.iloc[:,0]-intercept
plt.figure(figsize=(10,8))
plt.title('Price Spread')
plt.plot(data['spread'])

在这里插入图片描述

#对ζ值(spread)进行标准化并图表显示出来

data['zscore']=(data['spread']-data['spread'].mean())/data['spread'].std()
data['zscore'].plot(figsize=(10,8),title='Zscore')
plt.axhline(1.5)
plt.axhline(0)
plt.axhline(-1.5)

#计算交易信号点,当一个做多的时候,另外一个做空(不过中国股票不可以做空,只能获得单边收益,这里假设可以做空).ζ值(spread)标准化后的值,按±2的位置为开仓点位,±0.5之内为平仓点位的策略。

data['trading_point_1']=np.where(data['zscore']>2,1,np.nan)
data['trading_point_1']=np.where(data['zscore']<-2,-1,data['trading_point_1'])
data['trading_point_1']=np.where(abs(data['zscore'])<0.5,0,data['trading_point_1'])
data['trading_point_1']=data['trading_point_1'].fillna(method='ffill')
data['trading_point_2']=-np.sign(data['trading_point_1'])

#统计策略中两股票的年化总收益并可视化显示

data['returns_mt']=np.log(data['600519']/data['600519'].shift(1))
data['returns_wly']=np.log(data['000858']/data['000858'].shift(1))
data['strategy']=data['600519'].mean()/(data['600519'].mean()+data['000858'].mean())*data['returns_mt'].shift(1)*data['trading_point_1']+data['000858'].mean()/(data['600519'].mean()+data['000858'].mean())*data['returns_wly'].shift(1)*data['trading_point_2']
data[['returns_mt','returns_wly','strategy']].dropna().cumsum().apply(np.exp).plot(figsize=(10,8),title='Strategy_returns')

#从收益图上看,有两倍以上的收益。

在这里插入图片描述

“”"
可实盘对多只ETF进行配对交易,这能获得实际的收益;
当用于分析的公司本质上发生改变,使得不会再回归了,从而使策略实效,并产生亏损;
ζ值(spread)需要不断的迭代;
还需要考虑交易成本和其他成本

“”"

这篇关于以茅台和五粮液研究配对交易策略的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/407117

相关文章

Redis过期删除机制与内存淘汰策略的解析指南

《Redis过期删除机制与内存淘汰策略的解析指南》在使用Redis构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下... 目录1、简述2、Redis http://www.chinasem.cn的过期删除策略(Key Expir

利用Python实现时间序列动量策略

《利用Python实现时间序列动量策略》时间序列动量策略作为量化交易领域中最为持久且被深入研究的策略类型之一,其核心理念相对简明:对于显示上升趋势的资产建立多头头寸,对于呈现下降趋势的资产建立空头头寸... 目录引言传统策略面临的风险管理挑战波动率调整机制:实现风险标准化策略实施的技术细节波动率调整的战略价

Redis中6种缓存更新策略详解

《Redis中6种缓存更新策略详解》Redis作为一款高性能的内存数据库,已经成为缓存层的首选解决方案,然而,使用缓存时最大的挑战在于保证缓存数据与底层数据源的一致性,本文将介绍Redis中6种缓存更... 目录引言策略一:Cache-Aside(旁路缓存)策略工作原理代码示例优缺点分析适用场景策略二:Re

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

SpringRetry重试机制之@Retryable注解与重试策略详解

《SpringRetry重试机制之@Retryable注解与重试策略详解》本文将详细介绍SpringRetry的重试机制,特别是@Retryable注解的使用及各种重试策略的配置,帮助开发者构建更加健... 目录引言一、SpringRetry基础知识二、启用SpringRetry三、@Retryable注解

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable

SpringBoot如何通过Map实现策略模式

《SpringBoot如何通过Map实现策略模式》策略模式是一种行为设计模式,它允许在运行时选择算法的行为,在Spring框架中,我们可以利用@Resource注解和Map集合来优雅地实现策略模式,这... 目录前言底层机制解析Spring的集合类型自动装配@Resource注解的行为实现原理使用直接使用M

Redis 内存淘汰策略深度解析(最新推荐)

《Redis内存淘汰策略深度解析(最新推荐)》本文详细探讨了Redis的内存淘汰策略、实现原理、适用场景及最佳实践,介绍了八种内存淘汰策略,包括noeviction、LRU、LFU、TTL、Rand... 目录一、 内存淘汰策略概述二、内存淘汰策略详解2.1 ​noeviction(不淘汰)​2.2 ​LR