1

複数の要素を持つリストがあります。各リストの 2 つの要素を使用して、予測から ets 関数を適用する必要があります。

以下はリスト dat.list で、各リストには時系列が呼び出されzlam

## Create Dummy list
##Time series -> z, lambda - > lam
z <- ts(matrix(rnorm(30,10,10), 100, 3), start = c(1961, 1), frequency = 12)
lam <- 0.8
ap <- list(z=z,lam=lam)


z <- ts(matrix(rnorm(30,10,10), 100, 3), start = c(1971, 1), frequency = 12)
lam <- 0.5
zp <- list(z=z,lam=lam)

dat.list <- list(ap=ap,zp=zp)

ここで、各時系列zを取得し、パッケージの関数を使用lamして取得して適用する必要があります。次のコードを使用しました。etsforecast

library("forecast")
library("plyr")   
ets.f <- function(x) {
      forecast(ets(x$z, lambda = x$lam),h=12)$mean ## I need to apply lambda from list lam
    }

    ens.f <- function(x){
      mm <- llply(x,ets.f)
      tq <- matrix(unlist(mm), ncol = 12, byrow = TRUE)
      tq
    }

    fore <- llply(dat.list, ens.f)

プログラムを実行すると、次のエラーが表示されます"Error in x$z : $ operator is invalid for atomic vectors"

リストの個々の要素を適用して関数に適用する方法がわかりません。どんな助けでも大歓迎です。

本当にありがとう

また、リスト内の と を分離しようとしましたが、これを適用する方法に行き詰まりましたzlam以下のコードも使用することに同意します。ありがとうございました。

ts.l <- lapply(dat.list,'[[','z')
lam.l <- lapply(dat.list,'[[','lam')
4

1 に答える 1

1

これが役立つかもしれません:

lapply(dat.list, function(x) matrix(unlist(lapply(x$z,
           function(y) forecast(ets(y, lambda=x$lam), 
                        h=12)$mean)), ncol=12, byrow=TRUE))
于 2014-12-06T16:21:49.487 に答える