Skip to contents

cov_adj() takes a fitted covariance model and returns the information necessary for adjusting direct adjustment model estimates and associated standard errors for covariates. Standard errors will reflect adjustments made to the outcomes as well as contributions to sampling variability arising from the estimates of the covariance adjustment model coefficients.

Usage

cov_adj(model, newdata = NULL, specification = NULL, by = NULL)

Arguments

model

any model that inherits from a glm, lm, or robustbase::lmrob object

newdata

a dataframe of new data. Default is NULL, in which case a dataframe is sought from higher up the call stack.

specification

a StudySpecification object. Default is NULL, in which case a StudySpecification object is sought from higher up the call stack.

by

optional; a string or named vector of unique identifier columns in the data used to create specification and the data used to fit the covariance adjustment model. Default is NULL, in which case unit of assignment columns are used for identification (even if they do not uniquely identify units of observation). If a named vector is provided, names should represent variables in the data used to create specification, while values should represent variables in the covariance adjustment data.

Value

A SandwichLayer if specification is not NULL or a StudySpecification object is found in the call stack, otherwise a PreSandwichLayer object

Details

Prior to generating adjustments, cov_adj() identifies the treatment variable specified in the StudySpecification object passed to specification and replaces all values with a reference level. If the treatment has logical type, this reference level is FALSE, and if it has numeric type, this is the smallest non-negative value (which means 0 for 0/1 binary). Factor treatments are not currently supported for StudySpecification objects.

The values of the output vector represent adjustments for the outcomes in newdata if newdata is provided; adjustments for the outcomes in the data used to fit a teeMod model if cov_adj() is called within the offset argument of the model fit; or they are the fitted values from model if no relevant dataframe can be extracted from the call stack. The length of the output of cov_adj() will match the number of rows of the dataframe used.

Examples

data(STARdata)

y0hat_read <- lm(readk ~ gender + ethnicity + lunchk +
                     ladderk + experiencek + tethnicityk,
                 data = STARdata, subset = stark !="small")

STARspec <- rct_spec(stark ~ unit_of_assignment(studentid),
                     data = STARdata)
ett_wts    <- ett(STARspec, data = STARdata,
                  dichotomy= stark =="small" ~.)

ett_read <- lm(readk ~ assigned(dichotomy= stark =="small" ~.),
               ### expect warning about NAs generated here:
               offset = cov_adj(y0hat_read, newdata = STARdata),
               data = STARdata,
               weights = ett_wts)
#> Warning: Some covariance adjustments are NA; be careful of dropping these observations when fitting the ITT effect model
#> Warning: Some covariance adjustments are NA; be careful of dropping these observations when fitting the ITT effect model
coef(ett_read)
#>                                (Intercept) 
#>                              -1.150011e-13 
#> assigned(dichotomy = stark == "small" ~ .) 
#>                               5.554179e+00 
ett_read |> as.lmitt() |> vcov()
#> Warning: Some covariance adjustments are NA; be careful of dropping these observations when fitting the ITT effect model
#> Warning: Some covariance adjustments are NA; be careful of dropping these observations when fitting the ITT effect model
#> Warning: Some covariance adjustments are NA; be careful of dropping these observations when fitting the ITT effect model
#> Warning: Some covariance adjustments are NA; be careful of dropping these observations when fitting the ITT effect model
#>                                            (Intercept)
#> (Intercept)                                  0.6603452
#> assigned(dichotomy = stark == "small" ~ .)   0.3846596
#>                                            assigned(dichotomy = stark == "small" ~ .)
#> (Intercept)                                                                 0.3846596
#> assigned(dichotomy = stark == "small" ~ .)                                  0.9058149
#> attr(,"type")
#> [1] "CR0"

ate_read <- lmitt(readk ~ 1, STARspec, STARdata,
                  dichotomy= stark =="small" ~.,
                  offset = cov_adj(y0hat_read, newdata = STARdata),
                  weights = "ate")
#> Warning: Some covariance adjustments are NA; be careful of dropping these observations when fitting the ITT effect model
show(ate_read)
#>   stark. 
#> 5.554179 
coef(ate_read)
#>   (Intercept)        stark. 
#> -1.066237e-13  5.554179e+00 
vcov(ate_read)
#>             (Intercept)    stark.
#> (Intercept)   0.6603452 0.3846596
#> stark.        0.3846596 0.9058149
#> attr(,"type")
#> [1] "CR0"

ate_read_loc <-
    lmitt(readk ~ schoolk, STARspec, STARdata,
          dichotomy= stark =="small" ~.,
          offset = cov_adj(y0hat_read, newdata = STARdata),
          weights = "ate")
#> Warning: Some covariance adjustments are NA; be careful of dropping these observations when fitting the ITT effect model
show(ate_read_loc)
#> `stark._schoolkinner-city`     stark._schoolksuburban 
#>                   5.403909                   5.888685 
#>        stark._schoolkrural        stark._schoolkurban 
#>                   5.980288                   2.155538