Title: | Dynamic Simulations of Autoregressive Relationships |
---|---|
Description: | Dynamic simulations and graphical depictions of autoregressive relationships. |
Authors: | Christopher Gandrud [aut, cre], Laron K. Williams [aut], Guy D. Whitten [aut] |
Maintainer: | Christopher Gandrud <[email protected]> |
License: | GPL-3 |
Version: | 1.2.3 |
Built: | 2025-01-20 05:41:21 UTC |
Source: | https://github.com/christophergandrud/dynsim |
dynsim
dynamic simulations of autoregressive relationships
dynsim(obj, ldv, scen, n = 10, sig = 0.95, num = 1000, shocks = NULL, ...)
dynsim(obj, ldv, scen, n = 10, sig = 0.95, num = 1000, shocks = NULL, ...)
obj |
the output object the estimation model. |
ldv |
character. Names the lagged dependent variable |
scen |
data frame or list of data frames. Specifies the values of the
variables used to generate the predicted values when |
n |
numeric. Specifies the number of iterations (or time period) over which the program will generate the predicted value of the dependent variable. The default is 10. |
sig |
numeric. Specifies the level of statistical significance of the confidence intervals. Any value allowed be greater than 0 and cannot be greater than 1. |
num |
numeric. Specifies the number of simulations to compute for each
value of |
shocks |
data frame. Allows the user to choose independent variables,
their values, and times to introduce these values. The first column of the
data frame must be called |
... |
arguments to pass to methods. |
A post-estimation technique for producing dynamic simulations of autoregressive models.
The command returns a data.frame
and dynsim
class
object. This can contain up to columns elements:
scenNumber
: The scenario number.
time
: The time points.
shock.
: Columns containing the values of the shock variables
at each point in time
.
ldvMean
: Mean of the simulation distribution.
ldvLower
: Lower bound of the simulation distribution's
central interval set with sig
.
ldvUpper
: Upper bound of the simulation distribution's
central interval set with sig
.
ldvLower50
: Lower bound of the simulation distribution's
central 50 percent interval.
ldvUpper50
: Upper bound of the simulation distribution's
central 50 percent interval.
The output object is a data frame class object. Do with it as you like.
Williams, L. K., & Whitten, G. D. (2011). Dynamic Simulations of Autoregressive Relationships. The Stata Journal, 11(4), 577-588.
Williams, L. K., & Whitten, G. D. (2012). But Wait, There's More! Maximizing Substantive Inferences from TSCS Models. Journal of Politics, 74(03), 685-693.
# Load package library(DataCombine) # Load Grunfeld data data(grunfeld, package = "dynsim") # Create lag invest variable grunfeld <- slide(grunfeld, Var = "invest", GroupVar = "company", NewVar = "InvestLag") # Convert company to factor for fixed-effects specification grunfeld$company <- as.factor(grunfeld$company) # Estimate basic model M1 <- lm(invest ~ InvestLag + mvalue + kstock + company, data = grunfeld) # Estimate model with interaction between mvalue and kstock M2 <- lm(invest ~ InvestLag + mvalue*kstock + company, data = grunfeld) # Set up scenarios for company 4 ## List version ## attach(grunfeld) Scen1 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = quantile(mvalue, 0.05), kstock = quantile(kstock, 0.05), company4 = 1) Scen2 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = mean(mvalue), kstock = mean(kstock), company4 = 1) Scen3 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = quantile(mvalue, 0.95), kstock = quantile(kstock, 0.95), company4 = 1) detach(grunfeld) ## Not run: ## Alternative data frame version of the scenario builder ## attach(grunfeld) ScenComb <- data.frame(InvestLag = rep(mean(InvestLag, na.rm = TRUE), 3), mvalue = c(quantile(mvalue, 0.95), mean(mvalue), quantile(mvalue, 0.05)), kstock = c(quantile(kstock, 0.95), mean(kstock), quantile(kstock, 0.05)), company4 = rep(1, 3) ) detach(grunfeld) ## End(Not run) # Combine into a single list ScenComb <- list(Scen1, Scen2, Scen3) ## Run dynamic simulations without shocks and no interactions Sim1 <- dynsim(obj = M1, ldv = "InvestLag", scen = ScenComb, n = 20) ## Run dynamic simulations without shocks and interactions Sim2 <- dynsim(obj = M2, ldv = "InvestLag", scen = ScenComb, n = 20) ## Run dynamic simulations with shocks # Create data frame of shock values mShocks <- data.frame(times = c(5, 10), kstock = c(100, 1000), mvalue = c(58, 5000)) # Run simulations without interactions Sim3 <- dynsim(obj = M1, ldv = "InvestLag", scen = ScenComb, n = 20, shocks = mShocks) # Run simulations with interactions Sim4 <- dynsim(obj = M2, ldv = "InvestLag", scen = ScenComb, n = 20, shocks = mShocks)
# Load package library(DataCombine) # Load Grunfeld data data(grunfeld, package = "dynsim") # Create lag invest variable grunfeld <- slide(grunfeld, Var = "invest", GroupVar = "company", NewVar = "InvestLag") # Convert company to factor for fixed-effects specification grunfeld$company <- as.factor(grunfeld$company) # Estimate basic model M1 <- lm(invest ~ InvestLag + mvalue + kstock + company, data = grunfeld) # Estimate model with interaction between mvalue and kstock M2 <- lm(invest ~ InvestLag + mvalue*kstock + company, data = grunfeld) # Set up scenarios for company 4 ## List version ## attach(grunfeld) Scen1 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = quantile(mvalue, 0.05), kstock = quantile(kstock, 0.05), company4 = 1) Scen2 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = mean(mvalue), kstock = mean(kstock), company4 = 1) Scen3 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = quantile(mvalue, 0.95), kstock = quantile(kstock, 0.95), company4 = 1) detach(grunfeld) ## Not run: ## Alternative data frame version of the scenario builder ## attach(grunfeld) ScenComb <- data.frame(InvestLag = rep(mean(InvestLag, na.rm = TRUE), 3), mvalue = c(quantile(mvalue, 0.95), mean(mvalue), quantile(mvalue, 0.05)), kstock = c(quantile(kstock, 0.95), mean(kstock), quantile(kstock, 0.05)), company4 = rep(1, 3) ) detach(grunfeld) ## End(Not run) # Combine into a single list ScenComb <- list(Scen1, Scen2, Scen3) ## Run dynamic simulations without shocks and no interactions Sim1 <- dynsim(obj = M1, ldv = "InvestLag", scen = ScenComb, n = 20) ## Run dynamic simulations without shocks and interactions Sim2 <- dynsim(obj = M2, ldv = "InvestLag", scen = ScenComb, n = 20) ## Run dynamic simulations with shocks # Create data frame of shock values mShocks <- data.frame(times = c(5, 10), kstock = c(100, 1000), mvalue = c(58, 5000)) # Run simulations without interactions Sim3 <- dynsim(obj = M1, ldv = "InvestLag", scen = ScenComb, n = 20, shocks = mShocks) # Run simulations with interactions Sim4 <- dynsim(obj = M2, ldv = "InvestLag", scen = ScenComb, n = 20, shocks = mShocks)
dynsim
dynsimGG
uses ggplot2 to plot dynamic simulation results
created by dynsim
.
dynsimGG( obj, lsize = 1, color, alpha = 0.5, xlab = "\nTime", ylab = "Predicted Value\n", title = "", leg.name = "Scenario", leg.labels, legend = "legend", shockplot.var, shockplot.ylab, shockplot.heights = c(12, 4), shockplot.heights.units = c("cm", "cm") )
dynsimGG( obj, lsize = 1, color, alpha = 0.5, xlab = "\nTime", ylab = "Predicted Value\n", title = "", leg.name = "Scenario", leg.labels, legend = "legend", shockplot.var, shockplot.ylab, shockplot.heights = c(12, 4), shockplot.heights.units = c("cm", "cm") )
obj |
a |
lsize |
size of the smoothing line. Default is 1. See ggplot2. |
color |
character string. Specifies the color of the lines and ribbons.
If only one scenario is to be plotted then it can either be a single color
value using any color value allowed by ggplot2. The default is
the hexadecimal color |
alpha |
numeric. Alpha (e.g. transparency) for the ribbons. Default is
|
xlab |
a label for the plot's x-axis. |
ylab |
a label of the plot's y-axis. |
title |
the plot's main title. |
leg.name |
name of the legend (if applicable). |
leg.labels |
character vector specifying the labels for each scenario in the legend. |
legend |
specifies what type of legend to include (if applicable). The
default is |
shockplot.var |
character string naming the one shock variable to plot fitted values of over time specified underneath the main plot. |
shockplot.ylab |
character string for the shockplot's y-axis label. |
shockplot.heights |
numeric vector with of length 2 with units of the main and shockplot height plots. |
shockplot.heights.units |
a character vector of length 2 with the
unit types for the values in |
Plots dynamic simulations of autoregressive relationships from
dynsim
. The central line is the mean of the simulation
distributions. The outer ribbon is the furthest extent of the simulation
distributions' central intervals found in dynsim
with the
sig
argument. The middle ribbons plot the limits of the simulation
distributions' central 50
# Load package library(DataCombine) # Load Grunfeld data data(grunfeld, package = "dynsim") # Create lag invest variable grunfeld <- slide(grunfeld, Var = "invest", GroupVar = "company", NewVar = "InvestLag") # Convert company to factor for fixed-effects specification grunfeld$company <- as.factor(grunfeld$company) # Estimate basic model M1 <- lm(invest ~ InvestLag + mvalue + kstock + company, data = grunfeld) # Set up scenarios for company 4 attach(grunfeld) Scen1 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = quantile(mvalue, 0.05), kstock = quantile(kstock, 0.05), company4 = 1) Scen2 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = mean(mvalue), kstock = mean(kstock), company4 = 1) Scen3 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = quantile(mvalue, 0.95), kstock = quantile(kstock, 0.95), company4 = 1) detach(grunfeld) # Combine into a single list ScenComb <- list(Scen1, Scen2, Scen3) ## Run dynamic simulations without shocks Sim1 <- dynsim(obj = M1, ldv = "InvestLag", scen = ScenComb, n = 20) # Create plot legend label Labels <- c("5th Percentile", "Mean", "95th Percentile") # Plot dynsimGG(Sim1, leg.labels = Labels) ## Run dynamic simulations with shocks # Create data frame of shock values mShocks <- data.frame(times = c(5, 10), kstock = c(100, 1000)) # Run simulations Sim2 <- dynsim(obj = M1, ldv = "InvestLag", scen = ScenComb, n = 20, shocks = mShocks) # Plot dynsimGG(Sim2, leg.labels = Labels) # Plot with accompanying shock plot dynsimGG(Sim2, leg.labels = Labels, shockplot.var = "kstock")
# Load package library(DataCombine) # Load Grunfeld data data(grunfeld, package = "dynsim") # Create lag invest variable grunfeld <- slide(grunfeld, Var = "invest", GroupVar = "company", NewVar = "InvestLag") # Convert company to factor for fixed-effects specification grunfeld$company <- as.factor(grunfeld$company) # Estimate basic model M1 <- lm(invest ~ InvestLag + mvalue + kstock + company, data = grunfeld) # Set up scenarios for company 4 attach(grunfeld) Scen1 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = quantile(mvalue, 0.05), kstock = quantile(kstock, 0.05), company4 = 1) Scen2 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = mean(mvalue), kstock = mean(kstock), company4 = 1) Scen3 <- data.frame(InvestLag = mean(InvestLag, na.rm = TRUE), mvalue = quantile(mvalue, 0.95), kstock = quantile(kstock, 0.95), company4 = 1) detach(grunfeld) # Combine into a single list ScenComb <- list(Scen1, Scen2, Scen3) ## Run dynamic simulations without shocks Sim1 <- dynsim(obj = M1, ldv = "InvestLag", scen = ScenComb, n = 20) # Create plot legend label Labels <- c("5th Percentile", "Mean", "95th Percentile") # Plot dynsimGG(Sim1, leg.labels = Labels) ## Run dynamic simulations with shocks # Create data frame of shock values mShocks <- data.frame(times = c(5, 10), kstock = c(100, 1000)) # Run simulations Sim2 <- dynsim(obj = M1, ldv = "InvestLag", scen = ScenComb, n = 20, shocks = mShocks) # Plot dynsimGG(Sim2, leg.labels = Labels) # Plot with accompanying shock plot dynsimGG(Sim2, leg.labels = Labels, shockplot.var = "kstock")
A data set from Grunfeld (1958)
A data set with 200 observations and 6 variables
Grunfeld, Yehuda. 1958. The Determinants of Corporate Investment. PhD thesis. University of Chicago.