# Correlogram

A plot showing 100 random numbers with a "hidden" sine function, and an autocorrelation (correlogram) of the series on the bottom.

In the analysis of data, a correlogram is a chart of correlation statistics. For example, in time series analysis, a plot of the sample autocorrelations $\displaystyle{ r_h\, }$ versus $\displaystyle{ h\, }$ (the time lags) is an autocorrelogram. If cross-correlation is plotted, the result is called a cross-correlogram.

The correlogram is a commonly used tool for checking randomness in a data set. If random, autocorrelations should be near zero for any and all time-lag separations. If non-random, then one or more of the autocorrelations will be significantly non-zero.

In addition, correlograms are used in the model identification stage for Box–Jenkins autoregressive moving average time series models. Autocorrelations should be near-zero for randomness; if the analyst does not check for randomness, then the validity of many of the statistical conclusions becomes suspect. The correlogram is an excellent way of checking for such randomness.

Sometimes, corrgrams, color-mapped matrices of correlation strengths in multivariate analysis,[1] are also called correlograms.[2][3]

## Applications

The correlogram can help provide answers to the following questions:

• Are the data random?
• Is an observation related to an adjacent observation?
• Is an observation related to an observation twice-removed? (etc.)
• Is the observed time series white noise?
• Is the observed time series sinusoidal?
• Is the observed time series autoregressive?
• What is an appropriate model for the observed time series?
• Is the model
$\displaystyle{ Y = \text{constant} + \text{error} }$
valid and sufficient?
• Is the formula $\displaystyle{ s_{\bar{Y}}=s/\sqrt{N} }$ valid?

## Importance

Randomness (along with fixed model, fixed variation, and fixed distribution) is one of the four assumptions that typically underlie all measurement processes. The randomness assumption is critically important for the following three reasons:

• Most standard statistical tests depend on randomness. The validity of the test conclusions is directly linked to the validity of the randomness assumption.
• Many commonly used statistical formulae depend on the randomness assumption, the most common formula being the formula for determining the standard error of the sample mean:
$\displaystyle{ s_{\bar{Y}}=s/\sqrt{N} }$

where s is the standard deviation of the data. Although heavily used, the results from using this formula are of no value unless the randomness assumption holds.

• For univariate data, the default model is
$\displaystyle{ Y = \text{constant} + \text{error} }$

If the data are not random, this model is incorrect and invalid, and the estimates for the parameters (such as the constant) become nonsensical and invalid.

## Estimation of autocorrelations

The autocorrelation coefficient at lag h is given by

$\displaystyle{ r_h = c_h/c_0 \, }$

where ch is the autocovariance function

$\displaystyle{ c_h = \frac 1 N \sum_{t=1}^{N-h} \left(Y_t - \bar{Y}\right)\left(Y_{t+h} - \bar{Y}\right) }$

and c0 is the variance function

$\displaystyle{ c_0 = \frac 1 N \sum_{t=1}^N \left(Y_t - \bar{Y}\right)^2 }$

The resulting value of rh will range between −1 and +1.

### Alternate estimate

Some sources may use the following formula for the autocovariance function:

$\displaystyle{ c_h = \frac{1}{N-h}\sum_{t=1}^{N-h} \left(Y_t - \bar{Y}\right)\left(Y_{t+h} - \bar{Y} \right) }$

Although this definition has less bias, the (1/N) formulation has some desirable statistical properties and is the form most commonly used in the statistics literature. See pages 20 and 49–50 in Chatfield for details.

## Statistical inference with correlograms

Correlogram example from 400-point sample of a first-order autoregressive process with 0.75 correlation of adjacent points, along with the 95% confidence intervals (plotted about the correlation estimates in black and about zero in red), as calculated by the equations in this section. The dashed blue line shows the actual autocorrelation function of the sampled process.
20 correlograms from 400-point samples of the same random process as in the previous figure.

In the same graph one can draw upper and lower bounds for autocorrelation with significance level $\displaystyle{ \alpha\, }$:

$\displaystyle{ B=\pm z_{1-\alpha/2} SE(r_h)\, }$ with $\displaystyle{ r_h\, }$ as the estimated autocorrelation at lag $\displaystyle{ h\, }$.

If the autocorrelation is higher (lower) than this upper (lower) bound, the null hypothesis that there is no autocorrelation at and beyond a given lag is rejected at a significance level of $\displaystyle{ \alpha\, }$. This test is an approximate one and assumes that the time-series is Gaussian.

In the above, z1−α/2 is the quantile of the normal distribution; SE is the standard error, which can be computed by Bartlett's formula for MA() processes:

$\displaystyle{ SE(r_1)=\frac 1 {\sqrt{N}} }$
$\displaystyle{ SE(r_h)=\sqrt\frac{1+2\sum_{i=1}^{h-1} r^2_i}{N} }$ for $\displaystyle{ h\gt 1.\, }$

In the example plotted, we can reject the null hypothesis that there is no autocorrelation between time-points which are separated by lags up to 4. For most longer periods one cannot reject the null hypothesis of no autocorrelation.

Note that there are two distinct formulas for generating the confidence bands:

1. If the correlogram is being used to test for randomness (i.e., there is no time dependence in the data), the following formula is recommended:

$\displaystyle{ \pm \frac{z_{1-\alpha/2}}{\sqrt{N}} }$

where N is the sample size, z is the quantile function of the standard normal distribution and α is the significance level. In this case, the confidence bands have fixed width that depends on the sample size.

2. Correlograms are also used in the model identification stage for fitting ARIMA models. In this case, a moving average model is assumed for the data and the following confidence bands should be generated:

$\displaystyle{ \pm z_{1-\alpha/2} \sqrt{\frac 1 N \left(1+2\sum_{i=1}^k r_i^2\right)} }$

where k is the lag. In this case, the confidence bands increase as the lag increases.

## Software

Correlograms are available in most general purpose statistical libraries.

Correlograms:

• python pandas: pandas.plotting.autocorrelation_plot[5]
• R: functions acf and pacf

Corrgrams:

• python seaborn: heatmap, pairplot
• R: corrgram[2][3]

## References

1. Friendly, Michael (19 August 2002). "Corrgrams: Exploratory displays for correlation matrices". The American Statistician (Taylor & Francis) 56 (4): 316–324. doi:10.1198/000313002533. Retrieved 19 January 2014.
2. "CRAN – Package corrgram". 29 August 2013.