When using bal.tab()
with clustered data, the output will be different from the case with single-level data, and there are some options that are common across all bal.tab()
methods. This page outlines the outputs and options in this case.
There are two main components of the output of bal.tab()
with clustered data: the within-cluster balance summaries and the across-cluster balance summary. The within-cluster balance summaries display balance for units within each cluster separately.
The across-cluster balance summary pools information across the within-cluster balance summaries to simplify balance assessment. It provides a combination (e.g., mean or maximum) of each balance statistic for each covariate across all clusters. This allows you to see how bad the worst imbalance is and what balance looks like on average. The balance summary will not be computed if longitudinal treatments, multi-category treatments, or multiply imputed data are used.
Allowable arguments
There are four arguments for each bal.tab()
method that can handle clustered data: cluster
, which.cluster
, cluster.summary
, and cluster.fun
.
cluster
A vector of cluster membership. This can be factor, character, or numeric vector. This argument is required to let
bal.tab()
know that the data is clustered. If adata
argument is specified, this can also be the name of a variable indata
that contains cluster membership.which.cluster
This is a display option that does not affect computation. If
.all
(the default), all clusters incluster
will be displayed. If.none
, no clusters will be displayed. Otherwise, can be a vector of cluster names or numerical indices for which to display balance. Indices correspond to the alphabetical order of cluster names (or the order of cluster levels if a factor).cluster.summary
This is a display option that does not affect computation. If
TRUE
, the balance summary across clusters will be displayed. The default isTRUE
, and ifwhich.cluster
is.none
, it will automatically be set toTRUE
.cluster.fun
This is a display option that does not affect computation. Can be "min", "mean", or "max" and corresponds to which function is used in the across-cluster summary to combine results across clusters. For example, if
cluster.fun = "mean"
the mean balance statistic across clusters will be displayed. The default whenabs = FALSE
in thebal.tab()
call is to display all three. The default whenabs = FALSE
in thebal.tab()
call is to display just the mean and max balance statistic.
Output
The output is a bal.tab.cluster
object, which inherits from bal.tab
. It has the following elements:
Cluster.Balance
: For each cluster, a regularbal.tab
object containing a balance table, a sample size summary, and other balance assessment tools, depending on which options are specified.Cluster.Summary
: The balance summary across clusters. This will include the combination of each balance statistic for each covariate across all clusters according to the value ofcluster.fun
.Observations
: A table of sample sizes or effective sample sizes for each cluster before and after adjustment.
As with other methods, multiple weights can be specified, and values for all weights will appear in all tables.