请考虑以下几点:
我正在将数据与MatchIt
R 中的包匹配。我的控件少于处理的控件并使用选项replace = TRUE
。根据手册,权重告诉我们匹配控件的频率。
从手册:
“对于替换匹配,使用
replace = TRUE
。替换匹配后,权重可以用来反映每个控制单元匹配的频率。”
但是,我不明白为什么权重可以有小数以及如何反映频率。
例如,我replace == TRUE
在手册中的示例中添加了(参见第 18 页):
library("dplyr")
library("MatchIt")
m.out1 <- matchit(treat ~ re74 + re75 + age + educ, data = lalonde,
method = "nearest", distance = "logit", replace = T)
tail(match.data(m.out1), 15)
#> treat age educ black hispan married nodegree re74 re75 re78
#> PSID388 0 19 11 1 0 0 1 0 0 16485.520
#> PSID390 0 48 13 0 0 1 0 0 0 0.000
#> PSID392 0 17 10 1 0 0 1 0 0 0.000
#> PSID393 0 38 12 0 0 1 0 0 0 18756.780
#> PSID396 0 48 14 0 0 1 0 0 0 7236.427
#> PSID398 0 17 8 1 0 0 1 0 0 4520.366
#> PSID400 0 37 8 1 0 0 1 0 0 648.722
#> PSID401 0 17 10 1 0 0 1 0 0 1053.619
#> PSID407 0 23 12 0 0 0 0 0 0 3902.676
#> PSID409 0 17 10 0 0 0 1 0 0 14942.770
#> PSID411 0 18 10 1 0 0 1 0 0 5306.516
#> PSID413 0 17 10 0 0 1 1 0 0 3859.822
#> PSID419 0 51 4 1 0 0 1 0 0 0.000
#> PSID423 0 27 10 1 0 0 1 0 0 7543.794
#> PSID425 0 18 11 0 0 0 1 0 0 10150.500
#> distance weights
#> PSID388 0.4067545 0.6
#> PSID390 0.4042321 1.2
#> PSID392 0.3974677 0.6
#> PSID393 0.4016920 4.2
#> PSID396 0.4152715 0.6
#> PSID398 0.3758217 1.8
#> PSID400 0.3595084 0.6
#> PSID401 0.3974677 1.2
#> PSID407 0.4144044 1.8
#> PSID409 0.3974677 0.6
#> PSID411 0.3966277 1.2
#> PSID413 0.3974677 1.2
#> PSID419 0.3080590 0.6
#> PSID423 0.3890954 1.2
#> PSID425 0.4076015 1.2
对于控制“PSID393”,权重为 4.276。因此,我假设这个控件匹配了 4 或 5 次(四舍五入后)。
然而,我们也可以match.matrix
一一查看匹配的治疗和控制。过滤“PSID393”,我们看到控件实际上已经匹配了 7 次:
m.out1$match.matrix %>% data.frame() %>% filter(X1 == "PSID393")
#> X1
#> 1 PSID393
#> 2 PSID393
#> 3 PSID393
#> 4 PSID393
#> 5 PSID393
#> 6 PSID393
#> 7 PSID393
由reprex 包(v0.2.1)于 2019 年 5 月 6 日创建
如何正确解释这两个输出?