Title: | Data-Driven Locally Weighted Regression for Trend and Seasonality in TS |
---|---|
Description: | Various methods for the identification of trend and seasonal components in time series (TS) are provided. Among them is a data-driven locally weighted regression approach with automatically selected bandwidth for equidistant short-memory time series. The approach is a combination / extension of the algorithms by Feng (2013) <doi:10.1080/02664763.2012.740626> and Feng, Y., Gries, T., and Fritz, M. (2020) <doi:10.1080/10485252.2020.1759598> and a brief description of this new method is provided in the package documentation. Furthermore, the package allows its users to apply the base model of the Berlin procedure, version 4.1, as described in Speth (2004) <https://www.destatis.de/DE/Methoden/Saisonbereinigung/BV41-methodenbericht-Heft3_2004.pdf?__blob=publicationFile>. Permission to include this procedure was kindly provided by the Federal Statistical Office of Germany. |
Authors: | Yuanhua Feng [aut] (Paderborn University, Germany), Dominik Schulz [aut, cre] (Paderborn University, Germany) |
Maintainer: | Dominik Schulz <[email protected]> |
License: | GPL-3 |
Version: | 1.1.0 |
Built: | 2024-12-10 07:01:38 UTC |
Source: | CRAN |
A library of decomposition methods for equidistant time series with trend and seasonality.
deseats
is an R package for the decomposition of equidistant time
series with trend and seasonality. First and foremost, an own algorithm
for bandwidth selection in locally weighted regression of such time series
(with short-range dependence) is implemented that is based on both the
algorithms by Feng (2013) and Feng et al. (2020). For comparison,
a simplified version of the BV4.1 (Berlin Procedure 4.1, Speth, 2004), is
implemented as well that allows to implement the BV4.1 base model (trend
component + seasonality component + irregular component) without any
of the additional BV4.1 components (such as the calendar component).
Permission to include the BV4.1 base model procedure was kindly provided by
the Federal Statistical Office of Germany.
The main functions of the package are:
deseats
:locally weighted regression with automatically selected bandwidth for decomposition,
BV4.1
:BV4.1 base model for decomposition,
lm_decomp
:ordinary least squares for decomposition,
llin_decomp
:local linear regression for decomposition,
ma_decomp
:moving averages for decomposition,
hamilton_filter
:the time series filter by Hamilton.
The package includes a few datasets. Follow the corresponding links to the documentation of the datasets to find additional information including the sources.
CIVLABOR
:civilian labor force level in the USA.
CONSUMPTION
:real final consumption expenditure for Australia.
COVID
:new COVID-19 cases in Germany.
DEATHS
:recorded number of deaths in Germany.
ENERGY
:production and distribution of electricity, gas, steam and air conditioning in Germany.
EXPENDITURES
:consumption expenditures in the USA.
GDP
:GDP of the USA.
HOUSES
:new one family houses sold in the USA.
LIVEBIRTHS
:recorded number of livebirths in Germany.
NOLABORFORCE
:number of persons in the USA not belonging to the labor force.
RAINFALL
:average amount of rain in Germany.
RETAIL
:Retail sale volume in Germany.
SAVINGS
:savings of private households in Germany.
SUNSHINE
:average hours of sunshine in Germany.
TEMPERATURE
:average temperature in Germany.
The package is distributed under the General Public License v3 ([GPL-3](https://tldrlegal.com/license/gnu-general-public-license-v3-(gpl-3))).
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
Yuanhua Feng (Department of Economics, Paderborn
University),
Author
Feng, Y. (2013). An iterative plug-in algorithm for decomposing seasonal time series using the Berlin Method. Journal of Applied Statistics, 40(2): 266-281. DOI: 10.1080/02664763.2012.740626.
Feng, Y., Gries. T, and Fritz, M. (2020). Data-driven local polynomial for the trend and its derivatives in economic time series. Journal of Nonparametric Statistics, 32(2): 510-533. DOI: 10.1080/10485252.2020.1759598.
Speth, H.-T. (2004). Komponentenzerlegung und Saisonbereinigung ökonomischer Zeitreihen mit dem Verfahren BV4.1. Methodenberichte 3. Statistisches Bundesamt. URL: https://www.destatis.de/DE/Methoden/Saisonbereinigung/BV41-methodenbericht-Heft3_2004.pdf?__blob=publicationFile.
A generic that is the basis for methods that allow the user to create specific animations on-the-fly.
animate(object, ...)
animate(object, ...)
object |
the input object. |
... |
currently of no use; included for future compatibility. |
A generic that can be extended by methods to automatically create animations based on certain objects.
This generic does not return anything and is just the basis for more sophisticated methods.
The results of locally weighted regression results
acquired through decomposition of seasonal time series
via the function deseats
can be
animated automatically.
## S4 method for signature 'deseats' animate( object, col.obs = "grey74", col.fit = "red", col.weights = "#00D40E", col.window = "deepskyblue4", col.spot = "orange", save = NULL, xlab = "Time", ylab1 = "Estimated trend + seasonality", ylab2 = "Active kernel weights", main = NULL, ... )
## S4 method for signature 'deseats' animate( object, col.obs = "grey74", col.fit = "red", col.weights = "#00D40E", col.window = "deepskyblue4", col.spot = "orange", save = NULL, xlab = "Time", ylab1 = "Estimated trend + seasonality", ylab2 = "Active kernel weights", main = NULL, ... )
object |
an object of class |
col.obs |
the color to use for the observations. |
col.fit |
the color to use for the fitted values. |
col.weights |
the color to use for the active kernel weights. |
col.window |
the color to use for the window defined through the bandwidth |
col.spot |
the color to highlight the estimation time point. |
save |
whether to save the animation or not; for |
xlab |
the label for the x-axis. |
ylab1 |
the label for the y-axis on the left-hand side. |
ylab2 |
the label for the second y-axis on the right-hand side. |
main |
the plot title. |
... |
currently without use; implemented for possible future compatibility. |
deseats
estimation results are automatically animated
through this method. It shows the observed series together with fitted
values (trend + seasonality), the smoothing window, the fitted values from
the local regression, and the active kernel weights.
The function returns NULL
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
### Creating the animation might take a while Xt <- log(EXPENDITURES) smoothing_options <- set_options(order_poly = 3) est <- deseats(Xt, smoothing_options = smoothing_options) animate(est)
### Creating the animation might take a while Xt <- log(EXPENDITURES) smoothing_options <- set_options(order_poly = 3) est <- deseats(Xt, smoothing_options = smoothing_options) animate(est)
Calculate the coefficients of the infinite-order AR-representation of a given ARMA model.
arma_to_ar(ar = numeric(0), ma = numeric(0), max_i = 1000)
arma_to_ar(ar = numeric(0), ma = numeric(0), max_i = 1000)
ar |
a numeric vector with the AR parameters of the ARMA model;
should be ordered from |
ma |
a numeric vector with the MA parameters of the ARMA model;
should be ordered from |
max_i |
a single numeric value that indicates how many coefficients
should be returned; returned will be |
Consider an ARMA model
where and
are its real-valued
coefficients. The function
arma_to_ar()
uses these coefficients as
input to calculate the coefficients of the truncated infinite-order
AR-representation of the model defined through these coefficients. Note that
the stationarity and invertibility of the model defined through the provided
coefficients is not being checked.
NOTE:
This function implements C++ code by means
of the Rcpp
and
RcppArmadillo
packages for
better performance.
A numeric vector is returned.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
ar <- c(1.2, -0.4) ma <- c(0.5) arma_to_ar(ar = ar, ma = ma, max_i = 100)
ar <- c(1.2, -0.4) ma <- c(0.5) arma_to_ar(ar = ar, ma = ma, max_i = 100)
Calculate the coefficients of the infinite-order MA-representation of a given ARMA model.
arma_to_ma(ar = numeric(0), ma = numeric(0), max_i = 1000)
arma_to_ma(ar = numeric(0), ma = numeric(0), max_i = 1000)
ar |
a numeric vector with the AR parameters of the ARMA model;
should be ordered from |
ma |
a numeric vector with the MA parameters of the ARMA model;
should be ordered from |
max_i |
a single numeric value that indicates how many coefficients
should be returned; returned will be |
Consider an ARMA model
where and
are its real-valued
coefficients. The function
arma_to_ar()
uses these coefficients as
input to calculate the coefficients of the truncated infinite-order
MA-representation of the model defined through these coefficients. Note that
the stationarity and invertibility of the model defined through the provided
coefficients is not being checked.
NOTE:
This function implements C++ code by means
of the Rcpp
and
RcppArmadillo
packages for
better performance.
A numeric vector is returned.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
ar <- c(1.2, -0.4) ma <- c(0.5) arma_to_ma(ar = ar, ma = ma, max_i = 100)
ar <- c(1.2, -0.4) ma <- c(0.5) arma_to_ma(ar = ar, ma = ma, max_i = 100)
This is method for producing various plots of the decomposition results returned by this package.
## S4 method for signature 'decomp' autoplot(object, which = NULL, ...)
## S4 method for signature 'decomp' autoplot(object, which = NULL, ...)
object |
an object returned by the function |
which |
various plots can be selected either via a keyword or a number;
enter |
... |
no purpose and only implemented for compatibility. |
Create predefined standard plots of the decomposition objects returned by the
deseats
package, e.g. returned by the function deseats
.
Plots are created in the ggplot2 plot style. The type of plot can be chosen
either interactively from the console, or the argument which
can be
used to directly select the kind of plot to create (see also the description
of the argument which
) within the function call.
If plot type 5 (which = 5
) is selected, the estimated
seasonality will be displayed around the mean of the observations by default.
Setting the additional argument s_around
to some other value, will lead
to the seasonality being displayed around that constant value.
A ggplot2-graphic object is returned, i.e. an object of classes
"gg"
and "ggplot"
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
Xt <- log(EXPENDITURES) est <- deseats(Xt) autoplot(est, which = 3)
Xt <- log(EXPENDITURES) est <- deseats(Xt) autoplot(est, which = 3)
ggplot2
Plot Method for Class "deseats_fc"
Create ggplot2
R plots for forecasting objects of class
"deseats_fc"
.
## S4 method for signature 'deseats_fc' autoplot(object, ...)
## S4 method for signature 'deseats_fc' autoplot(object, ...)
object |
an object of class |
... |
currently without use; implemented for compatibility. |
This is a plot method to visualize the forecasting results for a Seasonal Semi-ARMA model. Common plot arguments can be implemented to change the appearance.
This method returns a ggplot2
plot object, i.e. an object of classes
"gg"
and "ggplot"
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
est <- s_semiarma(log(EXPENDITURES)) fc <- predict(est, n.ahead = 4) fc_e <- expo(fc) autoplot(fc_e)
est <- s_semiarma(log(EXPENDITURES)) fc <- predict(est, n.ahead = 4) fc_e <- expo(fc) autoplot(fc_e)
ggplot2
Plot Method for the Results of a Hamilton FilterVisualize the results of an applied Hamilton filter in the style of
ggplot2
.
## S4 method for signature 'hfilter' autoplot(object, which = NULL, ...)
## S4 method for signature 'hfilter' autoplot(object, which = NULL, ...)
object |
an object of class |
which |
either a string or a number can be entered to select a
plot type from the function call; options are (1) a facet plot of the
components, (2) the observed time series, (3) the observations together
with the fitted values, and (4) the residuals; for |
... |
currently without use, implemented for compatibility. |
This method returns a ggplot2
plot object, i.e. an object of classes
"gg"
and "ggplot"
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
est <- hamilton_filter(log(EXPENDITURES)) autoplot(est, which = 3, col = c(1, 6)) autoplot(est, which = 4)
est <- hamilton_filter(log(EXPENDITURES)) autoplot(est, which = 3, col = c(1, 6)) autoplot(est, which = 4)
Economic data can be decomposed into a trend, a seasonal and a remainder component using the Berlin procedure 4.1 (German: Berliner Verfahren 4.1), as used by the National Statistical Office of Germany. Currently with this version of the R package, only the trend and seasonal components can be estimated following BV4.1. All further component estimations, for example the estimation of the calendar component, of the official procedure BV4.1 are not yet implemented. The function supports quarterly and monthly data.
BV4.1(yt, type = NULL)
BV4.1(yt, type = NULL)
yt |
a time series object of class |
type |
a single character value that indicates, whether the data was
quarterly ( |
The BV4.1 base model is as follows:
trend and seasonality are estimated based on the additive nonparametric regression model for an equidistant time series
where is the observed time series with
,
is the rescaled time
on the interval
,
is a smooth trend function,
is a (slowly changing) seasonal component with
seasonal period
and
are stationary errors
with
that are furthermore assumed to be independent
but identically distributed (i.i.d.).
It is assumed that and
can be approximated locally by a
polynomial of
small order and by a trigonometric polynomial, respectively. Through locally
weighted regression,
and
can therefore be estimated
suitably.
The advantage of the Berlin Procedure 4.1 (BV4.1) is that it makes use of
fixed filters based on locally weighted regression (both with a weighted
mixture of local linear and local cubic components for the trend) at all
observation time points. Thus, BV4.1 results in fixed weighting matrices
both for the trend estimation step and for the seasonality estimation step
that can be immediately applied to all economic time series.
Those matrices are saved internally in the package and when applying
BV4.1
,
only weighted sums of the observations (with already obtained weights) have
to be obtained at all time points. Thus, this procedure is quite fast.
Permission to include the BV4.1 base model procedure was kindly provided by the Federal Statistical Office of Germany.
An S4 object with the following elements is returned.
decomp
An object of class "mts"
that consists of the
decomposed time series data.
frequency
the frequency of the time series.
ts_name
the object name of the initially provided time series object.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
Speth, H.-T. (2004). Komponentenzerlegung und Saisonbereinigung ökonomischer Zeitreihen mit dem Verfahren BV4.1. Methodenberichte 3. Statistisches Bundesamt. URL: https://www.destatis.de/DE/Methoden/Saisonbereinigung/BV41-methodenbericht-Heft3_2004.pdf?__blob=publicationFile.
Xt <- log(EXPENDITURES) est <- BV4.1(Xt) est
Xt <- log(EXPENDITURES) est <- BV4.1(Xt) est
A stationary block bootstrap is applied to resample from a time series that was decomposed into a trend, a seasonal component and a remainder by means of data-driven local polynomial regression with automatically selected bandwidth. Bandwidth re-estimation from each bootstrapped sample results in confidence bounds for the bandwidth.
bwidth_confint( nonpar_model, blocklen = NULL, npaths = 1000, parallel = TRUE, num_cores = future::availableCores() - 1, ... )
bwidth_confint( nonpar_model, blocklen = NULL, npaths = 1000, parallel = TRUE, num_cores = future::availableCores() - 1, ... )
nonpar_model |
the object with the nonparametric trend and seasonality
estimation results returned by for example the function
|
blocklen |
a numerical vector of length one that indicates the average
block length to be drawn from the detrended series; the default is
|
npaths |
a numeric vector of length one that indicates the number of
bootstrap paths; the default is |
parallel |
a logical vector of length one that indicates whether or
not to employ parallel programming for the resampling and the subsequently
data-driven bandwidth estimations from the bootstrapped samples; the default
is |
num_cores |
a numeric vector of length one that indicates the number of
CPU cores to use for parallel programming, if |
... |
further arguments to pass to |
Confidence bounds for the bandwidth in local polynomial regression for identifying the trend in a trend-stationary short-memory time series are obtained via a block bootstrap, which ensures that no specific model assumptions are required for the detrended series.
This function makes use of the future
parallel programming
framework to ensure exactly the same results regardless of whether
sequential or parallel programming, and then also regardless of
the number of workers, is employed.
A list with the following elements is returned.
conf
A vector with named elements that gives the original bandwidth estimate as well as the bootstrapped bounds of the 95 and 99 percent confidence intervals of the bandwidth.
bwidth_estimates
a vector with all the obtained bandwidths for the bootstrapped series.
se_bwidth
the sample standard deviation of
bwidth_estimates
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
xt <- log(EXPENDITURES) est <- deseats(xt, set_options(order_poly = 3)) conf <- bwidth_confint(est, npaths = 200, num_cores = 2) conf
xt <- log(EXPENDITURES) est <- deseats(xt, set_options(order_poly = 3)) conf <- bwidth_confint(est, npaths = 200, num_cores = 2) conf
If either deseats
or s_semiarma
are
used to fit a model to time series data, this method retrieves
the applied bandwidth from the output object.
## S4 method for signature 'deseats' bwidth(object) ## S4 method for signature 's_semiarma' bwidth(object)
## S4 method for signature 'deseats' bwidth(object) ## S4 method for signature 's_semiarma' bwidth(object)
object |
an object either of class |
When applying deseats
or link{s_semiarma}
,
one approach is to let the functions automatically choose a
bandwidth for locally weighted regression. Using this method,
the applied bandwidth can be retrieved.
A numeric vector of length one that represents the bandwidth used in the smoothing procedure is returned.
Xt <- log(EXPENDITURES) smoothing_options <- set_options(order_poly = 3) est <- deseats(Xt, smoothing_options = smoothing_options) bwidth(est)
Xt <- log(EXPENDITURES) smoothing_options <- set_options(order_poly = 3) est <- deseats(Xt, smoothing_options = smoothing_options) bwidth(est)
A ts
object that contains the monthly observed civilian labor force
level in the USA (in millions of persons) from January 1948 to December 2019.
The object contains 864 observations.
CIVLABOR
CIVLABOR
An object of class ts
of length 864.
The data was obtained from the databank of the Federal Reserve Bank of St. Louis (accessed: 2022-09-01) and then transformed into a time series object using R.
https://fred.stlouisfed.org/series/LNU01000000
A ts
object that contains the quarterly real final consumption
expenditure (in thousands of domestic currency) from the third quarter of 1959
to the last quarter in 2019. The object contains 242 observations.
CONSUMPTION
CONSUMPTION
An object of class ts
with 242 rows and 1 columns.
The data was obtained from the databank of the Federal Reserve Bank of St. Louis (accessed: 2023-09-26) and then transformed into a time series object using R.
https://fred.stlouisfed.org/series/NCRNSAXDCAUQ
A ts
object that contains the daily confirmed new COVID-19 cases
in Germany (in thousands of cases) from June 2021 to November 2021.
The object contains 183 observations. The time series object is created
as a time series object with frequency 7, i.e. the time unit is in calendar
weeks of the year 2021 and not in years.
COVID
COVID
An object of class ts
of length 183.
The data was obtained from the COVID-19 Data Hub (accessed: 2023-09-25) and then transformed into a time series object using R.
This function takes a coefficient series of a linear time series filter as an input and then returns the corresponding gain function as an R function.
create.gain(filter.coefs = c(1), zero.at = ceiling(length(filter.coefs)/2))
create.gain(filter.coefs = c(1), zero.at = ceiling(length(filter.coefs)/2))
filter.coefs |
a numeric vector with the filter coefficients ordered by coefficient index; see details for more info. |
zero.at |
a numeric vector of length one that indicates the position
of the coefficient for the present observation in |
This is a functional. The function returns a function that
represents the gain function for the input filter
filter.coefs
. The returned function only has the
argument lambda
, which is the frequency for which
the value of the gain function should be obtained.
Let be the input series and
the linear filter;
then the element
is the weight assigned to
. The
corresponding index
is important for the order of the argument
filter.coefs
.
The function returns a "gain function" function that has the numeric
argument lambda
only that represents frequencies to calculate
the values of the gain function for.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
# Moving average with smoothing over three values a <- 1 / 3 gain_ma <- create.gain(rep(a, 3)) lambda <- seq(0, 0.5, 0.001) GF <- gain_ma(lambda) plot(lambda, GF, type = "l") # First differences filter b <- c(1, -1) gain_diff <- create.gain(b) lambda <- seq(0, 0.5, 0.001) GF2 <- gain_diff(lambda) plot(lambda, GF2, type = "l") # For a fully data-driven local linear trend + # trigonometric polynomial seasonality # (Note: we get various filters for different observation time points) xt <- EXPENDITURES est <- deseats(log(xt), set_options(order_poly = 3)) ws <- est@weights[, , "Combined"] l <- (length(ws[, 1]) - 1) / 2 lambda <- seq(0, 0.5, 0.001) mat <- matrix(0, ncol = length(lambda), nrow = l + 1) colF <- colorRampPalette(c("deepskyblue4", "deepskyblue")) cols <- colF(l) for (j in 1:(l + 1)) { gainF <- create.gain(ws[j, ], zero.at = j) mat[j, ] <- gainF(lambda) } matplot(lambda, t(mat), type = paste0(rep("l", l + 1), collapse = ""), lty = rep(1, l + 1), col = cols) title( main = paste0( "Gain functions for the applied data-driven locally weighted ", "regression\napproach at boundary points and the first interior ", "point" ) ) # Same example as before but not for the trend but for the detrending filters # (Note: we get various filters for different observation time points) ll <- l * 2 + 1 mat2 <- mat for (j in 1:(l + 1)) { zero.vec <- rep(0, ll) zero.vec[[j]] <- 1 gainF <- create.gain(zero.vec - ws[j, ], zero.at = j) mat2[j, ] <- gainF(lambda) } matplot(lambda, t(mat2), type = paste0(rep("l", l + 1), collapse = ""), lty = rep(1, l + 1), col = cols) title( main = paste0( "Gain functions for the applied data-driven detrending filter\n", "at boundary points and the first interior ", "point" ) )
# Moving average with smoothing over three values a <- 1 / 3 gain_ma <- create.gain(rep(a, 3)) lambda <- seq(0, 0.5, 0.001) GF <- gain_ma(lambda) plot(lambda, GF, type = "l") # First differences filter b <- c(1, -1) gain_diff <- create.gain(b) lambda <- seq(0, 0.5, 0.001) GF2 <- gain_diff(lambda) plot(lambda, GF2, type = "l") # For a fully data-driven local linear trend + # trigonometric polynomial seasonality # (Note: we get various filters for different observation time points) xt <- EXPENDITURES est <- deseats(log(xt), set_options(order_poly = 3)) ws <- est@weights[, , "Combined"] l <- (length(ws[, 1]) - 1) / 2 lambda <- seq(0, 0.5, 0.001) mat <- matrix(0, ncol = length(lambda), nrow = l + 1) colF <- colorRampPalette(c("deepskyblue4", "deepskyblue")) cols <- colF(l) for (j in 1:(l + 1)) { gainF <- create.gain(ws[j, ], zero.at = j) mat[j, ] <- gainF(lambda) } matplot(lambda, t(mat), type = paste0(rep("l", l + 1), collapse = ""), lty = rep(1, l + 1), col = cols) title( main = paste0( "Gain functions for the applied data-driven locally weighted ", "regression\napproach at boundary points and the first interior ", "point" ) ) # Same example as before but not for the trend but for the detrending filters # (Note: we get various filters for different observation time points) ll <- l * 2 + 1 mat2 <- mat for (j in 1:(l + 1)) { zero.vec <- rep(0, ll) zero.vec[[j]] <- 1 gainF <- create.gain(zero.vec - ws[j, ], zero.at = j) mat2[j, ] <- gainF(lambda) } matplot(lambda, t(mat2), type = paste0(rep("l", l + 1), collapse = ""), lty = rep(1, l + 1), col = cols) title( main = paste0( "Gain functions for the applied data-driven detrending filter\n", "at boundary points and the first interior ", "point" ) )
A ts
object that contains the monthly observed deaths in Germany
(in thousands of cases) from January 1990 to April 2022. The object
contains 388 observations.
DEATHS
DEATHS
An object of class ts
of length 388.
The data was obtained from the databank "Genesis" of the National Statistical Office of Germany (accessed: 2022-07-21) and then transformed into a time series object using R.
Simultaneously estimate the trend and the seasonality via locally weighted regression in an equidistant time series under short memory. The default setting uses an iterative plug-in algorithm for identifying the asymptotically globally optimal bandwidth for smoothing.
deseats( y, smoothing_options = set_options(), bwidth_start = NULL, inflation_rate = c("optimal", "naive"), correction_factor = FALSE, autocor = TRUE, drop = NULL, error_model = c("free", "ARMA"), nar_lim = c(0, 3), nma_lim = c(0, 3), arma_mean = FALSE )
deseats( y, smoothing_options = set_options(), bwidth_start = NULL, inflation_rate = c("optimal", "naive"), correction_factor = FALSE, autocor = TRUE, drop = NULL, error_model = c("free", "ARMA"), nar_lim = c(0, 3), nma_lim = c(0, 3), arma_mean = FALSE )
y |
a numerical vector or a time series object of class |
smoothing_options |
an S4 object of class |
bwidth_start |
a single numeric value that is only relevant if the slot
|
inflation_rate |
a character vector of length one that indicates, which inflation rate
to use in the bandwidth selection; for a local linear trend, we have
|
correction_factor |
A logical vector of length one; theoretically, a
larger bandwidth to estimate the sum of autocovariances from residuals of
pilot trend and seasonality estimates is advisable than for estimating trend
and seasonality; for |
autocor |
a logical vector of length one; indicates whether to consider
autocorrelated errors ( |
drop |
a numeric vector of length one that indicates the proportion of
the observations to not include at each boundary in the bandwidth estimation
process, if a bandwidth is selected automatically; the default is
|
error_model |
a character vector of length one that indicates whether
for |
nar_lim |
only valid for |
nma_lim |
only valid for |
arma_mean |
only valid for |
Trend and seasonality are estimated based on the additive nonparametric regression model for an equidistant time series
where is the observed time series with
,
is the rescaled time
on the interval
,
is a smooth and deterministic
trend function,
is a (slowly changing) seasonal component with
seasonal period
and
are stationary errors
with
and short-range dependence (see for example also
Feng, 2013, for a similar model, where the stochastic term is however i.i.d.).
It is assumed that and
can be approximated locally by a polynomial of
small order and by a trigonometric polynomial, respectively. Through locally
weighted regression,
and
can therefore be estimated given
a suitable bandwidth.
The iterative-plug-in (IPI) algorithm, which numerically minimizes the asymptotic mean squared error (AMISE) to select a bandwidth is an extension of Feng (2013) to the case with short-range dependence in the errors. To achieve this goal, the error variance in the AMISE in Feng (2013) is replaced by the sum of autocovariances of the error process and this quantity is being estimated using a slightly adjusted version of the Bühlmann (1996) algorithm. This procedure is similar to the method described in Feng, Gries and Fritz (2020), where data-driven local polynomial regression with an automatically selected bandwidth is used to estimate the trend according to a model without seasonality and where the same adjusted Bühlmann (1996) algorithm is considered to estimate the sum of autocovariances in the error process.
Define ,
and
, where
is the order of the (local) polynomial
considered for
,
is the order of the asymptotically equivalent kernel
for estimating
,
, and
is the variance factor, i.e. the sum of autocovariances divided by
.
Furthermore, we define
and
with being the bandwidth,
being the number of
observations and
being the weighting function considered in the
weighted least squares approach, for example a second-order kernel function
with support on
. The AMISE is then
The function calculates suitable estimates for , the variance
factor, and
over different iterations. In each
iteration, a bandwidth is obtained in accordance with the AMISE that once
more serves as an input for the following iteration. The process repeats
until either convergence or the 40th iteration is reached. For further
details on the asymptotic theory or the algorithm, please consult Feng,
Gries and Fritz (2020) or Feng et al. (2019).
To apply the function, only few arguments are needed: a data input y
,
an object with smoothing options smoothing_options
returned by
set_options
and
a starting value for the relative bandwidth
bwidth_start
. Aside from y
, each argument has a default setting.
By default, a local linear trend is considered. In some cases, a local cubic
trend may, however, be more suitable. For more specific information on the input arguments
consult the section Arguments.
When applying the function, an optimal bandwidth is obtained based on the IPI algorithm proposed by Feng, Gries and Fritz (2020). In a second step, the nonparametric trend of the series and the seasonality are calculated with respect to the chosen bandwidth.
Note that with this function and
can be
estimated without a parametric
model assumption for the error series. Thus, after estimating and removing
the trend and the seasonality, any suitable parametric model, e.g. an
ARMA(
) model for
errors = "autocor"
, can be fitted to the
residuals (see arima
).
Usually, a local cubic trend (smoothing_options = set_options(order_poly = 3)
)
gives more suitable results. Moreover, if the resulting bandwidth is too large,
adjustments to the arguments inflation_rate
and drop
should be
tried first in that order before any other changes
to the input arguments.
The default print method for this function delivers key numbers such as the bandwidth considered for smoothing.
NOTE:
This function implements C++ code by means
of the Rcpp
and
RcppArmadillo
packages for
better performance.
The function returns and S4 object with the following elements (access them
via @
):
boundary_method
the applied boundary method.
bwidth
the globally applied bandwidth in the smoothing process; if not if no input is given in the function call, this is the automatically selected optimal bandwidth.
decomp
An object of class "mts"
that consists of the
decomposed time series data.
frequency
the frequency of the time series.
kernel_fun
the second-order kernel function considered for weighting.
order_poly
the order of polynomial considered locally for the trend.
order_poly
the order of polynomial considered locally for the trend.
sum_autocov
the estimated sum of autocovariances.
ts_name
the object name of the initially provided time series object.
weights_wfun
a matrix that gives the weights of the weighting
function at each estimation time point; ; if
is the length of the given time series and
is the applied
(relative) bandwidth, then the first row of the weighting system gives the
weighting function weights when estimating at
, the second row gives
the weights when estimating at
and so on for all left-hand side
boundary points
until the middle row, which contains the
weights used at all interior points; the rows following the middle row contain
the weights for right-hand side boundary points (the rows are ordered
chronologically)
weights
an array with many slices that represent the weighting
systems for various filters; each slice is a matrix, which gives the weighting
system to estimate a component, for example trend + seasonality, as a weighted
average from the given time series; if
is the length of the given time series and
is the applied
(relative) bandwidth, then the first row of the weighting system gives the
weights to obtain estimates at
, the second row gives the weights to
obtain estimates at
and so on for all left-hand side boundary points
until the middle row, which contains the
weights used at all interior points; the rows following the middle row contain
the weights for right-hand side boundary points (the rows are ordered
chronologically);
the slice names are
"Trend"
, "Season"
and "Combined"
,
where "Combined"
are the weights to estimate trend + seasonality
combined.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
Yuanhua Feng (Department of Economics, Paderborn
University),
Author
Bühlmann, P. (1996). Locally Adaptive Lag-Window Spectral Estimation. Journal of Time Series Analysis, 17(3): 247-270. DOI: 10.1111/j.1467-9892.1996.tb00275.x.
Feng, Y. (2013). An iterative plug-in algorithm for decomposing seasonal time series using the Berlin Method. Journal of Applied Statistics, 40(2): 266-281. DOI: 10.1080/02664763.2012.740626.
Feng, Y., Gries. T, and Fritz, M. (2020). Data-driven local polynomial for the trend and its derivatives in economic time series. Journal of Nonparametric Statistics, 32(2): 510-533. DOI: 10.1080/10485252.2020.1759598.
Xt <- log(EXPENDITURES) smoothing_options <- set_options(order_poly = 3) est <- deseats(Xt, smoothing_options = smoothing_options) est plot(est, which = 1)
Xt <- log(EXPENDITURES) smoothing_options <- set_options(order_poly = 3) est <- deseats(Xt, smoothing_options = smoothing_options) est plot(est, which = 1)
A ts
object that contains the monthly production and distribution
of electricity gas steam, and air conditioning for Germany (Index 2015 = 100)
from January 1991
to June 2023. The object contains 390 observations.
ENERGY
ENERGY
An object of class ts
with 390 rows and 1 columns.
The data was obtained from the databank of the Federal Reserve Bank of St. Louis (accessed: 2023-10-11) and then transformed into a time series object using R.
https://fred.stlouisfed.org/series/DEUPREND401IXOBM
A ts
object that contains the quarterly observed personal
consumption expenditures in the USA in trillions of dollars from the
first quarter of 1947 to the last quarter of 2019. The object contains
292 observations.
EXPENDITURES
EXPENDITURES
An object of class ts
of length 292.
The data was obtained from the databank of the Federal Reserve Bank of St. Louis (accessed: 2022-07-15) and then transformed into a time series object using R.
https://fred.stlouisfed.org/series/NA000349Q
A generic that is the basis for methods that allow the user to exponentiate certain results quickly.
expo(object, ...)
expo(object, ...)
object |
the input object. |
... |
currently of no use; included for future compatibility. |
A generic that can be extended by methods to exponentiate the numeric information in certain objects.
This generic does not return anything and is just the basis for more sophisticated methods.
deseats
ForecastsExponentiate, i.e. as act of retransformation, (point and interval) forecasts
obtained via the deseats
package.
## S4 method for signature 'deseats_fc' expo(object, ...)
## S4 method for signature 'deseats_fc' expo(object, ...)
object |
an object of class |
... |
currently without purpose; included for compatibility only. |
An object of class "deseats_fc"
is returned.
est <- s_semiarma(log(EXPENDITURES), set_options(order_poly = 3)) fc <- predict(est, n.ahead = 8) fc2 <- expo(fc) fc2
est <- s_semiarma(log(EXPENDITURES), set_options(order_poly = 3)) fc <- predict(est, n.ahead = 8) fc2 <- expo(fc) fc2
Obtain either fitted values or residuals from a fitted Hamilton filter.
## S4 method for signature 'hfilter' fitted(object, ...) ## S4 method for signature 'hfilter' residuals(object, ...)
## S4 method for signature 'hfilter' fitted(object, ...) ## S4 method for signature 'hfilter' residuals(object, ...)
object |
an object of class |
... |
currently without further use; implemented for compatibility. |
Obtain the fitted and the residual values from the result of a fitted Hamilton filter. The name of the method indicates, what is returned.
A time series object of class "ts"
is returned.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
est <- hamilton_filter(log(EXPENDITURES)) residuals(est) fitted(est)
est <- hamilton_filter(log(EXPENDITURES)) residuals(est) fitted(est)
Gain Function Generic
gain(object, lambda = seq(0, 0.5, 1e-04), ...)
gain(object, lambda = seq(0, 0.5, 1e-04), ...)
object |
an input object; for the linear filters considered in this object, gain function values should be obtained. |
lambda |
a vector of frequencies (from 0 to 0.5) for which to obtain the gain function. |
... |
currently without use; for possible future compatibility. |
A standard generic function. The purpose is to build various methods to instantaneously obtain gain function values for linear filters of different decomposition objects.
A generic that can be extended by methods to automatically obtain gain function values of linear filters described in certain objects.
This generic does not return anything and is just the basis for more sophisticated methods.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
Obtain gain function values for DeSeaTS Trend and Detrend Filters
## S4 method for signature 'deseats' gain(object, lambda = seq(0, 0.5, 1e-04), ...)
## S4 method for signature 'deseats' gain(object, lambda = seq(0, 0.5, 1e-04), ...)
object |
an object of class |
lambda |
a numeric vector with the frequencies at which to get the gain function values. |
... |
no current purpose for this ellipsis. |
The various filters obtained via deseats
(represented by
the returned weighting systems) have a representation in the frequency
domain. Using this method, those gain function values can be easily
obtained.
A list is returned. Each element represents gain function values
at the specified frequencies lambda
for the filter defined
through the element name.
gain_trend
gain function values for the trend filter.
gain_detrend
gain function values for the detrending filter.
gain_season
gain function values for the seasonality filter.
gain_deseason
gain function values for the seasonal adjustment filter.
gain_comb
gain function values for the trend + seasonality filter.
gain_decomb
gain function values for the detrending + seasonal adjustment filter.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
xt <- log(EXPENDITURES) est <- deseats(xt) lambda <- seq(0, 0.5, 0.01) gain_values <- gain(est, lambda = lambda) m <- length(gain_values$gain_trend[, 1]) k <- (m - 1) / 2 colF <- colorRampPalette(c("deepskyblue4", "deepskyblue")) cols <- colF(m) matplot(lambda, t(gain_values$gain_decomb[1:(k + 1), ]), type = paste0(rep("l", k + 1), collapse = ""), col = cols, lty = rep(1, k + 1)) title("Gain functions of the combined detrend and deseasonalization filters") matplot(lambda, t(gain_values$gain_trend[1:(k + 1), ]), type = paste0(rep("l", k + 1), collapse = ""), col = cols, lty = rep(1, k + 1)) title("Gain functions of the trend filters") matplot(lambda, t(gain_values$gain_deseason[1:(k + 1), ]), type = paste0(rep("l", k + 1), collapse = ""), col = cols, lty = rep(1, k + 1)) title("Gain functions of the seasonal adjustment filters")
xt <- log(EXPENDITURES) est <- deseats(xt) lambda <- seq(0, 0.5, 0.01) gain_values <- gain(est, lambda = lambda) m <- length(gain_values$gain_trend[, 1]) k <- (m - 1) / 2 colF <- colorRampPalette(c("deepskyblue4", "deepskyblue")) cols <- colF(m) matplot(lambda, t(gain_values$gain_decomb[1:(k + 1), ]), type = paste0(rep("l", k + 1), collapse = ""), col = cols, lty = rep(1, k + 1)) title("Gain functions of the combined detrend and deseasonalization filters") matplot(lambda, t(gain_values$gain_trend[1:(k + 1), ]), type = paste0(rep("l", k + 1), collapse = ""), col = cols, lty = rep(1, k + 1)) title("Gain functions of the trend filters") matplot(lambda, t(gain_values$gain_deseason[1:(k + 1), ]), type = paste0(rep("l", k + 1), collapse = ""), col = cols, lty = rep(1, k + 1)) title("Gain functions of the seasonal adjustment filters")
A ts
object that contains the quarterly US GDP
(in billions of USD) from the first quarter of 1947 to the last quarter in
2019. The object contains 292 observations.
GDP
GDP
An object of class ts
with 292 rows and 1 columns.
The data was obtained from the databank of the Federal Reserve Bank of St. Louis (accessed: 2023-09-25) and then transformed into a time series object using R.
https://fred.stlouisfed.org/series/NA000334Q
Allows to calculate the theoretically optimal bandwidth for estimating the trend and the seasonality in an equidistant time series with short-range dependence using locally weighted regression, if the trend function and the exact ARMA dependence structure of the errors are known.
hA_calc( m, arma = list(ar = NULL, ma = NULL, sd_e = 1), p = c(1, 3), mu = c(0, 1, 2, 3), frequ = c(4, 12), n = 300, cb = 0.1 )
hA_calc( m, arma = list(ar = NULL, ma = NULL, sd_e = 1), p = c(1, 3), mu = c(0, 1, 2, 3), frequ = c(4, 12), n = 300, cb = 0.1 )
m |
an expression that defines the trend function in terms of |
arma |
a list with the elements |
p |
the order of polynomial to use locally for the trend estimation. |
mu |
the smoothness parameter of the second-order kernel function used in the weighting process. |
frequ |
the frequency of the theoretical time series (4 for quarterly and 12 for monthly time series). |
n |
the number of observations. |
cb |
the part of observations to drop at each boundary. |
For simulation studies of the function deseats
one may be
interested in obtaining the theoretically optimal bandwidth for local
regression first for a given theoretical process (from which realizations
will be drawn in the simulation). This function assists in obtaining this
theoretical bandwidth.
This function returns a list with various elements. See the documentation of
deseats
to understand, what each quantity signifies.
b
This is the theoretical quantity .
hA
The theoretically asymptotically optimal global bandwidth for locally weighted regression applied to the theoretical time series under consideration.
Imk
This is the theoretical quantity .
RK
This is the theoretical quantity .
RW
This is the theoretical quantity .
sum_autocov
This is the theoretical quantity .
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
arma <- list(ar = 0.8, sd_e = 0.01) m_f <- expression(13.1 + 3.1 * x + (dnorm(x / 0.15 - 0.5 / 0.15) / 0.15) / 4) n <- 500 p <- 1 mu <- 1 frequ <- 4 cb <- 0.05 hA_calc( m = m_f, arma = arma, p = p, mu = mu, frequ = frequ, n = n, cb = cb ) t <- 1:n xt <- t / n mxt <- 13.1 + 3.1 * xt + dnorm(xt, mean = 0.5, sd = 0.15) / 4 S2 <- rep(c(0, 1, 0, 0), length.out = n) S3 <- rep(c(0, 0, 1, 0), length.out = n) S4 <- rep(c(0, 0, 0, 1), length.out = n) sxt <- -0.5 + 0.25 * S2 + 0.5 * S3 + 1.25 * S4 set.seed(123) et <- arima.sim(model = list(ar = 0.8), sd = 0.01, n = n) yt <- ts(mxt + sxt + et, frequency = frequ) plot(yt) est <- deseats(yt) est@bwidth est@sum_autocov
arma <- list(ar = 0.8, sd_e = 0.01) m_f <- expression(13.1 + 3.1 * x + (dnorm(x / 0.15 - 0.5 / 0.15) / 0.15) / 4) n <- 500 p <- 1 mu <- 1 frequ <- 4 cb <- 0.05 hA_calc( m = m_f, arma = arma, p = p, mu = mu, frequ = frequ, n = n, cb = cb ) t <- 1:n xt <- t / n mxt <- 13.1 + 3.1 * xt + dnorm(xt, mean = 0.5, sd = 0.15) / 4 S2 <- rep(c(0, 1, 0, 0), length.out = n) S3 <- rep(c(0, 0, 1, 0), length.out = n) S4 <- rep(c(0, 0, 0, 1), length.out = n) sxt <- -0.5 + 0.25 * S2 + 0.5 * S3 + 1.25 * S4 set.seed(123) et <- arima.sim(model = list(ar = 0.8), sd = 0.01, n = n) yt <- ts(mxt + sxt + et, frequency = frequ) plot(yt) est <- deseats(yt) est@bwidth est@sum_autocov
A stationary remainder is obtained from a univariate time series using the filter proposed by Hamilton. The filter is capable of estimating the trend together with the seasonality in a series.
hamilton_filter(yt, h = NULL, p = NULL)
hamilton_filter(yt, h = NULL, p = NULL)
yt |
a time series object of class |
h |
the backwards time skip for the first regressor; the default is
the seasonal period in |
p |
the number of regressors; the default is the seasonal period in
|
Implement the filter by Hamilton (2018) to decompose a time series.
A list with the following elements is returned.
an object of class "mts"
that consists of the
decomposed time series data.
the object name of the initially provided time series object.
the frequency of the time series.
an object of class "lm"
, i.e. basic regression
output.
Hamilton, J. D. (2018). Why You Should Never Use the Hodrick-Prescott Filter. The Review of Economics and Statistics, 100(5): 831–843. DOI: 10.1162/rest_a_00706.
est <- hamilton_filter(log(EXPENDITURES)) est
est <- hamilton_filter(log(EXPENDITURES)) est
A ts
object that contains the monthly new one family houses sold in
the USA (in thousands of units) from January 1985
to December 2005. The object contains 252 observations.
HOUSES
HOUSES
An object of class ts
with 252 rows and 1 columns.
The data was obtained from the databank of the Federal Reserve Bank of St. Louis (accessed: 2023-09-30) and then transformed into a time series object using R.
https://fred.stlouisfed.org/series/HSN1FNSA
A ts
object that contains the monthly observed live births in Germany
(in thousands of cases) from January 1995 to March 2023. The object
contains 339 observations.
LIVEBIRTHS
LIVEBIRTHS
An object of class ts
of length 339.
The data was obtained from the databank "Genesis" of the National Statistical Office of Germany (accessed: 2023-06-15) and then transformed into a time series object using R.
Trend and seasonality are modelled in a two-step approach, where first the trend is being estimated using local linear regression and then the seasonality is being estimated using various local linear regressions as well. In both cases a manually selected bandwidth is required.
llin_decomp( yt, bwidth_trend = 4, bwidth_season = 5, kernel_par = 1, boundary_method = c("extend", "shorten"), season = NULL )
llin_decomp( yt, bwidth_trend = 4, bwidth_season = 5, kernel_par = 1, boundary_method = c("extend", "shorten"), season = NULL )
yt |
a time series object of class |
bwidth_trend |
half of the absolute bandwidth (in years); represents the amount of data to use around the estimation time point to consider for trend smoothing. |
bwidth_season |
half of the absolute bandwidth (in years); represents the amount of data (only from the same quarter, month, etc.) to use around the estimation time point for the seasonality estimation. |
kernel_par |
the smoothness parameter for the second-order kernel function
used in the weighting process; for |
boundary_method |
a single character value; it indicates, what bandwidth
method to use at boundary points; for |
season |
the seasonal period in |
Apply local linear regression to estimate trend and seasonality
in a given time series . Assume that
follows an additive
component model with trend and seasonality components. First, a local linear
regression with a first (absolute) bandwidth is conducted to estimate the trend
from the series. If the seasonal period is
, then afterwards
local linear regressions (for each individual seasonal subseries of the
detrended series) are conducted with a second (absolute) bandwidth to obtain
seasonality estimates.
An S4 object with the following elements is returned.
an object of class "mts"
that consists of the
decomposed time series data.
the object name of the initially provided time series object.
the frequency of the time series.
the same as the input argument bwidth_trend
.
the same as the input argument bwidth_season
.
the same as the input argument boundary_method
.
the same as the input argument kernel_par
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
est <- llin_decomp(log(EXPENDITURES), bwidth_trend = 4, bwidth_season = 28) est
est <- llin_decomp(log(EXPENDITURES), bwidth_trend = 4, bwidth_season = 28) est
Trend and seasonality are simultaneously modelled by considering a polynomial for the trend and a polynomial in the seasonality (via dummy variables and their interactions with time) for the different time units (e.g. months).
lm_decomp(yt, order_poly = 1, order_poly_s = 1, season = NULL)
lm_decomp(yt, order_poly = 1, order_poly_s = 1, season = NULL)
yt |
a time series object of class |
order_poly |
the order of the polynomial considered for the trend; the
default is |
order_poly_s |
the order of the polynomial considered for the
seasonality; the default is |
season |
the seasonal period in |
Apply ordinary least squares to estimate trend and seasonality simultaneously
in a given time series. This a global approach in contrast to for example
deseats
, which is a local estimation method.
An S4 object with the following elements is returned.
an object of class "mts"
that consists of the
decomposed time series data.
the object name of the initially provided time series object.
the frequency of the time series.
an object of class "lm"
, i.e. basic regression
output; the time variable t
used in the regression is encoded as
seq_along(yt)
; the dummy variable S2
encodes
the first observation time point (and the yearly corresponding time points) as
-1
and the second observation time point (and the yearly corresponding
time points) as 1
, the dummy variable S3
does the same but has
instead for the third observation time point (and the yearly corresponding
time points) a 1
, and so on.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
est <- lm_decomp(log(EXPENDITURES), order_poly = 3, order_poly_s = 2) est
est <- lm_decomp(log(EXPENDITURES), order_poly = 3, order_poly_s = 2) est
Trend and seasonality are modelled in a two-step approach, where first the trend is being estimated using moving averages and then trend + seasonality are being estimated using moving averages. The difference is then the estimated seasonality.
ma_decomp(yt, k_trend = 4, k_season = 5, season = NULL)
ma_decomp(yt, k_trend = 4, k_season = 5, season = NULL)
yt |
a time series object of class |
k_trend |
the complete absolute bandwidth (in years); represents the data of how many years to use around the estimation time point to consider for trend smoothing. |
k_season |
the complete absolute bandwidth (in years); represents the data of how many years (only from the same quarter, month, etc.) to use around the estimation time point for trend + seasonality smoothing. |
season |
the seasonal period in |
Apply moving averages to estimate trend and seasonality
in a given time series. This approach results in missings NA
at
boundary points.
An S4 object with the following elements is returned.
an object of class "mts"
that consists of the
decomposed time series data.
the object name of the initially provided time series object.
the frequency of the time series.
the same as the input argument k_trend
.
the same as the input argument k_season
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
est <- ma_decomp(log(EXPENDITURES), k_trend = 6, k_season = 7) est
est <- ma_decomp(log(EXPENDITURES), k_trend = 6, k_season = 7) est
Given point forecasts and observations, calculate various forecasting accuracy measures.
measures(preds, obs)
measures(preds, obs)
preds |
the point predictions for the test data period. |
obs |
the observation series (training data and test data) |
Given one-step-ahead rolling forecasts as well as the whole series of given observations (training together with test data), different forecasting accuracy measures (MAE, RMSE, Pearson's correlation, MASE, RMSSE) are being calculated.
A named vector with the obtained criteria values is returned.
xt <- EXPENDITURES xt_in <- window(xt, end = c(2017, 4)) yt <- log(xt_in) est <- s_semiarma(yt, set_options(order_poly = 3), inflation_rate = "optimal") fc_results <- predict(est, n.ahead = 8, expo = TRUE) point_fc <- fc_results@pred measures(point_fc, xt)
xt <- EXPENDITURES xt_in <- window(xt, end = c(2017, 4)) yt <- log(xt_in) est <- s_semiarma(yt, set_options(order_poly = 3), inflation_rate = "optimal") fc_results <- predict(est, n.ahead = 8, expo = TRUE) point_fc <- fc_results@pred measures(point_fc, xt)
A ts
object that contains the monthly observed number of persons in
the USA that do not belong to the labor force (in millions of persons)
from January 1990 to December 2019.
The object contains 360 observations.
NOLABORFORCE
NOLABORFORCE
An object of class ts
of length 360.
The data was obtained from the databank of the Federal Reserve Bank of St. Louis (accessed: 2023-06-15) and then transformed into a time series object using R.
https://fred.stlouisfed.org/series/LNU05000000
Various generics that can be used write methods to either retrieve or set smoothing options.
order_poly(object) order_poly(object) <- value season(object, ...) season(object) <- value kernel_fun(object) kernel_fun(object) <- value bwidth(object) bwidth(object) <- value boundary_method(object) boundary_method(object) <- value
order_poly(object) order_poly(object) <- value season(object, ...) season(object) <- value kernel_fun(object) kernel_fun(object) <- value bwidth(object) bwidth(object) <- value boundary_method(object) boundary_method(object) <- value
object |
an object from which to either retrieve options or in which to set an option. |
value |
the value to set the corresponding option to. |
... |
without use; implemented for possible future compatibility only. |
order_poly
, season
, kernel_fun
, bwidth
, and
boundary_method
can be used to retrieve the order of polynomial,
the seasonal frequency, the kernel function setting, the bandwidth and
the boundary method from an object with smoothing options. The corresponding
generics beginning with <-
are useful to set such options instead.
The generics themselves are without a direct purpose.
Generics that can be extended by methods to set or obtain settings (e.g. smoothing options) in certain objects.
These generics do not return anything and are just the basis for more sophisticated methods.
Retrieve smoothing options from or set them in an object
of class "smoothing_options"
.
## S4 method for signature 'smoothing_options' order_poly(object) ## S4 replacement method for signature 'smoothing_options' order_poly(object) <- value ## S4 method for signature 'smoothing_options' season(object) ## S4 replacement method for signature 'smoothing_options' season(object) <- value ## S4 method for signature 'smoothing_options' kernel_fun(object) ## S4 replacement method for signature 'smoothing_options' kernel_fun(object) <- value ## S4 method for signature 'smoothing_options' bwidth(object) ## S4 replacement method for signature 'smoothing_options' bwidth(object) <- value ## S4 method for signature 'smoothing_options' boundary_method(object) ## S4 replacement method for signature 'smoothing_options' boundary_method(object) <- value
## S4 method for signature 'smoothing_options' order_poly(object) ## S4 replacement method for signature 'smoothing_options' order_poly(object) <- value ## S4 method for signature 'smoothing_options' season(object) ## S4 replacement method for signature 'smoothing_options' season(object) <- value ## S4 method for signature 'smoothing_options' kernel_fun(object) ## S4 replacement method for signature 'smoothing_options' kernel_fun(object) <- value ## S4 method for signature 'smoothing_options' bwidth(object) ## S4 replacement method for signature 'smoothing_options' bwidth(object) <- value ## S4 method for signature 'smoothing_options' boundary_method(object) ## S4 replacement method for signature 'smoothing_options' boundary_method(object) <- value
object |
an object of class |
value |
the value to set the corresponding option to. |
Various methods are provided to either retrieve smoothing option
settings from an object of class "smoothing_options"
or
to adjust them within such an object.
The methods without <-
return the corresponding settings in the supplied
object. The methods with <-
set the corresponding option in the
provided object.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
opts <- set_options() opts order_poly(opts) order_poly(opts) <- 3 opts
opts <- set_options() opts order_poly(opts) order_poly(opts) <- 3 opts
This is method for producing various plots of the decomposition results returned by this package.
## S4 method for signature 'decomp' plot(x, which = NULL, ...)
## S4 method for signature 'decomp' plot(x, which = NULL, ...)
x |
an object returned by the function |
which |
various plots can be selected either via a keyword or a number;
enter |
... |
further arguments to pass to |
Create predefined standard plots of the decomposition objects returned by the
deseats
package, e.g. returned by the function deseats
.
Plots are created in the base R plot style. The type of plot can be chosen
either interactively from the console, or the argument which
can be
used to directly select the kind of plot to create (see also the description
of the argument which
) within the function call.
If plot type 5 (which = 5
) is selected, the estimated
seasonality will be displayed around the mean of the observations by default.
Setting the additional argument s_around
to some other value, will lead
to the seasonality being displayed around that constant value.
A graphic is created in the plots windows, the function itself, however,
returns NULL
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
Xt <- log(EXPENDITURES) est <- deseats(Xt) plot(est, which = 3)
Xt <- log(EXPENDITURES) est <- deseats(Xt) plot(est, which = 3)
"deseats_fc"
Create basic R plots for forecasting objects of class "deseats_fc"
.
## S4 method for signature 'deseats_fc' plot(x, y = NULL, ...)
## S4 method for signature 'deseats_fc' plot(x, y = NULL, ...)
x |
an object of class |
y |
currently without use; for compatibility only. |
... |
further arguments of |
This is a plot method to visualize the forecasting results for a Seasonal Semi-ARMA model. Common plot arguments can be implemented to change the appearance.
This method returns NULL
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
est <- s_semiarma(log(EXPENDITURES)) fc <- predict(est, n.ahead = 4) fc_e <- expo(fc) plot(fc_e)
est <- s_semiarma(log(EXPENDITURES)) fc <- predict(est, n.ahead = 4) fc_e <- expo(fc) plot(fc_e)
Visualize the results of an applied Hamilton filter.
## S4 method for signature 'hfilter' plot(x, which = NULL, ...)
## S4 method for signature 'hfilter' plot(x, which = NULL, ...)
x |
an object of class |
which |
either a string or a number can be entered to select a
plot type from the function call; options are (1) a facet plot of the
components, (2) the observed time series, (3) the observations together
with the fitted values, and (4) the residuals; for |
... |
further arguments to pass to |
This function returns NULL
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
est <- hamilton_filter(log(EXPENDITURES)) plot(est, which = 3, col = c(1, 6)) plot(est, which = 4)
est <- hamilton_filter(log(EXPENDITURES)) plot(est, which = 3, col = c(1, 6)) plot(est, which = 4)
Obtain point and interval forecasts based on fitted Seasonal Semi-ARMA models.
## S4 method for signature 's_semiarma' predict( object, n.ahead = 1, intervals = TRUE, alpha = c(0.95, 0.99), method = c("norm", "boot"), bootMethod = c("simple", "advanced"), npaths = 5000, quant.type = 8, expo = FALSE, ... )
## S4 method for signature 's_semiarma' predict( object, n.ahead = 1, intervals = TRUE, alpha = c(0.95, 0.99), method = c("norm", "boot"), bootMethod = c("simple", "advanced"), npaths = 5000, quant.type = 8, expo = FALSE, ... )
object |
an object of class |
n.ahead |
a numeric vector of length one that represents the forecasting horizon; assume that |
intervals |
a logical vector of length one that indicates whether or not
forecasting intervals should be obtained; the default is |
alpha |
a numeric vector of variable length that indicates the confidence levels
at which to obtain forecasting intervals; the default is |
method |
a character vector that indicates the method used to obtain forecasting
intervals; available are theoretical intervals based on the assumption of normal
innovations ( |
bootMethod |
a character vector that allows the user to select a bootstrap
procedure for the forecasting intervals when |
npaths |
the number of paths to simulate, if the forecasting intervals are obtained via a bootstrap. |
quant.type |
the method to obtain sample quantiles from the simulated
forecasting errors; see also the argument |
expo |
a logical vector of length one; indicates whether the forecasting
results should be exponentiated at the end; the default is |
... |
only for comparability with the standard |
Assume a Seasonal Semi-ARMA model was fitted using s_semiarma
.
Pass the resulting object to this method, in order to obtain point and
interval forecasts.
A list with the following elements is returned.
pred
the obtained point forecasts.
interv
the obtained forecasting intervals.
obs
the observation series.
ts_name
the name of the observation series object.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
xt <- log(EXPENDITURES) est <- s_semiarma(xt) predict(est, n.ahead = 10)
xt <- log(EXPENDITURES) est <- s_semiarma(xt) predict(est, n.ahead = 10)
A ts
object that contains the monthly observed average rainfall
in Germany (in mm) from January 1881 to August 2023.
The object contains 1712 observations.
RAINFALL
RAINFALL
An object of class ts
of length 1712.
The data was obtained from the databank of the German Weather Service (DWD) (accessed: 2023-09-25) and then transformed into a time series object using R.
https://www.dwd.de/DE/leistungen/zeitreihen/zeitreihen.html#buehneTop
"ts"
or "mts"
Allows the user to read in a data file directly as a "ts"
or
"mts"
object, where a time point column in the data file is
immediately used to set starting points and frequency of the time
series automatically correctly. Works for equidistant observation time
points, e.g. quarterly or monthly observations.
read_ts( file, time_column = 1, sep = ",", dec = ".", header = TRUE, time_format = NULL )
read_ts( file, time_column = 1, sep = ",", dec = ".", header = TRUE, time_format = NULL )
file |
a data file name given as a string (including the file ending); the file should have at least two columns: one time column and at least one or multiple columns for time series observations; alternatively, a data frame can be passed to this argument. |
time_column |
a number that indicates which column in the dataset is the variable with the time points; by default, the first column is assumed to contain the information on time points. |
sep |
the separation symbol between the dataset columns. |
dec |
the decimal symbol in the dataset. |
header |
|
time_format |
with the default |
The data file is internally read into R as a "zoo"
object and then
transformed into a "ts"
object using zoo_to_ts
. This
happens without the user noticing. The result is an immediate transformation
of the input data into an object of class "ts"
or "mts"
for
the user.
An object of class "ts"
or "mts"
is returned.
### Create an example data file a <- 1:12 b <- 21:32 tp <- seq(from = as.Date("2020-01-01"), to = as.Date("2020-12-01"), by = "month") df <- data.frame( Time = tp, a = a, b = b ) file <- file.path(tempdir(), "ExampleFile.csv") write.table(df, file = file, quote = FALSE, sep = ",", row.names = FALSE, col.names = TRUE) ### Use the function to read in the data xt <- read_ts(file) xt
### Create an example data file a <- 1:12 b <- 21:32 tp <- seq(from = as.Date("2020-01-01"), to = as.Date("2020-12-01"), by = "month") df <- data.frame( Time = tp, a = a, b = b ) file <- file.path(tempdir(), "ExampleFile.csv") write.table(df, file = file, quote = FALSE, sep = ",", row.names = FALSE, col.names = TRUE) ### Use the function to read in the data xt <- read_ts(file) xt
A ts
object that contains the monthly total volume of retail trade
in Germany (Index 2015 = 100)
from January 1991
to December 2019. The object contains 348 observations.
RETAIL
RETAIL
An object of class ts
with 348 rows and 1 columns.
The data was obtained from the databank of the Federal Reserve Bank of St. Louis (accessed: 2023-10-11) and then transformed into a time series object using R.
https://fred.stlouisfed.org/series/DEUSLRTTO01IXOBM
A shiny app is started that allows its user to run some of the decomposition approaches of this package interactively.
runDecomposition()
runDecomposition()
Time series data can be uploaded to the app and then decomposed using some of the approaches implemented in this package. The decomposition is immediately visualized within the app, so that the user can assess the suitability of the decomposition graphically. The decomposed data can then be saved in CSV format.
This function returns NULL
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
Fit a seasonal semiparametric autoregressive moving-average
(S-Semi-ARMA) model to a univariate time series. The estimation is
in two steps: firstly, the series is detrended and seasonally adjusted using the
function deseats
. Then an ARMA model is fitted to the
residuals using arima
.
s_semiarma( yt, smoothing_options = set_options(), arma_options = list(ar_order = NULL, ma_order = NULL), bwidth_start = 0.2, inflation_rate = c("optimal", "naive"), correction_factor = FALSE, drop = NULL, error_model = c("free", "ARMA"), nar_lim = c(0, 3), nma_lim = c(0, 3), arma_mean = FALSE )
s_semiarma( yt, smoothing_options = set_options(), arma_options = list(ar_order = NULL, ma_order = NULL), bwidth_start = 0.2, inflation_rate = c("optimal", "naive"), correction_factor = FALSE, drop = NULL, error_model = c("free", "ARMA"), nar_lim = c(0, 3), nma_lim = c(0, 3), arma_mean = FALSE )
yt |
a numerical vector or a time series object of class |
smoothing_options |
an S4 object of class |
arma_options |
a list with the two elements |
bwidth_start |
a single numeric value that is only relevant if the slot
|
inflation_rate |
a character vector of length one that indicates, which inflation rate
to use in the bandwidth selection; for a local linear trend, we have
|
correction_factor |
A logical vector of length one; theoretically, a
larger bandwidth to estimate the sum of autocovariances from residuals of
pilot trend and seasonality estimates is advisable than for estimating trend
and seasonality; for |
drop |
a numeric vector of length one that indicates the proportion of
the observations to not include at each boundary in the bandwidth estimation
process, if a bandwidth is selected automatically; the default is
|
error_model |
a character vector of length one that indicates whether
for |
nar_lim |
only valid for |
nma_lim |
only valid for |
arma_mean |
only valid for |
For information on the nonparametric regression step, see
deseats
. After the trend and the seasonality have
been removed from the data, an autoregressive moving-average (ARMA) model
is fitted to the residuals either with orders selected by the Bayesian
information criterion (BIC) or with manually selected orders. The ARMA
model is fitted using arima
.
All function arguments except for arma_options
are identical to
those in deseats
. If all elements in
arma_options
are set to NULL
, the ARMA model orders are
selected for from
nar_lim[[1]]
and nma_lim[[1]]
up
until nar_lim[[2]]
and nma_lim[[2]]
according to the BIC.
The function returns and S4 object with the following elements (access them
via @
):
decomp
an object of class "mts"
that includes the
observed time series and its estimated components.
nonpar_model
an object of class "deseats"
; this is
the result of applying deseats
.
par_model
an object of class "Arima"
; the result of
applying arima
to the residuals of the nonparametric
estimation step.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
Yuanhua Feng (Department of Economics, Paderborn
University),
Author
Xt <- log(EXPENDITURES) est <- s_semiarma(Xt) est
Xt <- log(EXPENDITURES) est <- s_semiarma(Xt) est
A ts
object that contains the quarterly observed savings of
private households in Germany
(in billions of EUR) from January 1991 to December 2019. The object
contains 116 observations.
SAVINGS
SAVINGS
An object of class ts
of length 116.
The data was obtained from the databank "Genesis" of the National Statistical Office of Germany (accessed: 2023-06-15) and then transformed into a time series object using R.
Simplified seasonal plot creation of time series in order to identify seasonal patterns more easily.
seasonplot( x, xlab = NULL, ylab = NULL, main = NULL, labels = TRUE, colorpalette = NULL, rm_xticks = FALSE )
seasonplot( x, xlab = NULL, ylab = NULL, main = NULL, labels = TRUE, colorpalette = NULL, rm_xticks = FALSE )
x |
a time series object of class |
xlab |
a label for the plot's x-axis. |
ylab |
a label for the plot's y-axis. |
main |
a title for the plot. |
labels |
whether or not to show tick labels. |
colorpalette |
a color palette (either a numeric or character vector) that gives an alternative color palette to use for the subseries. |
rm_xticks |
whether to remove x-axis ticks and tick labels; the default is
|
The function creates a seasonal plot of the provided time series object. The series is split into different subseries, each reflecting one season, and then these subseries are plotted together. This helps identifying possible seasonal patterns in the data.
The function does not return anything, however a plot is created in the plot window.
seasonplot(TEMPERATURE, xlab = "Degrees Celsius", main = "Seasonal plot of German temperature data")
seasonplot(TEMPERATURE, xlab = "Degrees Celsius", main = "Seasonal plot of German temperature data")
Simplified seasonal plot creation of time series objects in order to identify seasonal patterns.
seasonplot_gg(x)
seasonplot_gg(x)
x |
a time series object of class |
The function returns an plot object in the style of ggplot2
. The plot
can therefore be adjusted easily using common ggplot2
syntax.
The function returns a ggplot2
plot object.
seasonplot_gg(TEMPERATURE) + ggplot2::ylab("Degrees Celsius") + ggplot2::ggtitle("Seasonal plot of German temperature data")
seasonplot_gg(TEMPERATURE) + ggplot2::ylab("Degrees Celsius") + ggplot2::ggtitle("Seasonal plot of German temperature data")
Optimal Bandwidth Estimation for Locally Weighted Regression in Equidistant Time Series under Short Memory
select_bwidth( y, smoothing_options = set_options(), bwidth_start = NULL, inflation_rate = c("optimal", "naive"), correction_factor = FALSE, autocor = TRUE, drop = NULL, error_model = c("free", "ARMA"), nar_lim = c(0, 3), nma_lim = c(0, 3), arma_mean = FALSE )
select_bwidth( y, smoothing_options = set_options(), bwidth_start = NULL, inflation_rate = c("optimal", "naive"), correction_factor = FALSE, autocor = TRUE, drop = NULL, error_model = c("free", "ARMA"), nar_lim = c(0, 3), nma_lim = c(0, 3), arma_mean = FALSE )
y |
a numerical vector or a time series object of class |
smoothing_options |
an S4 object of class |
bwidth_start |
a single numeric value that is only relevant if the slot
|
inflation_rate |
a character vector of length one that indicates, which inflation rate
to use in the bandwidth selection; for a local linear trend, we have
|
correction_factor |
A logical vector of length one; theoretically, a
larger bandwidth to estimate the sum of autocovariances from residuals of
pilot trend and seasonality estimates is advisable than for estimating trend
and seasonality; for |
autocor |
a logical vector of length one; indicates whether to consider
autocorrelated errors ( |
drop |
a numeric vector of length one that indicates the proportion of
the observations to not include at each boundary in the bandwidth estimation
process, if a bandwidth is selected automatically; the default is
|
error_model |
a character vector of length one that indicates whether
for |
nar_lim |
only valid for |
nma_lim |
only valid for |
arma_mean |
only valid for |
See further details in the documentation of the function
deseats
, where this function is applied internally
by default to select an optimal bandwidth.
The function returns a list with different components:
bopt
the obtained optimal bandwidth.
bwidths
the obtained bandwidth for each iteration of the IPI-algorithm.
Imk
the final estimate of .
sum_autocov
the final estimate of the sum of autocovariances.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
Yuanhua Feng (Department of Economics, Paderborn
University),
Author
Feng, Y. (2013). An iterative plug-in algorithm for decomposing seasonal time series using the Berlin Method. Journal of Applied Statistics, 40(2): 266-281. DOI: 10.1080/02664763.2012.740626.
Feng, Y., Gries. T, and Fritz, M. (2020). Data-driven local polynomial for the trend and its derivatives in economic time series. Journal of Nonparametric Statistics, 32(2): 510-533. DOI: 10.1080/10485252.2020.1759598.
Xt <- log(EXPENDITURES) select_bwidth(Xt)
Xt <- log(EXPENDITURES) select_bwidth(Xt)
Set the smoothing specifications for locally weighted regression for identifying the trend and the seasonality in an equidistant time series.
set_options( order_poly = 1, season = NA_real_, kernel_fun = "epanechnikov", bwidth = NA_real_, boundary_method = "extend" )
set_options( order_poly = 1, season = NA_real_, kernel_fun = "epanechnikov", bwidth = NA_real_, boundary_method = "extend" )
order_poly |
the order of the local polynomials used for estimating the
smooth nonparametric trend; the default is |
season |
the frequency of observations per time unit, for example per
year; set to |
kernel_fun |
the weighting function to consider; supported are four
second-order kernel functions with compact support on |
bwidth |
a numeric value that indicates the relative bandwidth to
consider in the smoothing process; the default is |
boundary_method |
a single character value; it indicates, what bandwidth
method to use at boundary points; for |
An object of class "smoothing_options"
is created that contains
all required information to conduct a locally weighted regression for
decomposing a seasonal time series. The information include the order
of the trend polynomials, the frequency of the observed series, the
second-order kernel function to use in the weighting process, the
(relative) bandwidth to employ, and the boundary method for the bandwidth.
The function returns an S4 object with the following elements (access via
@
):
identical to the input argument with that name; please see the description of that input argument.
identical to the input argument with that name; please see the description of that input argument.
identical to the input argument with that name; please see the description of that input argument.
identical to the input argument with that name; please see the description of that input argument.
identical to the input argument with that name; please see the description of that input argument.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
deseats
Function ResultsPrint results of the function deseats
.
## S4 method for signature 'deseats' show(object)
## S4 method for signature 'deseats' show(object)
object |
an object of class |
After trend and seasonality in a time series have been estimated using the
function deseats
, basic estimation results can be easily printed to
the console.
The function returns NULL
.
"s_semiarma"
Print results of the function s_semiarma
to the console.
## S4 method for signature 's_semiarma' show(object)
## S4 method for signature 's_semiarma' show(object)
object |
an object of class |
Use this method to create a nice looking overview of the contents of
objects of class "s_semiarma"
.
This method returns NULL
.
Dominik Schulz (Research Assistant) (Department of Economics, Paderborn
University),
Author and Package Creator
Show smoothing settings in an object of class "smoothing_options"
.
## S4 method for signature 'smoothing_options' show(object)
## S4 method for signature 'smoothing_options' show(object)
object |
an object of class |
This is a special printing method for objects object of class
"smoothing_options"
. Calling this method shows a nice looking
overview of the saved smoothing settings.
This method returns NULL
.
opts <- set_options() opts
opts <- set_options() opts
A ts
object that contains the monthly observed hours of sunshine
in Germany from January 1951 to August 2023.
The object contains 872 observations.
SUNSHINE
SUNSHINE
An object of class ts
of length 872.
The data was obtained from the databank of the German Weather Service (DWD) (accessed: 2023-09-25) and then transformed into a time series object using R.
https://www.dwd.de/DE/leistungen/zeitreihen/zeitreihen.html#buehneTop
A ts
object that contains the monthly observed average temperature
in Germany (in degrees Celsius) from January 1881 to August 2023.
The object contains 1712 observations.
TEMPERATURE
TEMPERATURE
An object of class ts
of length 1712.
The data was obtained from the databank of the German Weather Service (DWD) (accessed: 2023-09-25) and then transformed into a time series object using R.
https://www.dwd.de/DE/leistungen/zeitreihen/zeitreihen.html#buehneTop
Obtain estimated components, such as the estimated trend, the seasonally adjusted series, and so on from an estimation object.
trend(object, ...) deseasonalize(object, ...) detrend(object, ...)
trend(object, ...) deseasonalize(object, ...) detrend(object, ...)
object |
the estimation object. |
... |
currently without use; included for future compatibility. |
Generics that can be extended by methods to obtain (estimated) time series components from certain estimation objects.
These generics do not return anything and are just the basis for more sophisticated methods.
The provided methods work for decomposition objects created within this package. They allow the user to retrieve individual components among the estimated ones.
## S4 method for signature 'decomp' trend(object, ...) ## S4 method for signature 'decomp' season(object, ...) ## S4 method for signature 'decomp' fitted(object, ...) ## S4 method for signature 'decomp' residuals(object, ...) ## S4 method for signature 'decomp' deseasonalize(object, ...) ## S4 method for signature 'decomp' detrend(object, ...)
## S4 method for signature 'decomp' trend(object, ...) ## S4 method for signature 'decomp' season(object, ...) ## S4 method for signature 'decomp' fitted(object, ...) ## S4 method for signature 'decomp' residuals(object, ...) ## S4 method for signature 'decomp' deseasonalize(object, ...) ## S4 method for signature 'decomp' detrend(object, ...)
object |
the estimation / decomposition object, for example
of class |
... |
without further use; implemented for compatibility only. |
Apply these functions directly to an estimation object, i.e. the result of a decomposition of a seasonal time series, in order to retrieve individual estimated components.
These methods return time series objects of class "ts"
that represent
the corresponding estimated component in the time series originally used in
the estimation process.
Xt <- log(EXPENDITURES) smoothing_options <- set_options(order_poly = 3) est <- deseats(Xt, smoothing_options = smoothing_options) trend_e <- trend(est) # Trend estimates season_e <- season(est) # Seasonality estimates trend_season_e <- fitted(est) # Trend + seasonality estimates resid_e <- residuals(est) # Residuals (observ. - trend - seasonality) ts_adj <- deseasonalize(est) # Seasonally adjusted series ts_notrend <- detrend(est) # Detrended series
Xt <- log(EXPENDITURES) smoothing_options <- set_options(order_poly = 3) est <- deseats(Xt, smoothing_options = smoothing_options) trend_e <- trend(est) # Trend estimates season_e <- season(est) # Seasonality estimates trend_season_e <- fitted(est) # Trend + seasonality estimates resid_e <- residuals(est) # Residuals (observ. - trend - seasonality) ts_adj <- deseasonalize(est) # Seasonally adjusted series ts_notrend <- detrend(est) # Detrended series
"zoo"
to "ts"
Allows for the conversion of time series objects of class "zoo"
to time series objects of class "ts"
. This is only suitable, if
the time series is observed in regular time intervals (monthly, quarterly,
yearly, etc.). The correct observation time points are then kept.
zoo_to_ts(xt)
zoo_to_ts(xt)
xt |
a time series object of class |
An equidistant time series object of class "zoo"
is transformed to
class "ts"
. This is particularly useful, since most functions of this
package work with objects of class "ts"
only.
An object of class "ts"
is returned.
# Create example zoo-object tp <- seq(from = as.Date("2020-01-01"), to = as.Date("2020-10-01"), by = "month") xt <- zoo::zoo(1:10, order.by = tp) xt # Transform into ts-object yt <- zoo_to_ts(xt) yt
# Create example zoo-object tp <- seq(from = as.Date("2020-01-01"), to = as.Date("2020-10-01"), by = "month") xt <- zoo::zoo(1:10, order.by = tp) xt # Transform into ts-object yt <- zoo_to_ts(xt) yt