Python玩转金融时间序列之ARCH与GARCH模型

01 引言

作为金融时间序列的专题推文,【手把手教你】时间序列之日期处理主要介绍了使用Python处理时间序列的日期和统计分析;【Python量化基础】时间序列的自相关性与平稳性主要介绍了时间序列的一些基础概念,包括自相关性、偏自相关性、白噪声和平稳性;而【手把手教你】使用Python玩转金融时间序列模型主要介绍了AR、MA、ARMA和ARIMA模型的基本原理与Python的实现。从上一篇推文不难看出,使用ARMA等模型对股票收益率的时间序列建模效果不是很理想,主要在于忽略了时间序列的异方差和波动聚集特性。所谓波动性聚集,是指金融时间序列的波动具有大波动接着大波动,小波动接着小波动的特征,即波峰和波谷具有连续性。ARCH和GARCH模型正是基于条件异方差和波动聚集的特性建模的。本次推文着重介绍 ARCH和GARCH模型的基本原理及其Python实现。

02 股票收益率时间序列特点

在介绍ARCH和GARCH模型之前,我们先来看看金融资产收益率的时间序列有哪些比较突出的特点。仍然以沪深300指数为例,考察其收益率时间的分布和统计特性。下面的Python代码与上一篇推文类似,包括导入需要用到的库、定义画图函数和使用tushare获取数据等。遇到问题没人解答,小编创建了一个Python学习交流裙:五二八 三九七 六一七, 寻找有志同道合的小伙伴,互帮互助,群里还有不错的学习视频教程和PDF电子书分享!

import pandas as pd

import numpy as np

import statsmodels.tsa.api as smt

#tsa为Time Series analysis缩写

import statsmodels.api as sm

import scipy.stats as scs

from arch import arch_model

#画图

import matplotlib.pyplot as plt

import matplotlib as mpl

%matplotlib inline

#正常显示画图时出现的中文和负号

from pylab import mpl

mpl.rcParams['font.sans-serif']=['SimHei']

mpl.rcParams['axes.unicode_minus']=False

def ts_plot(data, lags=None,title=''):

if not isinstance(data, pd.Series):

data = pd.Series(data)

#matplotlib官方提供了五种不同的图形风格,

#包括bmh、ggplot、dark_background、

#fivethirtyeight和grayscale

with plt.style.context('ggplot'):

fig = plt.figure(figsize=(10, 8))

layout = (3, 2)

ts_ax = plt.subplot2grid(layout, (0, 0))

acf_ax = plt.subplot2grid(layout, (1, 0))

pacf_ax = plt.subplot2grid(layout, (1, 1))

qq_ax = plt.subplot2grid(layout, (2, 0))

pp_ax = plt.subplot2grid(layout, (2, 1))

data.plot(ax=ts_ax)

ts_ax.set_title(title+'时序图')

smt.graphics.plot_acf(data, lags=lags,

ax=acf_ax, alpha=0.5)

acf_ax.set_title('自相关系数')

smt.graphics.plot_pacf(data, lags=lags,

ax=pacf_ax, alpha=0.5)

pacf_ax.set_title('偏自相关系数')

sm.qqplot(data, line='s', ax=qq_ax)

qq_ax.set_title('QQ 图')

scs.probplot(data, sparams=(data.mean(),

data.std()), plot=pp_ax)

pp_ax.set_title('PP 图')

plt.tight_layout()

return

使用tushare获取沪深300交易数据

import tushare as ts

token='输入你的token'

pro=ts.pro_api(token)

  • 22
    点赞
  • 262
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
好的,下面是一个基本的Python实现copula-DCC-GARCH模型的示例代码,供您参考: ``` import numpy as np import pandas as pd import arch from arch import arch_model from scipy.stats import norm from scipy.stats import t from scipy.optimize import minimize from copulae import GaussianCopula # 读取数据 data = pd.read_csv('data.csv') # 计算收益率 returns = np.log(data['Close']).diff().dropna() # 初始化GARCH模型 am = arch_model(returns, p=1, q=1, vol='GARCH') # 拟合GARCH模型 res = am.fit(disp='off') # 计算预测方差 volatility = res.conditional_volatility # 计算标准化残差 standardized_residuals = res.resid / volatility # 计算相关矩阵 corr_matrix = np.corrcoef(standardized_residuals.T) # 初始化copula copula = GaussianCopula(corr_matrix) # 拟合copula-DCC-GARCH模型 def dcc_garch_likelihood(parameters): omega = parameters[0] alpha = parameters[1] beta = parameters[2] gamma = parameters[3] df = parameters[4] copula_corr = copula.fit([norm.cdf(standardized_residuals[:,0]), norm.cdf(standardized_residuals[:,1])])[0][1] dcc_corr = arch.dcc_garch(omega=omega, alpha=alpha, beta=beta, gamma=gamma, corr0=copula_corr, nobs=len(returns), vol='GARCH', dist='t', df=df, resids=standardized_residuals, options={'maxiter':1000}) dcc_volatility = dcc_corr.conditional_volatility dcc_loglikelihood = np.sum(t.logpdf(standardized_residuals, df, loc=0, scale=dcc_volatility)) return -dcc_loglikelihood # 最小化似然函数 initial_params = np.array([0.01, 0.1, 0.85, 0.1, 10.0]) results = minimize(dcc_garch_likelihood, initial_params, method='L-BFGS-B', bounds=((0, None), (0, None), (0, 1), (0, 1), (2.1, None))) # 输出结果 omega = results.x[0] alpha = results.x[1] beta = results.x[2] gamma = results.x[3] df = results.x[4] print('omega: ', omega) print('alpha: ', alpha) print('beta: ', beta) print('gamma: ', gamma) print('df: ', df) ``` 这个代码示例使用了arch包和copulae包。首先,使用arch包计算收益率,并拟合GARCH模型,计算预测方差和标准化残差。然后,计算标准化残差的相关矩阵,并使用copulae包拟合Gaussian copula。最后,定义一个似然函数,使用scipy.optimize包最小化该函数,得到copula-DCC-GARCH模型的参数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值