| Type: | Package | 
| Title: | Optimal Multilevel Matching using a Network Algorithm | 
| Version: | 1.1.14 | 
| Date: | 2025-4-17 | 
| Maintainer: | Sam Pimentel <spi@berkeley.edu> | 
| Description: | Performs multilevel matches for data with cluster- level treatments and individual-level outcomes using a network optimization algorithm. Functions for checking balance at the cluster and individual levels are also provided, as are methods for permutation-inference-based outcome analysis. Details in Pimentel et al. (2018) <doi:10.1214/17-AOAS1118>. The optmatch package, which is useful for running many of the provided functions, may be downloaded from Github at https://github.com/markmfredrickson/optmatch if not available on CRAN. | 
| Depends: | R (≥ 4.3.0), rlang, dplyr | 
| Imports: | rcbsubset (≥ 1.1.4), plyr, coin, weights, mvtnorm, MASS, sandwich, magrittr | 
| Suggests: | optmatch, testthat, knitr, rrelaxiv | 
| Additional_repositories: | https://errickson.net/rrelaxiv/ | 
| License: | MIT + file LICENSE | 
| VignetteBuilder: | knitr | 
| RoxygenNote: | 7.3.2 | 
| NeedsCompilation: | no | 
| Packaged: | 2025-04-18 05:27:46 UTC; sdbpimentel | 
| Author: | Luke Keele [aut], Luke Miratrix [aut], Sam Pimentel [aut, cre], Paul Rosenbaum [ctb] | 
| Repository: | CRAN | 
| Date/Publication: | 2025-04-18 05:50:02 UTC | 
Extract School-Level Covariates
Description
Given a vector of variables of interest for students in a single school, extracts a single value for the school
Usage
agg(x)
Arguments
| x | a vector containing student-level observations for a school. If it is a factor it must contain only a single level. | 
Details
If the input is numeric, agg returns the mean; if the input is not
numeric, an error will be thrown unless all values are the same, in which
case the single unique value will be returned.
Value
A single value of the same type as the input vector.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
Collect Matched Samples
Description
After students and schools have both been matched separately, assembles the matched student samples corresponding to the school match into a single dataframe of student-level data.
Usage
assembleMatch(student.matches, school.match, school.id, treatment)
Arguments
| student.matches | a list of lists object produced by
 | 
| school.match | a dataframe, produced by  | 
| school.id | the name of the column storing the unique school identifier
(in the dataframes stored in  | 
| treatment | the name of the column storing the binary treatment status
indicator (in the dataframes stored in  | 
Value
a dataframe containing the full set of matched samples for the multilevel match.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
Performs balance checking after multilevel matching.
Description
This function checks balance after multilevel balance. It checks balance on both level-one (student) and level-two (school) covariates.
Usage
balanceMulti(
  match.obj,
  student.cov = NULL,
  school.cov = NULL,
  include.tests = TRUE,
  single.table = FALSE
)
Arguments
| match.obj | A multilevel match object | 
| student.cov | Names of student level covariates that you want to check balance | 
| school.cov | Names of school level covariates for which you want to check balance, if any. | 
| include.tests | If TRUE include tests for balance. FALSE just report the means and differences. | 
| single.table | If FALSE include a list of student and school covariates separately. TRUE means single balance table. | 
Details
This function returns a list which include balance checks for before and after matching for both level-one and level-two covariates. Balance statistics include treated and control means, standardized differences, which is the difference in means divided by the pooled standard deviation before matching, and p-values for mean differences. It extracts the matched data and calls 'balanceTable' for student and school level covariates.
Value
| students | Balance table for student level covariates, as a dataframe. | 
| schools | Balance table for school level covariates, as a dataframe. | 
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu Sam Pimentel, University of Pennsylvania, spi@wharton.upenn.edu
See Also
See also matchMulti, matchMultisens,
matchMultioutcome, rematchSchools
Examples
	## Not run: 
# Load Catholic school data
data(catholic_schools)
student.cov <- c('minority','female','ses','mathach')
# Check balance student balance before matching
balanceTable(catholic_schools[c(student.cov,'sector')],  treatment = 'sector')
#Match schools but not students within schools
match.simple <- matchMulti(catholic_schools, treatment = 'sector',
school.id = 'school', match.students = FALSE)
#Check balance after matching - this checks both student and school balance
balanceMulti(match.simple, student.cov = student.cov)
## End(Not run)
Create Balance Table
Description
Given an unmatched sample of treated and control units and (optionally) a matched sample from the same data, produces a table with pre- and post-match measures of covariate balance.
Usage
balanceTable(
  df.orig,
  df.match = NULL,
  treatment,
  school.id = NULL,
  var.names = NULL,
  include.tests = FALSE,
  verbose = FALSE
)
Arguments
| df.orig | a data frame containing the data before matching | 
| df.match | an optional data frame containing the matched sample. Must have all variable names to be balanced. | 
| treatment | name of the binary indicator for treatment status | 
| school.id | Identifier for groups (for example schools); need to pass if p-values for balance statistics are desired. | 
| var.names | List of variable names to calculate balance for. If NULL, use all variables found in the df.orig data.frame. | 
| include.tests | Include tests of imbalance on covariates (TRUE/FALSE). | 
| verbose | a logical value indicating whether detailed output should be printed. | 
Details
This table can also include p-values for tests of whether the balance is statistically significant. These tests assume randomization at the cluster level. We recommend looking at the standardized differences rather than p-values to assess severity of imbalance, however.
The two tests, for each covariate are (1) Aggregation, where the covariates are averaged by each cluster, followed by a heteroskedastic robust t-test on the coefficient of a regression of these averages onto treatment (and intercept) and (2) cluster robust standard errors for the coefficient of treatment on a regression of covariate onto treatment (and intercept).
Value
A data.frame of balance measures, with one row for each covariate in
df.orig except treatment, and columns for treated and control
means, standardized differences in means, p-values from two types of
regression for difference in the groups.  See description for further
details. If df.match is specified there are twice as many columns,
one set for the pre-match samples and one set for the post-match samples.
References
Rosenbaum, Paul R. (2002). Observational Studies. Springer-Verlag.
Rosenbaum, Paul R. (2010). Design of Observational Studies. Springer-Verlag.
Construct propensity score caliper
Description
Fits a propensity score for an individual-level or group-level treatment, computes a caliper for the propensity score (based on a fractional number of standard deviations provided by the user), and creates a matrix containing information about which treated-control pairings are excluded by the caliper.
Usage
buildCaliper(data, treatment, ps.vars, group.id = NULL, caliper = 0.2)
Arguments
| data | A data frame containing the treatment variable, the variables to be used in fitting the propensity score and (if treatment is at the group level) a group ID. | 
| treatment | Name of the treatment indicator. | 
| ps.vars | Vector of names of variables to use in fitting the propensity score. | 
| group.id | Name of group ID variable, if applicable. | 
| caliper | Desired size of caliper, in number of standard deviations of the fitted propensity score. | 
Details
The treatment variable should be binary with 1 indicating treated
units and 0 indicating controls.  When group.id is NULL,
treatment is assumed to be at the individual level and the propensity score
is fitted using the matrix data.  When a group ID is specified, data
frame data is first aggregated into groups, with variables in
ps.vars replaced by their within-group means, and the propensity
score is fitted on the group matrix.
Value
A matrix with nrow equal to the number of treated individuals
or groups and ncol equal to the number of control individuals, with
0 entries indicating pairings permitted by the caliper and Inf
entries indicating forbidden pairings.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
Examples
	## Not run: 
# Load Catholic school data
data(catholic_schools)
student.cov <- c('minority','female','ses','mathach')
# Check balance student balance before matching
balanceTable(catholic_schools[c(student.cov,'sector')],  treatment = 'sector')
#fit a propensity score caliper on mean values of student covariates within schools
school.caliper <- buildCaliper(data = catholic_schools, treatment = 'sector',
	ps.vars = student.cov, group.id = 'school')
#Match schools but not students within schools
match.simple <- matchMulti(catholic_schools, treatment = 'sector', 
	school.caliper = school.caliper, school.id = 'school', match.students = FALSE)
#Check balance after matching - this checks both student and school balance
balanceMulti(match.simple, student.cov = student.cov)
## End(Not run)
1980 and 1982 High School and Beyond Data
Description
These data are a subset of the data used in Raudenbush and Bryk (1999) for multilevel modeling.
Format
A data.frame with 1595 observations on the following
variables.
school: unique school level identifier
ses: student level socio-economic status scale ranges from approx. -3.578 to 2.692
mathach: senior year mathematics test score, outcome measure
female: student level indicator for sex
minority: student level indicator for minority
minority_mean: school level measure of percentage of student body that is minority
female_mean: school level measure of percentage of student body that is female
ses_mean: school level measure of average level of student socio-economic status
sector: treatment indicator 1 if catholic 0 if public
size: school level measure of total number of enrolled students
acad: school level measure of the percentage of students on the academic track
discrm: school level measure of disciplinary climate ranges from approx. -2.4 to 2.7
size_large: school level indicator for schools with more than 1000 students
minority_mean_large: school level indicator for schools with more than ten percent minority
Source
Raudenbush, S. W. and Bryk, A. (2002). Hierarchical Linear Models: Applications and Data Analysis Methods. Thousand Oaks, CA: Sage.
References
United States Department of Education. National Center for Education Statistics. High School and Beyond, 1980: Sophomore and Senior Cohort First Follow-Up (1982).
Outcome analysis.
Description
Calculates confidence interval via grid search.
Usage
ci_func(
  beta,
  obj,
  out.name = NULL,
  schl_id_name = NULL,
  treat.name = NULL,
  alpha,
  alternative = "less"
)
Arguments
| beta | Confidence interval value | 
| obj | a multiMatch object | 
| out.name | Name of outcome covariate | 
| schl_id_name | Name of school (group) identifier | 
| treat.name | Name of treatment indicator | 
| alpha | Level of test for confidence interval, default is .05 for 95% CI. | 
| alternative | Direction of test. | 
Value
The endpoint of an estimated confidence interval.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
References
Rosenbaum, Paul R. (2002). Observational Studies. Springer-Verlag.
Rosenbaum, Paul R. (2010). Design of Observational Studies. Springer-Verlag.
Print out summary of student and school counts
Description
Given a school ID and treatment variable, count up number of schools and students, print out a summary of the counts of students and schools.
Usage
describe_data_counts(data, school.id, treatment)
Arguments
| data | Dataset (student level) | 
| school.id | String name of ID column in data (the grouping variable) | 
| treatment | String name of the treatment variable. | 
Value
List of three numbers, # control, # Tx, # Total
See Also
tally_schools
Optimal Subset Matching without Balance Constraints
Description
Conducts optimal subset matching as described in the reference.
Usage
elastic(mdist, n = 0, val = 0)
pairmatchelastic(mdist, n = 0, val = 0)
Arguments
| mdist | distance matrix with rows corresponding to treated units and columns corresponding to controls. | 
| n | maximum number of treated units that can be excluded. | 
| val | cost of excluding a treated unit (i.e. we prefer to exclude a
treated unit if it increases the total matched distance by more than
 | 
Details
pairmatchelastic is the main function, which conducts an entire match.
elastic is a helper function which augments the original distance
matrix as described in the reference. 
The original versions of these functions were written by Paul Rosenbaum and distributed in the supplemental material to the paper: "Optimal Matching of an Optimally Chosen Subset in Observational Studies," Paul R. Rosenbaum, Journal of Computational and Graphical Statistics, Vol. 21, Iss. 1, 2012.
Value
elastic returns an augmented version of the input matrix
mdist.  pairmatchelastic returns a matrix of 1 column whose
values are the column numbers of matched controls and whose rownames are
the row numbers of matched treated units.
Author(s)
Paul R. Rosenbaum (original forms), modifications by Luke Keele and Sam Pimentel
References
Rosenbaum, Paul R. (2012) "Optimal Matching of an Optimally Chosen Subset in Observational Studies." Journal of Computational and Graphical Statistics, 21.1, 57-71.
Handle Missing Values
Description
Preprocesses a dataframe of matching covariates so the Mahalanobis distance can be calculated.
Usage
handleNA(X, verbose = FALSE)
Arguments
| X | a matrix or dataframe of covariates to be used for matching | 
| verbose | logical value indicating whether detailed output should be provided. | 
Details
Preprocessing involves three main steps: (1) converting factors to matrices of dummy variables (2) for any variable with NAs, adding an additional binary variable indicating whether it is missing (3) imputing all NAs with the column mean. This follows the recommendations of Rosenbaum in section 9.4 of the referenced text.
Value
a matrix containing the preprocessed data.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
References
Rosenbaum, Paul R. (2010). Design of Observational Studies. Springer-Verlag.
Check if a variable is binary
Description
Examines a vector that is not coded as a logical to see if it contains only 0s and 1s.
Usage
is.binary(x)
Arguments
| x | A vector. | 
Value
a logical value, TRUE if the vector contains only 0s and 1s
and FALSE otherwise.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
Compute School Distance from a Student Match
Description
Defines a distance between two schools whose students have been matched based on the size of the resulting matched sample and on the student-level covariate balance.
Usage
match2distance(
  matchFrame,
  treatFrame,
  ctrlFrame,
  student.vars,
  treatment,
  largeval
)
Arguments
| matchFrame | dataframe containing all matched students. | 
| treatFrame | dataframe containing all students from the treated school. | 
| ctrlFrame | dataframe containing all students from the control school. | 
| student.vars | names of variables on which to evaluate balance in the
matched sample.  Must be present in the column names of each of
 | 
| treatment | name of the treatment variable. Must be present in the
column names of each of  | 
| largeval | a large penalty value to be added to the distance for each student-level imbalance. | 
Details
The distance is computed by (1) subtracting the harmonic mean of the treated
and control counts in the matched sample from largeval (2) adding
largeval for each covariate among studentvars that has an
absolute standardized difference exceeding 0.2.  This encourages the school
match to choose larger schools with better balance.
Value
a numeric distance.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
A function that performs multilevel matching.
Description
This is the workhorse function in the package which matches groups and units within groups. For example, it will match both schools and students in schools, where the goal is to make units more comparable to estimate treatment effects.
Usage
matchMulti(
  data,
  treatment,
  school.id,
  match.students = TRUE,
  student.vars = NULL,
  school.caliper = NULL,
  school.fb = NULL,
  verbose = FALSE,
  keep.target = NULL,
  student.penalty.qtile = 0.05,
  min.keep.pctg = 0.8,
  school.penalty = NULL,
  save.first.stage = TRUE,
  tol = 10,
  solver = "rlemon"
)
Arguments
| data | A data frame for use in matching. | 
| treatment | Name of covariate that defines treated and control groups. | 
| school.id | Identifier for groups (for example schools) | 
| match.students | Logical flag for whether units within groups should
also be matched.  If set to  | 
| student.vars | Names of student level covariates on which to measure
balance.  School-level distances will be penalized when student mathces are
imbalanced on these variables. In addition, when  | 
| school.caliper | matrix with one row for each treated school and one
column for each control school, containing zeroes for pairings allowed by
the caliper and  | 
| school.fb | A list of discrete group-level covariates on which to enforce fine balance, i.e., ensure marginal distributions are balanced. First group is most important, second is second most, etc. If a simple list of variable names, one group is assumed. A list of list will give this hierarchy. | 
| verbose | Logical flag for whether to give detailed output. | 
| keep.target | an optional numeric value specifying the number of treated schools desired in the final match. | 
| student.penalty.qtile | This helps exclude students if they are difficult to match. Default is 0.05, which implies that in the match we would prefer to exclude students rather than match them at distances larger than this quantile of the overall student-student robust Mahalanobis distance distribution | 
| min.keep.pctg | Minimum percentage of students (from smaller school) to keep when matching students in each school pair. | 
| school.penalty | A penalty to remove groups (schools) in the group (school) match | 
| save.first.stage | Should first stage matches be saved. | 
| tol | a numeric tolerance value for comparing distances, used in the school match. It may need to be raised above the default when matching with many levels of refined balance or in very large problems (when these distances will often be at least on the order of the tens of thousands). | 
| solver | Name of package used to solve underlying network flow problem for the school match, one of 'rlemon' and 'rrelaxiv'. rrelaxiv carries an academic license and is not hosted on CRAN so it must be installed separately. | 
Details
matchMulti first matches students (or other individual units) within
each pairwise combination of schools (or other groups); based on these
matches a distance matrix is generated for the schools.  Then schools are
matched on this distance matrix and the student matches for the selected
school pairs are combined into a single matched sample.
School covariates are not used to compute the distance matrix for schools
(since it is generated from the student match).  Instead imbalances in school
covariates should be addressed through theschool.fb argument, which
encodes a refined covariate balance constraint. School covariates in
school.fb should be given in order of priority for balance, since the
matching algorithm optimally balances the variables in the first list
element, then attempts to further balance the those in the second element,
and so on.
Value
| raw | The unmatched data before matching. | 
| matched | The matched dataset of both units and groups. Outcome analysis and balance checks are peformed on this item. | 
| school.match | Object with two parts. The first lists which treated groups (schools) are matched to which control groups. The second lists the population of groups used in the match. | 
| school.id | Name of school identifier | 
| treatment | Name of treatment variable | 
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
See Also
See also matchMulti, matchMultisens,
balanceMulti, matchMultioutcome,
rematchSchools
Examples
#toy example with short runtime
library(matchMulti)
#Load Catholic school data
data(catholic_schools)
# Trim data to speed up example
catholic_schools <- catholic_schools[catholic_schools$female_mean >.45 &
 catholic_schools$female_mean < .60,]
#match on a single covariate
student.cov <- c('minority')
 match.simple <- 
matchMulti(catholic_schools, treatment = 'sector',
                             school.id = 'school', match.students = FALSE,
                             student.vars = student.cov, verbose=TRUE, tol=.01)
#Check balance after matching - this checks both student and school balance
  balanceMulti(match.simple, student.cov = student.cov)
## Not run: 
#larger example
data(catholic_schools)
student.cov <- c('minority','female','ses')
# Check balance student balance before matching
balanceTable(catholic_schools[c(student.cov,'sector')],  treatment = 'sector')
#Match schools but not students within schools
match.simple <- matchMulti(catholic_schools, treatment = 'sector',
school.id = 'school', match.students = FALSE)
#Check balance after matching - this checks both student and school balance
balanceMulti(match.simple, student.cov = student.cov)
#Estimate treatment effect
output <- matchMultioutcome(match.simple, out.name = "mathach",
schl_id_name = "school",  treat.name = "sector")
# Perform sensitivity analysis using Rosenbaum bound -- increase Gamma to increase effect of
# possible hidden confounder
matchMultisens(match.simple, out.name = "mathach",
          schl_id_name = "school",
          treat.name = "sector", Gamma = 1.3)
# Now match both schools and students within schools
match.out <- matchMulti(catholic_schools, treatment = 'sector',
school.id = 'school', match.students = TRUE, student.vars = student.cov)
# Check balance again
bal.tab <- balanceMulti(match.out, student.cov = student.cov)
# Now match with fine balance constraints on whether the school is large
# or has a high percentage of minority students
match.fb <- matchMulti(catholic_schools, treatment = 'sector', school.id = 'school',
match.students = TRUE, student.vars = student.cov,
school.fb = list( c('size_large'), c('minority_mean_large') )
# Estimate treatment effects
matchMultioutcome(match.fb, out.name = "mathach", schl_id_name = "school",  treat.name = "sector")
#Check Balance
balanceMulti(match.fb, student.cov = student.cov)
## End(Not run)
matchMultiResult object for results of power calculations
Description
The matchMultiResult object is an S3 class that holds the results from the matchMulti call.
matchMulti result objects have the matched datasets inside of them.
Usage
is.matchMultiResult(x)
## S3 method for class 'matchMultiResult'
print(x, ...)
## S3 method for class 'matchMultiResult'
summary(object, ...)
Arguments
| x | a matchMultiResult object (except for is.matchMultiResult, where it is a generic object to check). | 
| ... | Extra options passed to print.matchMultiResult | 
| object | Object to summarize. | 
Value
is.matchMultiResult: TRUE if object is a matchMultiResult object.
Performs an outcome analysis after multilevel matching.
Description
This function returns a point estimate, 95% confidence interval, and p-values for the matched multilevel data. All results are based on randomization inference.
Usage
matchMultioutcome(
  obj,
  out.name = NULL,
  schl_id_name = NULL,
  treat.name = NULL,
  end.1 = -1000,
  end.2 = 1000
)
Arguments
| obj | A multilevel match object. | 
| out.name | Outcome variable name | 
| schl_id_name | Level 2 ID variabel name. This variable identifies the clusters in the data that you want to match. | 
| treat.name | Treatment variable name, must be zero or one. | 
| end.1 | Lower bound for point estimate search, default is -1000. | 
| end.2 | Upper bound for point estimate search, default is 1000. | 
Details
It may be necessary to adjust the lower and upper bounds if one expects the treatment effect confidence interval to be outside the range of -1000 or 1000.
Value
| pval.c | One-sided approximate p-value for test of the sharp null. | 
| pval.p | One-sided approximate p-value for test of the sharp null assuming treatment effects vary with cluster size | 
| ci1 | Lower bound for 95% confidence interval. | 
| ci2 | Upper bound for 95% confidence interval. | 
| p.est | Point estimate for the group level treatment effect. | 
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
References
Rosenbaum, Paul R. (2002) Observational Studies. Springer-Verlag.
See Also
See Also as matchMulti, matchMultisens
Examples
	## Not run: 
# Load Catholic school data
data(catholic_schools)
student.cov <- c('minority','female','ses','mathach')
# Check balance student balance before matching
balanceTable(catholic_schools[c(student.cov,'sector')],  treatment = 'sector')
#Match schools but not students within schools
match.simple <- matchMulti(catholic_schools, treatment = 'sector',
school.id = 'school', match.students = FALSE)
#Check balance after matching - this checks both student and school balance
balanceMulti(match.simple, student.cov = student.cov)
#Estimate treatment effect
output <- matchMultioutcome(match.simple, out.name = "mathach",
schl_id_name = "school",  treat.name = "sector")
  
## End(Not run)
Rosenbaum Bounds after Multilevel Matching
Description
Function to calculate Rosenbaum bounds for continuous outcomes after multilevel matching.
Usage
matchMultisens(
  obj,
  out.name = NULL,
  schl_id_name = NULL,
  treat.name = NULL,
  Gamma = 1
)
Arguments
| obj | A multilevel match object | 
| out.name | Outcome variable name | 
| schl_id_name | Level 2 ID variable name, that is this variable identifies clusters matched in the data. | 
| treat.name | Treatment indicator name | 
| Gamma | Sensitivity analysis parameter value. Default is one. | 
Details
This function returns a single p-value, but actually conducts two tests. The first assumes that the treatment effect does not vary with cluster size. The second allows the treatment effect to vary with cluster size. The function returns a single p-value that is corrected for multiple testing. This p-value is the upper bound for a single Gamma value
Value
| pval | Upper bound on one-sided approximate p-value for test of the sharp null. | 
Author(s)
Luke Keele, University of Pennsylvania, luke.keele@gmail.com
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
References
Rosenbaum, Paul R. (2002) Observational Studies. Springer-Verlag.
See Also
See Also as matchMulti,
matchMultioutcome
Examples
## Not run: 
# Load Catholic school data
data(catholic_schools)
student.cov <- c('minority','female','ses','mathach')
# Check balance student balance before matching
balanceTable(catholic_schools[c(student.cov,'sector')],  treatment = 'sector')
#Match schools but not students within schools
match.simple <- matchMulti(catholic_schools, treatment = 'sector',
school.id = 'school', match.students = FALSE)
#Check balance after matching - this checks both student and school balance
balanceMulti(match.simple, student.cov = student.cov)
#Estimate treatment effect
output <- matchMultioutcome(match.simple, out.name = "mathach",
schl_id_name = "school",  treat.name = "sector")
# Perform sensitivity analysis using Rosenbaum bound -- increase Gamma to increase effect of
# possible hidden confounder 
         
matchMultisens(match.simple, out.name = "mathach",
          schl_id_name = "school", 
          treat.name = "sector", Gamma=1.3)
          
          
## End(Not run)
Match Schools on Student-based Distance
Description
Takes in a school distance matrix created using information from the first-stage student match and matches schools optimally, potentially
Usage
matchSchools(
  dmat,
  students,
  treatment,
  school.id,
  school.fb,
  penalty,
  verbose,
  tol,
  solver = "rlemon"
)
Arguments
| dmat | a distance matrix for schools, with a row for each treated school and a column for each control school. | 
| students | a dataframe containing student and school covariates, with a different row for each student. | 
| treatment | the column name of the binary treatment status indicator in
the  | 
| school.id | the column name of the unique school ID in the
 | 
| school.fb | an optional list of character vectors, each containing a
subset of the column names of  | 
| penalty | a numeric value, treated as the cost to the objective function of excluding a treated school. If it is set lower, more schools will be excluded. | 
| verbose | a logical value indicating whether detailed output should be printed. | 
| tol | a numeric tolerance value for comparing distances. It may need to be raised above the default when matching with many levels of refined balance. | 
| solver | Name of package used to solve underlying network flow problem, one of 'rlemon' and 'rrelaxiv'. rrelaxiv carries an academic license and is not hosted on CRAN so it must be installed separately. | 
Details
The school.fb argument encodes a refined covariate balance
constraint: the matching algorithm optimally balances the interaction of the
variables in the first list element, then attempts to further balance the
interaction in the second element, and so on.  As such variables should be
added in order of priority for balance.
Value
a dataframe with two columns, one containing treated school IDs and the other containing matched control school IDs.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
Compute Student Matches for all Pairs of Schools
Description
Iterates over all possible treated-control school pairs, optionally computes and stores an optimal student match for each one, and generates a distance matrix for schools based on the quality of each student match.
Usage
matchStudents(
  students,
  treatment,
  school.id,
  match.students,
  student.vars,
  school.caliper = NULL,
  verbose,
  penalty.qtile,
  min.keep.pctg
)
Arguments
| students | a dataframe containing student covariates, with a different row for each student. | 
| treatment | the column name of the binary treatment status indicator in
the  | 
| school.id | the column name of the unique school ID in the
 | 
| match.students | logical value.  If  | 
| student.vars | column names of variables in  | 
| school.caliper | matrix with one row for each treated school and one
column for each control school, containing zeroes for pairings allowed by
the caliper and  | 
| verbose | a logical value indicating whether detailed output should be printed. | 
| penalty.qtile | a numeric value between 0 and 1 specifying a quantile of the distribution of all student-student matching distances. The algorithm will prefer to exclude treated students rather than form pairs with distances exceeding this quantile. | 
| min.keep.pctg | a minimum percentage of students in the smaller school in a pair which must be retained, even when treated students are excluded. | 
Details
The penalty.qtile and min.keep.pctg control the rate at which
students are trimmed from the match.  If the quantile is high enough no
students should be excluded in any match; if the quantile is very low the
min.keep.pctg can still ensure a minimal sample size in each match.
Value
A list with two elements:
| student.matches | a list with one element for each treated school. Each element is a list with one element for each control school, and each element of these secondary lists is a dataframe containing the matched sample for the corresponding treated-control pairing. | 
| schools.matrix | a matrix with one row for each treated school and one column for each control school, giving matching distances based on the student match. | 
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
Mini-data set for illustration
Description
The Catholic schools dataset subset to a smaller number of schools (with only 6 Catholic schools). See full dataset documentation for more information.
Format
A data frame with 1500 rows and 12 variables, as described in the 'catholic_schools' dataset.
Source
See documentation page for 'catholic_schools' dataset.
See Also
catholic_schools
Outcome analysis.
Description
Calculates Hodges-Lehmann point estimate for treatment effect.
Usage
pe_func(beta, obj, out.name = NULL, schl_id_name = NULL, treat.name = NULL)
Arguments
| beta | Point estimate value | 
| obj | A multiMatch object | 
| out.name | Name of outcome covariate | 
| schl_id_name | Name of school (group) identifier | 
| treat.name | Name of treatment indicator | 
Value
A point estimate for constant-additive treatment effect.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
References
Rosenbaum, Paul R. (2002). Observational Studies. Springer-Verlag.
Rosenbaum, Paul R. (2010). Design of Observational Studies. Springer-Verlag.
Outcome analysis.
Description
Calcualtes p-values for test of sharp null for treatment effect.
Usage
pval_func(
  obj,
  out.name = NULL,
  schl_id_name = NULL,
  treat.name = NULL,
  wt = TRUE
)
Arguments
| obj | A multiMatch object | 
| out.name | Name of outcome covariate | 
| schl_id_name | Name of school (group) identifier | 
| treat.name | Name of treatment indicator | 
| wt | Logical flag for whether p-value should weight strata by size. | 
Value
A p-value for constant-additive treatment effect.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
References
Rosenbaum, Paul R. (2002). Observational Studies. Springer-Verlag.
Rosenbaum, Paul R. (2010). Design of Observational Studies. Springer-Verlag.
Repeat School Match Only
Description
After matchMulti has been called, repeats the school match (with
possibly different parameters) without repeating the more computationally
intensive student match.
Usage
rematchSchools(
  match.out,
  students,
  school.fb = NULL,
  verbose = FALSE,
  keep.target = NULL,
  school.penalty = NULL,
  tol = 0.001
)
Arguments
| match.out | an object returned by a call to  | 
| students | a dataframe containing student and school covariates, with a different row for each student. | 
| school.fb | an optional list of character vectors, each containing a
subset of the column names of  | 
| verbose | a logical value indicating whether detailed output should be printed. | 
| keep.target | an optional numeric value specifying the number of treated schools desired in the final match. | 
| school.penalty | an optional numeric value, treated as the cost (to the objective function in the underlying optimization problem) of excluding a treated school. If it is set lower, more schools will be excluded. | 
| tol | a numeric tolerance value for comparing distances. It may need to be raised above the default when matching with many levels of refined balance. | 
Details
The school.fb argument encodes a refined covariate balance
constraint: the matching algorithm optimally balances the interaction of the
variables in the first list element, then attempts to further balance the
interaction in the second element, and so on.  As such variables should be
added in order of priority for balance.
The keep.target and school.penalty parameters allow optimal
subset matching within the school match. When the keep.target
argument is specified, the school match is repeated for different values of
the school.penalty parameter in a form of binary search until an
optimal match is obtained with the desired number of treated schools or a
stopping rule is reached.  The tol parameter controls the stopping
rule; smaller values provide a stronger guarantee of obtaining the exact
number of treated schools desired but may lead to greater computational
costs.
It is not recommended that users specify the school.penalty parameter
directly in most cases.  Instead the keep.target parameter provides
an easier way to consider excluding schools.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
References
Rosenbaum, Paul R. (2002). Observational Studies. Springer-Verlag.
Rosenbaum, Paul R. (2010). Design of Observational Studies. Springer-Verlag.
Rosenbaum, Paul R. (2012) "Optimal Matching of an Optimally Chosen Subset in Observational Studies." Journal of Computational and Graphical Statistics, 21.1, 57-71.
See Also
Examples
## Not run: 
# Load Catholic school data
data(catholic_schools)
student.cov <- c('minority','female','ses')
school.cov <- c('minority_mean','female_mean', 'ses_mean', 'size', 'acad')
#Match schools but not students within schools
match.simple <- matchMulti(catholic_schools, treatment = 'sector',
school.id = 'school', match.students = FALSE)
#Check balance after matching - this checks both student and school balance
balanceMulti(match.simple, student.cov = student.cov, school.cov = school.cov)
#now rematch excluding 2 schools
match.trimmed <- rematchSchools(match.simple, catholic_schools, keep.target = 13)
match.trimmed$dropped$schools.t
## End(Not run)
Ensure Dataframes Share Same Set Columns
Description
Takes in two dataframes. For each column name that is in the second frame but not in the first frame, a new column of zeroes is added to the first frame.
Usage
resolve.cols(df1, df2)
Arguments
| df1 | a dataframe. | 
| df2 | a dataframe. | 
Value
a dataframe
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
Balance Measures
Description
Balance assessment for individual variables, before and after matching
Usage
sdiff(varname, treatment, orig.data, match.data = NULL)
Arguments
| varname | name of the variable on which to test balance | 
| treatment | name of the binary indicator for treatment status | 
| orig.data | a data frame containing the data before matching | 
| match.data | an optional data frame containing the matched sample | 
Details
The sdiff function computes the standardized difference in means. The
other functions perform different kinds of balance tests: t.balance
does the 2-sample t-test, fisher.balance does Fisher's exact test for
binary variable, and wilc.balance does Wilcoxon's signed rank test.
Value
a labeled vector.  For sdiff, the vector has six elements if
match.data is provided: treated and control means and standardized
differences before and after matching.  If match.data is not
provided, the vector has only the three elements corresponding to the
pre-match case.
For the other functions, if match.data is provided, the vector
contains p-values for the test before and after matching. Otherwise a
single p-value is given for the pre-match data.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
References
Rosenbaum, Paul R. (2002). Observational Studies. Springer-Verlag.
Rosenbaum, Paul R. (2010). Design of Observational Studies. Springer-Verlag.
Robust Mahalanobis Distance
Description
Computes robust Mahalanobis distance between treated and control units.
Usage
smahal(z, X)
Arguments
| z | vector of treatment indicators (1 for treated, 0 for controls). | 
| X | matrix of numeric variables to be used for computing the
Mahalanobis distance.  Row count must match length of  | 
Details
For an explanation of the robust Mahalanobis distance, see section 8.3 of the first reference. This function was written by Paul Rosenbaum and distributed in the supplemental material to the second reference.
Value
a matrix of robust Mahalanobis distances, with a row for each treated unit and a column for each control.
Author(s)
Paul R. Rosenbaum.
References
Rosenbaum, Paul R. (2010). Design of Observational Studies. Springer-Verlag.
Rosenbaum, Paul R. (2012) "Optimal Matching of an Optimally Chosen Subset in Observational Studies." Journal of Computational and Graphical Statistics, 21.1, 57-71.
Aggregate Student Data into School Data
Description
Takes a dataframe of student-level covariates and aggregates selected columns into a dataframe of school covariates.
Usage
students2schools(students, school.cov, school.id)
Arguments
| students | a dataframe of students. | 
| school.cov | a character vector of column names in  | 
| school.id | the name of the column in  | 
Details
Aggregation is either done by taking averages or by selecting the unique
factor value when a school has only one value for a factor.  As a result,
school.covs should only include variables that are numeric or do not
vary within schools.
Value
a dataframe of aggregated data, with one row for each school and
columns in school.covs and school.id.
Author(s)
Luke Keele, Penn State University, ljk20@psu.edu
Sam Pimentel, University of California, Berkeley, spi@berkeley.edu
Tally schools and students in a given dataset
Description
Returns a count of schools, without printing anything.
Usage
tally_schools(data, school.id, treatment)
Arguments
| data | Dataset (student level) | 
| school.id | String name of ID column in data (the grouping variable) | 
| treatment | String name of the treatment variable. | 
Value
List of two things: school and student counts (invisible).
Author(s)
Luke Miratrix
See Also
describe_data_counts