开发者

R: Reversing the data in a time series object

开发者 https://www.devze.com 2023-03-26 17:57 出处:网络
I figured out a way to backcast (ie. predicting the past) with a time series. Now I\'m just struggling with the programming in R.

I figured out a way to backcast (ie. predicting the past) with a time series. Now I'm just struggling with the programming in R.

I would like to reverse the time series data so that I can forecast the past. How do I do this?

Say the original time series object looks like this:

     Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec
2008 116  99 115 101 112 120 120 110 143 136 147 142
2009 117 114 133 134 139 147 147 开发者_如何转开发131 125 143 136 129

I want it to look like this for the 'backcasting':

     Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec
2008 129 136 143 125 131 147 147 139 134 133 114 117
2009 142 147 136 143 110 120 120 112 101 115  99 116

Note, I didn't forget to change the years - I am basically mirroring/reversing the data and keeping the years, then going to forecast.

I hope this can be done in R? Or should I export and do it in Excel somehow?


Try this:

tt <- ts(1:24, start = 2008, freq = 12)
tt[] <- rev(tt)

ADDED. This also works and does not modify tt :

replace(tt, TRUE, rev(tt))


You can just coerce the matrix to a vector, reverse it, and make it a matrix again. Here's an example:

mat <- matrix(seq(24),nrow=2,byrow=TRUE)
> mat

     [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12]
[1,]    1    2    3    4    5    6    7    8    9    10    11    12
[2,]   13   14   15   16   17   18   19   20   21    22    23    24
> matrix( rev(mat), nrow=nrow(mat) )

     [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12]
[1,]   24   23   22   21   20   19   18   17   16    15    14    13
[2,]   12   11   10    9    8    7    6    5    4     3     2     1


I found this post of Hyndman under http://www.r-bloggers.com/backcasting-in-r/ and am basically pasting in his solution, which in my opinion provids a complete answer to you question.

library(forecast)
x <- WWWusage
h <- 20
f <- frequency(x)
# Reverse time
revx <- ts(rev(x), frequency=f)
# Forecast
fc <- forecast(auto.arima(revx), h)
plot(fc)
# Reverse time again
fc$mean <- ts(rev(fc$mean),end=tsp(x)[1] - 1/f, frequency=f)
fc$upper <- fc$upper[h:1,]
fc$lower <- fc$lower[h:1,]
fc$x <- x
# Plot result
plot(fc, xlim=c(tsp(x)[1]-h/f, tsp(x)[2]))
0

精彩评论

暂无评论...
验证码 换一张
取 消