前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MATLAB用GARCH-EVT-Copula极值理论模型VaR预测分析股票投资组合|附代码数据

MATLAB用GARCH-EVT-Copula极值理论模型VaR预测分析股票投资组合|附代码数据

原创
作者头像
拓端
发布2023-04-19 00:29:49
3110
发布2023-04-19 00:29:49
举报
文章被收录于专栏:拓端tecdat

全文链接:http://tecdat.cn/?p=30426

最近我们被客户要求撰写关于GARCH-EVT-Copula的研究报告,包括一些图形和统计输出。

对VaR计算方法的改进,以更好的度量开放式基金的风险。本项目把基金所持股票看成是一个投资组合,引入Copula来描述多只股票间的非线性相关性,构建多元GARCH-EVT-Copula模型来度量开放式基金的风险,并与其他VaR估计方法的预测结果进行比较

其次是将VaR引入到基金业绩评价中,构造RAROC指标来评价基金业绩,检验该评价指标的可行性。

GARCH-EVT-Copula 模型

首先用GARCH族模型拟合单项资产收益率,并提取标准化残差以满足极值理论的假设前提,接着对标准化残差的上下尾部分采用EVT理论中的广义帕累托分布GPD拟合,中间部分采用高斯核函数来估计其经验累积分布函数,从而得到标准化残差的边缘分布函数 。然后选取适当的Copula 函数,构造多元标准化残差间的相关结构和联合分布函数。

Copula 函数参数估计

本项目中,采用 伪极大似然估计(CML) 方法来估计 Copula 函数的参数 第一步,将金融资产对数收益率数据x通过经验分布函数转化为均匀变量(uniform variates) 第二步,利用密度似然函数估计Copula函数的参数:

图片
图片

GARCH-EVT-Copula 模型计算 VaR

本项目将开放式基金看做是一个资产组合,以每只基金所持有的股票收益率为研究对象,从投资组合的角度利用多元GARCH-EVT-Copula模型来计算基金的VaR值。

图片
图片

读取数据

图片
图片
代码语言:javascript
复制
[NUM,TXT,RAW]=xlsread('data')

Data=NUM

function [ output_args ] = GEC( input_args )

建立 GARCH 模型

代码语言:javascript
复制
nIndices = size(Data,2); % # 基金数量

spec(1:nIndices) = garchset('Distribution' , 'T' , 'Display', 'off', ...

'VarianceModel', 'GJR', 'P', 1, 'Q', 1, 'R', 1);%对每只基金设置garch模型的

残差自相关性检验

代码语言:javascript
复制
%残差自相关性检验

figure, subplot(2,1,1)

plot(residuals(:,1))

xlabel('时间'), ylabel('残差'), title ('N225收益率残差')
图片
图片

根据 FHS 提取标准化残差

代码语言:javascript
复制
title('N225标准化残差自相关图')

subplot(2,1,2)

autocorr(residuals(:,1).^2)
图片
图片
01
图片
图片

02

图片
图片

03

图片
图片

04

图片
图片

GDAXI

代码语言:javascript
复制
%残差自相关性检验

figure, subplot(2,1,1)

plot(residuals(:,2))
图片
图片
图片
图片

GSPC

图片
图片

FCHI

代码语言:javascript
复制
%残差自相关性检验

figure, subplot(2,1,1)

plot(residuals(:,4))
图片
图片

根据 FHS 提取标准化残差

图片
图片

采用 EVT 理论对标准残差估计累计分布函数

代码语言:javascript
复制
% Estimate the Semi-Parametric CDFs

nPoints= 200; % # of sampled points of kernel-smoothed CDF需要拟合的样本点

tailFraction = 0.1; % Decimal fraction of residuals allocated to each tail 小数保存位数

plot(y, (OBJ{index}.cdf(y + Q(2)) - P(2))/P(1))

[F,x] = ecdf(y); % empirical CDF

hold('on'); stairs(x, F, 'r'); grid('on')

legend('拟合的广义 Pareto 累计分布函数','经验累积分布函数','Location','SouthEast');

xlabel('Exceedance'); ylabel('Probability');

title(['标准化残差序列',num2str(index),'的上尾']);
图片
图片
代码语言:javascript
复制
for i=1:242

VaRp(i,:)=pPrice(i+T-242)*exp(VaR(i,:));

end

%%

figure

plot(1:242,pPrice(T-242+2:end),'r-',1:242,VaRp(1:242,1),'g-',1:242,VaRp(1:242,2),'b-',1:242,VaRp(1:242,3),'y-');

title('基金持股收盘价实际与 VaR 预测下限走势图')
图片
图片
代码语言:javascript
复制
plot(1:242, b(:,s),'go-',x,d,'ro',1:0.25:250,0,'b');

legend('未突破 VaR 预测下限','突破 VaR 预测下限','Location','Best' )

title('基金实际持股收盘价与 VaR 预测下限差额')

xlabel('时间日期')

ylabel('差额');
图片
图片
图片
图片
图片
图片
图片
图片
图片
图片
图片
图片
图片
图片
图片
图片

收益率t分布%QQ图

图片
图片
图片
图片
图片
图片
图片
图片
图片
图片
图片
图片

N225收益率平方自相关图和偏相关图

图片
图片

图片
图片

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 全文链接:http://tecdat.cn/?p=30426
  • GARCH-EVT-Copula 模型
  • Copula 函数参数估计
  • GARCH-EVT-Copula 模型计算 VaR
  • 读取数据
  • 建立 GARCH 模型
    • 残差自相关性检验
    • 根据 FHS 提取标准化残差
      • GDAXI
      • GSPC
      • FCHI
        • 根据 FHS 提取标准化残差
        • 采用 EVT 理论对标准残差估计累计分布函数
        • 收益率t分布%QQ图
        • N225收益率平方自相关图和偏相关图
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档