Zamanla değişen katsayı DLM takma


9

Zamana göre değişen katsayılara sahip bir DLM, yani normal doğrusal regresyonun bir uzantısı olan,

yt=θ1+θ2x2.

Bir tahmin edicim var (x2) ve bir yanıt değişkeni (yt), 1950-2011 yılları arasında sırasıyla deniz ve iç yıllık balık avları. DLM regresyon modelinin takip etmesini istiyorum,

yt=θt,1+θt,2xt

burada sistem evrim denklemi

θt=G,tθt-1

43. sayfadaki Petris ve ark.

Bazıları burada kodlama yapıyor,

fishdata <- read.csv("http://dl.dropbox.com/s/4w0utkqdhqribl4/fishdata.csv", header=T)
x <- fishdata$marinefao
    y <- fishdata$inlandfao

lmodel <- lm(y ~ x)
summary(lmodel)
plot(x, y)
abline(lmodel)

Açıkça, regresyon modelinin zamanla değişen katsayıları burada daha uygundur. Örneğini 121 - 125. Sayfalardan takip ediyorum ve bunu kendi verilerime uygulamak istiyorum. Bu örnekten kodlamadır

############ PAGE 123
require(dlm)

capm <- read.table("http://shazam.econ.ubc.ca/intro/P.txt", header=T)
capm.ts <- ts(capm, start = c(1978, 1), frequency = 12)
colnames(capm)
plot(capm.ts)
IBM <- capm.ts[, "IBM"]  - capm.ts[, "RKFREE"]
x <- capm.ts[, "MARKET"] - capm.ts[, "RKFREE"]
x
plot(x)
outLM <- lm(IBM ~ x)
outLM$coef
    acf(outLM$res)
qqnorm(outLM$res)
    sig <- var(outLM$res)
sig

mod <- dlmModReg(x,dV = sig, m0 = c(0, 1.5), C0 = diag(c(1e+07, 1)))
outF <- dlmFilter(IBM, mod)
outF$m
    plot(outF$m)
outF$m[ 1 + length(IBM), ]

########## PAGES 124-125
buildCapm <- function(u){
  dlmModReg(x, dV = exp(u[1]), dW = exp(u[2:3]))
}

outMLE <- dlmMLE(IBM, parm = rep(0,3), buildCapm)
exp(outMLE$par)
    outMLE
    outMLE$value
mod <- buildCapm(outMLE$par)
    outS <- dlmSmooth(IBM, mod)
    plot(dropFirst(outS$s))
outS$s

plot(dropFirst(outS$s))Kendi verilerim için düzgünleştirme tahminlerini çizebilmek istiyorum, ki bu da yürütmede sorun yaşıyorum.

GÜNCELLEME

Şimdi bu grafikleri üretebiliyorum ama doğru olduklarını düşünmüyorum.

fishdata <- read.csv("http://dl.dropbox.com/s/4w0utkqdhqribl4/fishdata.csv", header=T)
x <- as.numeric(fishdata$marinefao)
    y <- as.numeric(fishdata$inlandfao)
xts <- ts(x, start=c(1950,1), frequency=1)
xts
yts <- ts(y, start=c(1950,1), frequency=1)
yts

lmodel <- lm(yts ~ xts)
#################################################
require(dlm)
    buildCapm <- function(u){
  dlmModReg(xts, dV = exp(u[1]), dW = exp(u[2:3]))
}

outMLE <- dlmMLE(yts, parm = rep(0,3), buildCapm)
exp(outMLE$par)
        outMLE$value
mod <- buildCapm(outMLE$par)
        outS <- dlmSmooth(yts, mod)
        plot(dropFirst(outS$s))

> summary(outS$s); lmodel$coef
       V1              V2       
 Min.   :87.67   Min.   :1.445  
 1st Qu.:87.67   1st Qu.:1.924  
 Median :87.67   Median :3.803  
 Mean   :87.67   Mean   :4.084  
 3rd Qu.:87.67   3rd Qu.:6.244  
 Max.   :87.67   Max.   :7.853  
 (Intercept)          xts 
273858.30308      1.22505 

Kesişim yumuşatma tahmini (V1) lm regresyon katsayısından uzaktır. Birbirlerine daha yakın olmaları gerektiğini düşünüyorum.

Yanıtlar:


2

Sorununuz tam olarak nedir?

Bulduğum tek tuzak, görünüşe göre,

fishdata <- read.csv("http://dl.dropbox.com/s/4w0utkqdhqribl4,
                     fishdata.csv", header=T)

verileri tamsayı olarak okur. Onları yüzmeye dönüştürmek zorunda kaldım,

x <- as.numeric(fishdata$marinefao)
y <- as.numeric(fishdata$inlandfao)

dlm * işlevlerini çağırmadan önce.


Önerileriniz için teşekkürler @F. TUSELL; Sorumu güncelledim. Üretilen düzeltme tahminleri tahminlere yakın değildir lmodel$coef. Arsaların yanlış olduğunu düşünüyorum ama yanlış olabilirim.
hgeop

1
Eğim ve kesişimin düzleştirilmiş tahminlerinin doğrusal regresyondaki sabit betalara yakın olmasını beklemek için hiçbir neden yoktur. Özellikle, eğim çılgınca dalgalanmalı.
F. Tusell
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.