Transform and combine clarify_est
objects
Source: R/transform.clarify_est.R
transform.clarify_est.Rd
transform()
modifies a clarify_est
object by allowing for the calculation of new quantities from the existing quantities without re-simulating them. cbind()
binds two clarify_est
objects together.
Arguments
- _data
the
clarify_est
object to be transformed.- ...
for
transform()
, arguments in the formname = value
, wherename
is the name of a new quantity to be computed andvalue
is an expression that is a function of the existing quantities corresponding to the new quantity to be computed. See Details. Forcbind()
,clarify_est
objects to be combined.- deparse.level
ignored.
Value
A clarify_est
object, either with new columns added (when using transform()
) or combining two clarify_est
objects. Note that any type attributes corresponding to the sim_apply()
wrapper used (e.g., sim_ame()
) is lost when using either function. This can affect any helper functions (e.g., plot()
) designed to work with the output of specific wrappers.
Details
For transform()
, the expression on the right side of the =
should use the names of the existing quantities (e.g., `E[Y(1)]` - `E[Y(1)]`
), with `
appropriately included when the quantity name include parentheses or brackets. Alternatively, it can use indexes prefixed by .b
, e.g., .b2 - .b1
, to refer to the corresponding quantity by position. This can aid in computing derived quantities of quantities with complicated names. (Note that if a quantity is named something like .b1
, it will need to be referred to by position rather than name, as the position-based label takes precedence). See examples. Setting an existing value to NULL
will remove that quantity from the object.
cbind()
does not rename the quanities or check for uniqueness of the names, so it is important to rename them yourself prior to combining the objects.
Examples
data("lalonde", package = "MatchIt")
# Fit the model
fit <- lm(re78 ~ treat * (age + educ + race +
married + re74 + re75),
data = lalonde)
# Simulate coefficients
set.seed(123)
s <- sim(fit, n = 100)
# Average adjusted predictions for `treat` within
# subsets of `race`
est_b <- sim_ame(s, var = "treat", verbose = FALSE,
subset = race == "black")
est_b
#> A `clarify_est` object (from `sim_ame()`)
#> - Average adjusted predictions for `treat`
#> - 100 simulated values
#> - 2 quantities estimated:
#> E[Y(0)] 4589.139
#> E[Y(1)] 6148.136
est_h <- sim_ame(s, var = "treat", verbose = FALSE,
subset = race == "hispan")
est_h
#> A `clarify_est` object (from `sim_ame()`)
#> - Average adjusted predictions for `treat`
#> - 100 simulated values
#> - 2 quantities estimated:
#> E[Y(0)] 7014.868
#> E[Y(1)] 7183.475
# Compute differences between adjusted predictions
est_b <- transform(est_b,
diff = `E[Y(1)]` - `E[Y(0)]`)
est_b
#> A `clarify_est` object (from `sim_apply()`)
#> - 100 simulated values
#> - 3 quantities estimated:
#> E[Y(0)] 4589.139
#> E[Y(1)] 6148.136
#> diff 1558.997
est_h <- transform(est_h,
diff = `E[Y(1)]` - `E[Y(0)]`)
est_h
#> A `clarify_est` object (from `sim_apply()`)
#> - 100 simulated values
#> - 3 quantities estimated:
#> E[Y(0)] 7014.8679
#> E[Y(1)] 7183.4751
#> diff 168.6072
# Bind estimates together after renaming
names(est_b) <- paste0(names(est_b), "_b")
names(est_h) <- paste0(names(est_h), "_h")
est <- cbind(est_b, est_h)
est
#> A `clarify_est` object (from `sim_apply()`)
#> - 100 simulated values
#> - 6 quantities estimated:
#> E[Y(0)]_b 4589.1390
#> E[Y(1)]_b 6148.1362
#> diff_b 1558.9972
#> E[Y(0)]_h 7014.8679
#> E[Y(1)]_h 7183.4751
#> diff_h 168.6072
# Compute difference in race-specific differences
est <- transform(est,
`diff-diff` = .b6 - .b3)
summary(est,
parm = c("diff_b", "diff_h", "diff-diff"))
#> Estimate 2.5 % 97.5 %
#> diff_b 1559 -148 3472
#> diff_h 169 -5763 4870
#> diff-diff -1390 -7645 3299
# Remove last quantity by using `NULL`
transform(est, `diff-diff` = NULL)
#> A `clarify_est` object (from `sim_apply()`)
#> - 100 simulated values
#> - 6 quantities estimated:
#> E[Y(0)]_b 4589.1390
#> E[Y(1)]_b 6148.1362
#> diff_b 1558.9972
#> E[Y(0)]_h 7014.8679
#> E[Y(1)]_h 7183.4751
#> diff_h 168.6072