[Rd] CCF and ACF

Simone Giannerini sgiannerini at gmail.com
Tue Oct 3 10:15:54 CEST 2006


Thank you Gabor, by the way I have checked in the Matlab GARCH
toolbox, the crosscorrelation function is reversed with respect to R,
I think it would be useful for the users to have documented the way
CCF is computed.

Simone

On 10/2/06, Gabor Grothendieck <ggrothendieck at gmail.com> wrote:
> Using "ts" objects these can be written in the following consistent
> manner:
>
> > sum(ts(x) * lag(ts(x)) / sum(ts(x)^2))
> [1] -0.2648633
>
> > sum(ts(x) * lag(ts(y)) / sqrt(sum(ts(y)^2) * sum(ts(x)^2)))
> [1] 0.5930216
>
> On 10/2/06, Simone Giannerini <sgiannerini at gmail.com> wrote:
> > Dear all,
> >
> >  given two numeric vectors x and y, the ACF(x) at lag k is
> > cor(x(t),x(t+k)) while the CCF(x,y) at lag k is cor(x(t),y(t-k)). See
> > below for a simple example.
> >
> >  > set.seed(1)
> >  > x <- rnorm(10)
> >  > y <- rnorm(10)
> > > x
> >  [1] -0.6264538  0.1836433 -0.8356286  1.5952808  0.3295078 -0.8204684
> >  0.4874291  0.7383247  0.5757814 -0.3053884
> > > y
> >  [1]  1.51178117  0.38984324 -0.62124058 -2.21469989  1.12493092
> > -0.04493361 -0.01619026  0.94383621  0.82122120  0.59390132
> > > x <- x - mean(x);
> > > y <- y -mean(y);
> >
> >   ## ACF OF x(t)
> > > print(acf(x,lag=2,plot=F),digits=5))
> >
> >  Autocorrelations of series 'x', by lag
> >
> >        0        1        2
> >  1.00000 -0.26486 -0.25352
> >
> >  ## For Instance ACF(x) at lag 1 is Corr(x(t),x(t+1)):
> >
> >  > sum(x[1:9]*x[2:10])/sum(x^2)
> > [1] -0.2648633
> >
> >  ## whereas CCF(x,y) at lag 1 is Corr(x(t),y(t-1))
> >  > ccf(x,y,lag=2,plot=F)
> >
> > Autocorrelations of series 'X', by lag
> >
> >    -2     -1      0      1      2
> >   -0.139  0.593 -0.377 -0.382  0.116
> >
> >  > sum(x[1:9]*y[2:10])/sqrt(sum(x^2)*sum(y^2))
> >
> > [1] 0.5930216
> >
> > > sum(x[2:10]*y[1:9])/sqrt(sum(x^2)*sum(y^2))
> >  [1] -0.3822885
> >
> > from a quick survey on textbooks (Brockwell and Davis, Chatfield,
> > Fuller) it looks like different authors use different conventions so
> > that I think that it would be nice to clarify this in the
> > documentation.
> >
> > Ciao
> >
> > Simone
> >
> > > R.version
> >               _
> > platform       i386-pc-mingw32
> > arch           i386
> > os             mingw32
> > system         i386, mingw32
> > status         beta
> > major          2
> > minor          4.0
> > year           2006
> > month          09
> > day            20
> > svn rev        39421
> > language       R
> > version.string R version 2.4.0 beta (2006-09-20 r39421)
> >
> > > Sys.getlocale()
> > [1] "LC_COLLATE=English_United States.1252;LC_CTYPE=English_United
> > States.1252;LC_MONETARY=English_United
> > States.1252;LC_NUMERIC=C;LC_TIME=English_United  States.1252"
> >
> >
> > ______________________________________________________
> >
> > Simone Giannerini
> >  Dipartimento di Scienze Statistiche "Paolo Fortunati"
> > Universita' di Bologna
> > Via delle belle arti 41 - 40126  Bologna,  ITALY
> >  Tel: +39 051 2098262  Fax: +39 051 232153
> >
> > ______________________________________________
> > R-devel at r-project.org mailing list
> > https://stat.ethz.ch/mailman/listinfo/r-devel
> >
>


-- 
______________________________________________________

Simone Giannerini
Dipartimento di Scienze Statistiche "Paolo Fortunati"
Universita' di Bologna
Via delle belle arti 41 - 40126  Bologna,  ITALY
Tel: +39 051 2098262  Fax: +39 051 232153




More information about the R-devel mailing list