sequential_g {DirectEffects} | R Documentation |
Perform linear sequential g-estimation to estimate the controlled direct effect of a treatment net the effect of a mediator.
Description
Perform linear sequential g-estimation to estimate the controlled direct effect of a treatment net the effect of a mediator.
Usage
sequential_g(
formula,
data,
subset,
weights,
na.action,
offset,
contrasts = NULL,
verbose = TRUE,
...
)
Arguments
formula |
formula specification of the first-stage,
second-stage, and blip-down models. The right-hand side of the
formula should have three components separated by the |
data |
A dataframe to apply |
subset |
A vector of logicals indicating which rows of |
weights |
an optional vector of weights to be used in the fitting
process. Should be |
na.action |
a function which indicates what should happen
when the data contain |
offset |
this can be used to specify an a priori known
component to be included in the linear predictor during fitting.
This should be |
contrasts |
an optional list. See the |
verbose |
logical indicating whether to suppress progress bar. Default is FALSE. |
... |
additional arguments to be passed to the low level regression fitting functions (see below). |
Details
The sequential_g
function implements the linear
sequential g-estimator developed by Vansteelandt (2009) with the
consistent variance estimator developed by Acharya, Blackwell, and
Sen (2016).
The formula specifies specifies the full first-stage model
including treatment, baseline confounders, intermediate
confounders, and the mediators. The user places |
bars to
separate out these different components of the model. For
example, the formula should have the form y ~ tr + x1 + x2
| z1 + z2 | m1 + m2
. where tr
is the name of the
treatment variable, x1
and x2
are baseline
covariates, z1
and z2
are intermediate covariates,
and m1
and m2
are the names of the mediator
variables. This last set of variables specify the 'blip-down' or
'demediation' function that is used to remove the average effect
of the mediator (possibly interacted) from the outcome to create
the blipped-down outcome. This blipped-down outcome is the passed
to a standard linear model with the covariates as specified for
the direct effects model.
See the references below for more details.
Value
Returns an object of class
A "seqg"
. Similar
to the output of a call to lm
. Contains the following
components:
coefficients: a vector of named coefficients for the direct effects model.
residuals: the residuals, that is the blipped-down outcome minus the fitted values.
rank: the numeric rank of the fitted linear direct effects model.
fitted.values: the fitted mean values of the direct effects model.
weights: (only for weighted fits) the specified weights.
df.residual: the residual degrees of freedom for the direct effects model.
aliased: logical vector indicating if any of the terms were dropped or aliased due to perfect collinearity.
terms: the list of
terms
object used. One for the baseline covariates and treatment (X
) and one for the variables in the blip-down model (M
).formula: the
formula
object used, possibly modified to drop a constant in the blip-down model.call: the matched call.
na.action: (where relevant) information returned by
model.frame
of the special handling ofNA
s.xlevels: the levels of the factor variables.
contrasts: the contrasts used for the factor variables.
first_mod: the output from the first-stage regression model.
model: full model frame, including all variables.
Ytilde: the blipped-down response vector.
X: the model matrix for the second stage.
M: the model matrix for demediation/blip-down function.
In addition, non-null fits will have components assign
,
effects
, and qr
from the output of lm.fit
or
lm.wfit
, whichever is used.
References
Vansteelandt, S. (2009). Estimating Direct Effects in Cohort and Case-Control Studies. Epidemiology, 20(6), 851-860.
Acharya, Avidit, Blackwell, Matthew, and Sen, Maya. (2016) "Explaining Causal Effects Without Bias: Detecting and Assessing Direct Effects." American Political Science Review 110:3 pp. 512-529
Examples
data(ploughs)
form_main <- women_politics ~ plow +
agricultural_suitability + tropical_climate + large_animals +
political_hierarchies + economic_complexity +
rugged | years_civil_conflict +
years_interstate_conflict + oil_pc +
european_descent + communist_dummy + polity2_2000 +
serv_va_gdp2000 | centered_ln_inc + centered_ln_incsq
direct <- sequential_g(form_main, ploughs)
summary(direct)