AnomaliesFiltersLags {greenbrown}R Documentation

Calculate anomalies, lags and rolling windows

Description

This function computes several time-variant statisttics of a time series like seasonal anomalies, time lagged versions of time series, and filters time series based on running windows (using rollapply.

Usage

AnomaliesFiltersLags(x, funSeasonalCycle = MeanSeasonalCycle, 
    funFilter = median, alignFilter = c("center", "left", "right"), 
    filters = c(3, 5, 7, 9, 11, 13), lags = -1:-7, anom = TRUE, 
    ...)

Arguments

x

univariate time series of class ts

funSeasonalCycle

a function to estimate the seasonal cycle of the time series.

funFilter

a function to filter the time series based on rolling windows.

alignFilter

specifies whether the index of the running filter results should be left- or right-aligned or centered (default) compared to the rolling window of observations. See rollapply

filters

window sizes for rolling filters to be applied. If NULL, do not apply filters.

lags

time lags to be applied for lagged time series. If NULL, do not apply lags.

anom

compute seasonal anomalies?

...

further arguments (currently not used)

Value

The function returns a multivariate time series of class 'mts' with the following columns:

Author(s)

Matthias Forkel <matthias.forkel@geo.tuwien.ac.at> [aut, cre]

See Also

MeanSeasonalCycle

Examples

# load a time series of Normalized Difference Vegetation Index
data(ndvi)
plot(ndvi)

# do calculations
afl <- AnomaliesFiltersLags(ndvi)
colnames(afl)
summary(afl)

# seasonal anomalies
plot(afl[,"anom"]) 

# running median filters on original time series
plot(afl[, grep("orig.filter", colnames(afl))], plot.type="single", col=rainbow(6)) 

# running median filters on anomalies
plot(afl[, grep("anom.filter", colnames(afl))], plot.type="single", col=rainbow(6)) 

# lagged versions of original time series
plot(window(afl[, grep("orig.lag", colnames(afl))], start=c(1995, 1), 
   end=c(2000, 12)), plot.type="single", col=rainbow(7), type="l") 

# lagged versions of anomaly time series
plot(afl[, grep("anom.lag", colnames(afl))], plot.type="single", col=rainbow(7)) 


[Package greenbrown version 2.4.3 Index]