Hello,

   Thank you very much.

   How can I create an empty time series with the same dates as existing
time series?

   If x is a ts object, then it would be easy:
   y<-ts(NA, start=start(x), end=end(x),frequency=frequency(x))

   What can I do if x is a zoo or xts object?
   I come up with a cumbersome way of doing this:
   xts<-as.ts(x)
   y1<-ts(NA, start=start(y), end=end(y),frequency=frequency(y))
   y<-as.xts(y1)

   Is there any easier way to do it?

   Thanks

miao


2012/4/11 R. Michael Weylandt <michael.weyla...@gmail.com>

> Two ways around this:
>
> I = Easy) Just use zoo/xts objects. ts objects a real pain in the
> proverbial donkey because of things like this.
>
> Something like:
>
> library(xts)
> PI1.yq <- as.xts(PI1) # Specialty class for quarterly data (or regular
> zoo works)
> lag(PI1.yq)
>
> II = Hard) lag on a ts actually changes the time indices while keeping
> all the data, [so the fourth data point is the same value -- just a
> different time point] what you may want to do is cbind() the objects
> to see how they line up now.
>
> cbind(PI1, lag(PI1,4))
>
> Hope this helps,
> Michael
>
> On Tue, Apr 10, 2012 at 11:21 PM, jpm miao <miao...@gmail.com> wrote:
> > Hello,
> >
> >   I am writing codes for time series computation but encountering some
> > problems
> >
> >   Given the quarterly data from 1983Q1 to 1984Q2
> >
> > PI1<-ts(c(2.747365190,2.791594762, -0.009953715, -0.015059485,
> > -1.190061246, -0.553031799,  0.686874720,  0.953911035),
> > start=c(1983,1), frequency=4)
> >
> >> PI1
> >             Qtr1         Qtr2         Qtr3         Qtr4
> > 1983  2.747365190  2.791594762 -0.009953715 -0.015059485
> > 1984 -1.190061246 -0.553031799  0.686874720  0.953911035
> >
> >
> >    If I would like to create a time series vector containing the data in
> 4
> > quarters ahead
> >
> >> PI4<-lag(PI1,4)> PI4             Qtr1         Qtr2         Qtr3
> Qtr4
> > 1982  2.747365190  2.791594762 -0.009953715 -0.015059485
> > 1983 -1.190061246 -0.553031799  0.686874720  0.953911035
> >
> >
> >    Confusingly, PI1[1] and PI4[1] are exactly the same! I usually would
> > like to calculate the difference between the vector of interest and  the
> > corresponding values 4 quarters ahead, but it is zero!
> >
> >> PI1[1][1] 2.747365> PI4[1][1] 2.747365
> >
> >
> > One remedy that comes into my mind is to use window,but a warning message
> > emerges
> >
> >> PI4w<-window(PI4, start=start(PI1), end=end(PI1))Warning message:In
> window.default(x, ...) : 'end' value not changed> PI4w           Qtr1
> Qtr2       Qtr3       Qtr4
> > 1983 -1.1900612 -0.5530318  0.6868747  0.9539110
> >
> >
> >    Similar problems happen with the usage of the function "diff", which
> > calculate the difference. I wonder if it is better to work with the dates
> > (1983Q1, 1983Q2,.....) directly?
> >
> >    If I want to write a loop, say, to conduct some computation from
> 1983Q1
> > to 2011Q4, the only way I know is to convert the dates to the ordinal
> > indices, 1, 2, 3...... Can we work with the dates? Is there any built-in
> > equality that provides the computation like
> >    1983Q1 +1 equals 1983Q2?
> >    In EViews, it is easy to do that. We can let %s run from 1983Q1 to
> > 2011Q4, and he knows that 1983Q1+1 is exactly 1983Q2.
> >
> >     Thanks very much for your reply!
> >
> > miao
> >
> >        [[alternative HTML version deleted]]
> >
> > ______________________________________________
> > R-help@r-project.org mailing list
> > https://stat.ethz.ch/mailman/listinfo/r-help
> > PLEASE do read the posting guide
> http://www.R-project.org/posting-guide.html
> > and provide commented, minimal, self-contained, reproducible code.
>

        [[alternative HTML version deleted]]

______________________________________________
R-help@r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.

Reply via email to