【发布时间】:2017-11-18 20:07:43
【问题描述】:
我可以就以下问题获得一些帮助吗?我有一个数据框,它有多个组,我想在上面运行线性模型。作为测试,我只对其中一个组进行子集化并运行函数 lm() 并得到以下输出:
test <- filter(dat, locus == "ChrX_1")
test.result <- lm(methylation ~ Pheno, dat)
term estimate std.error statistic p.value
1 (Intercept) 56.955 0.9729203 58.540254 9.080525e-250
2 Pheno1 9.015 1.1915791 7.565591 1.464884e-13
然后我使用 dplyr 包中的 group_by 对不同的组执行 lm() 函数。但是轨迹 "ChrX_1" 的 p.value 的输出现在不同并且更弱了。
test.result4 <- group_by(dat, locus) %>%
do(model.test2 = lm(methylation ~ Pheno, data = .))
tidy(test.result4, model.test2)
locus term estimate std.error statistic p.value
<chr> <chr> <dbl> <dbl> <dbl> <dbl>
1 ChrX_1 (Intercept) 59.40 4.476666 13.268804 1.342225e-13
2 ChrX_1 Pheno1 9.05 5.482773 1.650624 1.099895e-01
3 ChrX_10 (Intercept) 59.00 4.069398 14.498459 1.522725e-14
4 ChrX_10 Pheno1 11.40 4.983974 2.287331 2.993721e-02
5 ChrX_11 (Intercept) 58.90 4.665565 12.624408 4.460131e-13
6 ChrX_11 Pheno1 9.10 5.714127 1.592544 1.224905e-01
7 ChrX_12 (Intercept) 52.80 3.717022 14.204921 2.526739e-14
8 ChrX_12 Pheno1 10.65 4.552403 2.339424 2.667444e-02
9 ChrX_13 (Intercept) 53.10 3.556734 14.929427 7.343091e-15
10 ChrX_13 Pheno1 7.10 4.356092 1.629901 1.143224e-01
# ... with 30 more rows
因此,我想知道是什么导致 p.values 减弱?我认为 p.value 应该与我对轨迹进行子集化并在其上运行 lm() 函数时相同。
谢谢
【问题讨论】:
-
当您尝试将
lm用于locus == "ChrX_1"时,您没有使用test数据集,而是使用dat。是这个问题吗? -
我怀疑您将整个数据集用于第一个
lm。你需要使用test而不是dat -
感谢您指出。不知何故,我完全错过了。
标签: r group-by statistics lm