6 Bootstrapping
library(PSAboot)
boot.matching.1to3 <- function(Tr, Y, X, X.trans, formu, ...) {
return(boot.matching(Tr=Tr, Y=Y, X=X, X.trans=X.trans, formu=formu, M=3, ...))
}
boot_out <- PSAboot(Tr = lalonde$treat == 1,
Y = lalonde$re78,
X = lalonde[,all.vars(lalonde.formu)[-1]],
seed = 2112,
methods=c('Stratification' = boot.strata,
'ctree' = boot.ctree,
'rpart' = boot.rpart,
'Matching' = boot.matching,
'Matching-1-to-3' = boot.matching.1to3,
'MatchIt' = boot.matchit) )
summary(boot_out)
plot(boot_out)
data:image/s3,"s3://crabby-images/451f0/451f03da78b20670976779bea2c319fd96cbd79e" alt="Mean difference across all bootstrap samples by method"
Figure 6.1: Mean difference across all bootstrap samples by method
boxplot(boot_out)
data:image/s3,"s3://crabby-images/1b60f/1b60f305bddc2ae1e0a4cc5c134628227bad0a75" alt=""
matrixplot(boot_out)
data:image/s3,"s3://crabby-images/e5013/e5013359d8199ebe98880ea6671570704e9fd815" alt=""
boot_balance <- balance(boot_out)
boot_balance
## Unadjusted balance: 1.48309081605193
## 0.04
## 0.08
## 0.05
## 0.06
## 0.01
## 0.06
## 0.04
## NA
## 0.07
## 0.07
## 0.05
## 0.08
plot(boot_balance)
data:image/s3,"s3://crabby-images/9e940/9e9408e5d081f3861e72b77b15df611b21ce0a2a" alt=""
boxplot(boot_balance) + geom_hline(yintercept=.1, color='red')
data:image/s3,"s3://crabby-images/4d9e9/4d9e9d77f8d29bb37899d095847f2d6c2f42d50c" alt=""
Details are available within the returned object
boot_balance$unadjusted
## 3.51
## 5.46
## 1.12
## 1.16
## 0.66
## 0.89
## 0.39
## 0.44
## 0.72
## 0.49
boot_balance$complete
## 0.04
## 0.00
## 0.00
## 0.01
## 0.00
## 0.16
## 0.03
## 0.16
## 0.05
## 0.04
## 0.02
## 0.06
## 0.09
## 0.15
## 0.14
## 0.04
## 0.01
## 0.02
## 0.04
## 0.05
## 0.08
## 0.04
## 0.00
## 0.09
## 0.02
## 0.08
## 0.10
## 0.09
## 0.01
## 0.02
## 0.03
## 0.08
## 0.02
## 0.09
## 0.02
## 0.07
## 0.00
## 0.09
## 0.05
## 0.06
## 0.00
## 0.00
## 0.03
## 0.09
## 0.01
## 0.07
## 0.01
## 0.04
## 0.06
## 0.06
## 0.06
## 0.02
## 0.05
## 0.08
## 0.03
## 0.03
## 0.01
## 0.10
## 0.00
## 0.05
boot_balance$pooled |> head()
## 0.02
## 0.03
## 0.04
## 0.03
## 0.04
## 0.05
## 0.07
## 0.09
## 0.12
## NA
## 0.06
## 0.12
## 0.05
## 0.09
## 0.08
## 0.11
## 0.08
## 0.07
## 0.06
## 0.07
## 0.03
## 0.07
## 0.05
## 0.06
## 0.04
## 0.03
## 0.03
## 0.08
## 0.03
## 0.05
## 0.08
## 0.10
## 0.09
## 0.07
## 0.10
## 0.10