From 63c2bba293c9da9788e26731a1e2f73c5af64aa5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tomasz=20Wo=C5=BAniak?= Date: Thu, 25 Jul 2024 17:14:37 +1000 Subject: [PATCH] included summary.ForecastsPANEL #17 --- NAMESPACE | 1 + R/summary.R | 95 +++++++++++++++++++++++++++++++++++ man/summary.ForecastsPANEL.Rd | 83 ++++++++++++++++++++++++++++++ 3 files changed, 179 insertions(+) create mode 100644 man/summary.ForecastsPANEL.Rd diff --git a/NAMESPACE b/NAMESPACE index b474671..4091867 100644 --- a/NAMESPACE +++ b/NAMESPACE @@ -6,6 +6,7 @@ S3method(estimate,PosteriorBVARPANEL) S3method(forecast,PosteriorBVARPANEL) S3method(plot,ForecastsPANEL) S3method(plot,PosteriorFEVDPANEL) +S3method(summary,ForecastsPANEL) S3method(summary,PosteriorBVARPANEL) S3method(summary,PosteriorFEVDPANEL) export(specify_bvarPANEL) diff --git a/R/summary.R b/R/summary.R index a552228..574c897 100644 --- a/R/summary.R +++ b/R/summary.R @@ -266,3 +266,98 @@ summary.PosteriorFEVDPANEL = function( summary(object[[which_c]], ...) } + + + + + +#' @title Provides posterior summary of country-specific Forecasts +#' +#' @description Provides posterior summary of the forecasts including their +#' mean, standard deviations, as well as 5 and 95 percentiles. +#' +#' @param object an object of class \code{ForecastsPANEL} obtained using the +#' \code{forecast()} function containing draws the predictive density. +#' @param which_c a positive integer or a character string specifying the country +#' for which the forecast should be plotted. +#' @param ... additional arguments affecting the summary produced. +#' +#' @return A list reporting the posterior mean, standard deviations, as well as +#' 5 and 95 percentiles of the forecasts for each of the variables and forecast +#' horizons. +#' +#' @method summary ForecastsPANEL +#' +#' @seealso \code{\link{forecast.PosteriorBVARPANEL}}, \code{\link{plot}} +#' +#' @author Tomasz Woźniak \email{wozniak.tom@pm.me} +#' +#' @examples +#' data(ilo_cubic_panel) # load the data +#' data(ilo_exogenous_variables) # load the exogenous variables +#' data(ilo_exogenous_forecasts) # load the exogenous forecast +#' set.seed(123) +#' +#' # specify the model +#' specification = specify_bvarPANEL$new(ilo_cubic_panel, exogenous = ilo_exogenous_variables) +#' burn_in = estimate(specification, 10) # run the burn-in +#' posterior = estimate(burn_in, 10) # estimate the model +#' +#' # forecast 6 years ahead +#' predictive = forecast(posterior, 6, exogenous_forecast = ilo_exogenous_forecasts) +#' summary(predictive, which_c = "POL") +#' +#' # workflow with the pipe |> +#' ############################################################ +#' set.seed(123) +#' ilo_cubic_panel |> +#' specify_bvarPANEL$new() |> +#' estimate(S = 10) |> +#' estimate(S = 20) |> +#' forecast(horizon = 2) |> +#' summary(which_c = "POL") +#' +#' # conditional forecasting 6 years ahead conditioning on +#' # provided future values for the Gross Domestic Product +#' # growth rate +#' ############################################################ +#' data(ilo_conditional_forecasts) # load the conditional forecasts of dgdp +#' specification = specify_bvarPANEL$new(ilo_cubic_panel) # specify the model +#' burn_in = estimate(specification, 10) # run the burn-in +#' posterior = estimate(burn_in, 10) # estimate the model +#' # forecast 6 years ahead +#' predictive = forecast(posterior, 6, conditional_forecast = ilo_conditional_forecasts) +#' summary(predictive, which_c = "POL") +#' +#' # workflow with the pipe |> +#' ############################################################ +#' set.seed(123) +#' ilo_cubic_panel |> +#' specify_bvarPANEL$new() |> +#' estimate(S = 10) |> +#' estimate(S = 20) |> +#' forecast( +#' horizon = 6, +#' conditional_forecast = ilo_conditional_forecasts +#' ) |> +#' summary(which_c = "POL") +#' +#' @export +summary.ForecastsPANEL = function( + object, + which_c, + ... +) { + + if (is.numeric(which_c)) { + stopifnot("Argument which_c must be a positive integer indicating one of the countries." + = length(which_c) == 1 & which_c %% 1 == 0 & which_c > 0 & which_c <= length(object)) + } else if (is.character(which_c)) { + stopifnot("Argument which_c must be a character string indicating one of the countries." + = which_c %in% names(object)) + } else { + stop("Argument which_c must be either a positive integer or a character string.") + } + + summary(object[[which_c]], ...) +} # END summary.ForecastsPANEL diff --git a/man/summary.ForecastsPANEL.Rd b/man/summary.ForecastsPANEL.Rd new file mode 100644 index 0000000..e34acf6 --- /dev/null +++ b/man/summary.ForecastsPANEL.Rd @@ -0,0 +1,83 @@ +% Generated by roxygen2: do not edit by hand +% Please edit documentation in R/summary.R +\name{summary.ForecastsPANEL} +\alias{summary.ForecastsPANEL} +\title{Provides posterior summary of country-specific Forecasts} +\usage{ +\method{summary}{ForecastsPANEL}(object, which_c, ...) +} +\arguments{ +\item{object}{an object of class \code{ForecastsPANEL} obtained using the +\code{forecast()} function containing draws the predictive density.} + +\item{which_c}{a positive integer or a character string specifying the country +for which the forecast should be plotted.} + +\item{...}{additional arguments affecting the summary produced.} +} +\value{ +A list reporting the posterior mean, standard deviations, as well as +5 and 95 percentiles of the forecasts for each of the variables and forecast +horizons. +} +\description{ +Provides posterior summary of the forecasts including their +mean, standard deviations, as well as 5 and 95 percentiles. +} +\examples{ +data(ilo_cubic_panel) # load the data +data(ilo_exogenous_variables) # load the exogenous variables +data(ilo_exogenous_forecasts) # load the exogenous forecast +set.seed(123) + +# specify the model +specification = specify_bvarPANEL$new(ilo_cubic_panel, exogenous = ilo_exogenous_variables) +burn_in = estimate(specification, 10) # run the burn-in +posterior = estimate(burn_in, 10) # estimate the model + +# forecast 6 years ahead +predictive = forecast(posterior, 6, exogenous_forecast = ilo_exogenous_forecasts) +summary(predictive, which_c = "POL") + +# workflow with the pipe |> +############################################################ +set.seed(123) +ilo_cubic_panel |> + specify_bvarPANEL$new() |> + estimate(S = 10) |> + estimate(S = 20) |> + forecast(horizon = 2) |> + summary(which_c = "POL") + +# conditional forecasting 6 years ahead conditioning on +# provided future values for the Gross Domestic Product +# growth rate +############################################################ +data(ilo_conditional_forecasts) # load the conditional forecasts of dgdp +specification = specify_bvarPANEL$new(ilo_cubic_panel) # specify the model +burn_in = estimate(specification, 10) # run the burn-in +posterior = estimate(burn_in, 10) # estimate the model +# forecast 6 years ahead +predictive = forecast(posterior, 6, conditional_forecast = ilo_conditional_forecasts) +summary(predictive, which_c = "POL") + +# workflow with the pipe |> +############################################################ +set.seed(123) +ilo_cubic_panel |> + specify_bvarPANEL$new() |> + estimate(S = 10) |> + estimate(S = 20) |> + forecast( + horizon = 6, + conditional_forecast = ilo_conditional_forecasts + ) |> + summary(which_c = "POL") + +} +\seealso{ +\code{\link{forecast.PosteriorBVARPANEL}}, \code{\link{plot}} +} +\author{ +Tomasz Woźniak \email{wozniak.tom@pm.me} +}