1

我正在尝试使用 R 中的包将两种马尔可夫切换模型拟合到对数返回的时间序列。MSwM我正在考虑的模型是只有截距的回归模型和 AR(1) 模型。这是我正在使用的代码:

library(tseries)

#Prices
ftse<-get.hist.quote(instrument="^FTSE", start="1984-01-03", end="2014-01-01", quote="AdjClose", compression="m")

#Log-returns
ftse.ret<-diff(log(ftse))

library(MSwM)

#Model with only intercept
mod<-lm(ftse.ret ~ 1)

#Fit regime-switching model
msmFit(mod, k=2, sw=c(T,T), p=0, data=ftse.ret)

#AR(1) model
mod<-lm(ftse.ret[2:360] ~ ftse.ret[1:359])

#Fit regime-switching model
msmFit(mod, k=2, sw=c(T,T,T), p=1, data=ftse.ret)

在这两种情况下,该功能msmFit都不起作用。这是我收到的错误消息:

Error in (function (classes, fdef, mtable)  : 
  unable to find an inherited method for function ‘msmFit’ for signature ‘"lm", "numeric", "logical", "numeric", "zoo", "missing"’

我不知道为什么会收到此错误消息,因为我使用对象作为函数msmFit的第一个参数,lm而这是一个适合函数参数的类。

4

2 回答 2

1

当您设置 p = 1 时,msmFit 模型将为您添加一个 AR(1) 系数。因此,您可以简单地仅使用截距 (mod) 传入模型并设置 p = 1。以下代码应该可以工作。

library(tseries)
#Prices 
ftse<-get.hist.quote(instrument="^FTSE", start="1984-01-03", end="2014-01-01", quote="AdjClose", compression="m")

#Log-returns
ftse.ret<-diff(log(ftse))

library(MSwM)

#Model with only intercept
mod<-lm(ftse.ret ~ 1)

#Fit regime-switching model
msm_intercept <- msmFit(mod, k=2, sw=c(T,T), p=0)

#Fit regime-switching model with AR(1) model
msm_ar1 <- msmFit(mod, k=2, sw=c(T,T,T), p=1)
于 2016-05-27T17:09:08.683 回答
1

当您将数据传递给 msmFit 时,您有一个不必要的参数,这是不必要的。数据已经包含在 mod 中。以下代码为我运行:

library(tseries)

#Prices
ftse<-get.hist.quote(instrument="^FTSE", start="1984-01-03", end="2014-01-01", quote="AdjClose",     compression="m")

#Log-returns
ftse.ret<-diff(log(ftse))

library(MSwM)

#Model with only intercept
mod<-lm(ftse.ret ~ 1)

#Fit regime-switching model
mod.mswm=msmFit(mod, k=2, sw=c(T,T), p=0)
plot(mod.mswm)
于 2015-08-18T06:07:47.740 回答