楼主: uxn790159
957 0

[实际应用] 求教R语言做模型比较(EWMA和HS等),怎么实现test window起始日固定在2008.01.01? [推广有奖]

  • 1关注
  • 0粉丝

本科生

53%

还不是VIP/贵宾

-

威望
0
论坛币
1082 个
通用积分
45.5000
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
344 点
帖子
70
精华
0
在线时间
27 小时
注册时间
2020-10-3
最后登录
2024-4-3

楼主
uxn790159 发表于 2021-3-24 01:26:31 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
以下是部分代码

rm(list=ls())

library(tseries)   
library(fGarch)
#library(rugarch)
library(zoo)

source("ind_test.R")
source("bern_test.R")

# data
p = get.hist.quote(instrument = "^djc", start = "2000-01-30",end="2017-11-01",quote="Close",quiet=T)
y=diff(log(p))      
y=coredata(y)


# Set backtest up
TT = length(y)      
WE = 500          # est. window
p = 0.05          # probability level
l1 = WE*p         # location of "-VaR(p)" in a WE-dimensional distribution
value = 1;        # portfolio value

# initialize forecasts matrix (will use 4 models)
VaR = matrix(nrow=TT,ncol=4)  

# EWMA parameters
lambda = 0.94;
s11 = var(y[1:30]);    # initialisation of sigma^2
for(t in 2:WE) s11 = lambda * s11 + (1-lambda) * y[t-1]^2 # this stops at WE

# Running the backtest
for (t in (WE+1):TT){
  t1 = t-WE;         # start of the data window
  t2 = t-1;          # end of the data window
  window = y[t1:t2]  # data for estimation
  # ewma
  s11   = lambda * s11  + (1-lambda) * y[t-1]^2 # this starts at WE+1
  VaR[t,1] = -qnorm(p) * sqrt(s11) * value
  # ma
  VaR[t,2] = - qnorm(p)* sd(window) * value
  # hs
  ys = sort(window)         
  VaR[t,3] = -ys[l1]*value  
  
  # garch(1,1)
  g=garchFit(formula = ~ garch (1,1), window ,trace=FALSE, include.mean=FALSE)
  par=g@fit$matcoef        
  s4=par[1]+par[2]*window[WE]^2+par[3]*g@h.t[WE]   # h.t is cond variance
  VaR[t,4] = -qnorm(p) * sqrt(s4) * value # garch(1,1) VaR
}
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:Window wind test EWMA Est

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-9 06:07