pandas计算对冲比率

2023-11-20 15:10
文章标签 计算 pandas 比率 对冲

本文主要是介绍pandas计算对冲比率,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前置条件:

1. 以黄金白银主力合约为例

2. 数据

AU黄金数据:

链接:https://pan.baidu.com/s/1GfSWSvygp7lrAeckXK4ypw 
提取码:92l6

AG白银数据:

链接:https://pan.baidu.com/s/13RGpZmGyTQbONbOMlUnW5g 
提取码:r0oj

-------------------------------------------

对冲比率计算方法:

对冲比率 = 【黄金和白银的协方差】/【黄金的方差】

对冲比率 = Cov(黄金收益率,白银收益率)/Var(黄金收益率)

计算过程:

1. 将AG_main_pe.csv 和 AU_main_pe.csv 放到一个目录下

2. 在该目录下打开 jupyter notebook, 读入数据文件并根据日期对齐

import numpy as np
import pandas as pdag_file_path = r'./AG_main_pe.csv'
au_file_path = r'./AU_main_pe.csv'
ag_df = pd.read_csv(ag_file_path,encoding='utf-8')
au_df = pd.read_csv(au_file_path,encoding='utf-8')
ag_df = ag_df.loc[:,['date','ag_close','ag_pe']]
au_df = au_df.loc[:,['date','au_close','au_pe']]
ag_df['date'] = pd.to_datetime(ag_df['date'])
au_df['date'] = pd.to_datetime(au_df['date'])
two_df0 = pd.merge(ag_df,au_df,how='inner',on='date')
two_df0.sort_values(by='date',ascending=True,inplace=True)

3. 计算对冲比率

# 计算 AG和AU 的协方差
res_cov = two_df0.au_pe.cov(two_df0.ag_pe)
# 计算 AU 的方差
au_var = two_df0.au_pe.var()
# 对冲比率
final_res = res_cov/au_var
print('AG和AU的协方差',res_cov)
print('AU的方差',au_var)
print('对冲比率',final_res)
# 打印结果
# AG和AU的协方差 0.00011104459160659251
# AU的方差 8.258266462241457e-05
# 对冲比率 1.3446477189166988

至此,对冲比率计算完毕。

附加:

使用OLS计算对冲比率,OLS中所得的系数即是对冲比率。

在上面的代码中继续:

import statsmodels.api as sm
two_df0.dropna(inplace=True)
model01 = sm.OLS(two_df0['ag_pe'],sm.add_constant(two_df0['au_pe'])).fit()
model01.summary()

单独打印系数:

model01.params[1]
# 1.3440849961596375

这篇关于pandas计算对冲比率的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Pandas中多重索引技巧的实现

《Pandas中多重索引技巧的实现》Pandas中的多重索引功能强大,适用于处理多维数据,本文就来介绍一下多重索引技巧,具有一定的参考价值,感兴趣的可以了解一下... 目录1.多重索引概述2.多重索引的基本操作2.1 选择和切片多重索引2.2 交换层级与重设索引3.多重索引的高级操作3.1 多重索引的分组聚

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

在Pandas中进行数据重命名的方法示例

《在Pandas中进行数据重命名的方法示例》Pandas作为Python中最流行的数据处理库,提供了强大的数据操作功能,其中数据重命名是常见且基础的操作之一,本文将通过简洁明了的讲解和丰富的代码示例,... 目录一、引言二、Pandas rename方法简介三、列名重命名3.1 使用字典进行列名重命名3.编

Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南

《Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南》在日常数据处理工作中,我们经常需要将不同Excel文档中的数据整合到一个新的DataFrame中,以便进行进一步... 目录一、准备工作二、读取Excel文件三、数据叠加四、处理重复数据(可选)五、保存新DataFram

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

pandas数据过滤

Pandas 数据过滤方法 Pandas 提供了多种方法来过滤数据,可以根据不同的条件进行筛选。以下是一些常见的 Pandas 数据过滤方法,结合实例进行讲解,希望能帮你快速理解。 1. 基于条件筛选行 可以使用布尔索引来根据条件过滤行。 import pandas as pd# 创建示例数据data = {'Name': ['Alice', 'Bob', 'Charlie', 'Dav

XTU 1237 计算几何

题面: Magic Triangle Problem Description: Huangriq is a respectful acmer in ACM team of XTU because he brought the best place in regional contest in history of XTU. Huangriq works in a big compa