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

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

相关文章

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

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

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

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

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Deepseek使用指南与提问优化策略方式

《Deepseek使用指南与提问优化策略方式》本文介绍了DeepSeek语义搜索引擎的核心功能、集成方法及优化提问策略,通过自然语言处理和机器学习提供精准搜索结果,适用于智能客服、知识库检索等领域... 目录序言1. DeepSeek 概述2. DeepSeek 的集成与使用2.1 DeepSeek API

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

SpringBoot中的404错误:原因、影响及解决策略

《SpringBoot中的404错误:原因、影响及解决策略》本文详细介绍了SpringBoot中404错误的出现原因、影响以及处理策略,404错误常见于URL路径错误、控制器配置问题、静态资源配置错误... 目录Spring Boot中的404错误:原因、影响及处理策略404错误的出现原因1. URL路径错

Redis多种内存淘汰策略及配置技巧分享

《Redis多种内存淘汰策略及配置技巧分享》本文介绍了Redis内存满时的淘汰机制,包括内存淘汰机制的概念,Redis提供的8种淘汰策略(如noeviction、volatile-lru等)及其适用场... 目录前言一、什么是 Redis 的内存淘汰机制?二、Redis 内存淘汰策略1. pythonnoe

Python 中 requests 与 aiohttp 在实际项目中的选择策略详解

《Python中requests与aiohttp在实际项目中的选择策略详解》本文主要介绍了Python爬虫开发中常用的两个库requests和aiohttp的使用方法及其区别,通过实际项目案... 目录一、requests 库二、aiohttp 库三、requests 和 aiohttp 的比较四、requ

Redis过期键删除策略解读

《Redis过期键删除策略解读》Redis通过惰性删除策略和定期删除策略来管理过期键,惰性删除策略在键被访问时检查是否过期并删除,节省CPU开销但可能导致过期键滞留,定期删除策略定期扫描并删除过期键,... 目录1.Redis使用两种不同的策略来删除过期键,分别是惰性删除策略和定期删除策略1.1惰性删除策略

关于Java内存访问重排序的研究

《关于Java内存访问重排序的研究》文章主要介绍了重排序现象及其在多线程编程中的影响,包括内存可见性问题和Java内存模型中对重排序的规则... 目录什么是重排序重排序图解重排序实验as-if-serial语义内存访问重排序与内存可见性内存访问重排序与Java内存模型重排序示意表内存屏障内存屏障示意表Int