coeftest
オブジェクトから 2 つ以上の列を抽出できる関数はありますか? これは一度に 1 つのオブジェクトで簡単ですが、(ループcoeftest
以外の) リストに対して同じことを行うことはできますか?for()
> # meaningless data
> temp <- data.frame(a = rnorm(100, mean = 5), b = rnorm(100, mean = 1),
+ c = 1:100)
> formulas <- list(a ~ b, a ~ c)
> models <- lapply(formulas, lm, data = temp)
> library(lmtest)
> cts <- lapply(models, coeftest)
> # easy to extract columns one object at a time
> cts[[1]][, 1:2]
Estimate Std. Error
(Intercept) 5.0314196 0.1333705
b -0.1039264 0.0987044
> # but more difficult algorithmically
> # either one column
> lapply(cts, "[[", 1)
[[1]]
[1] 5.03142
[[2]]
[1] 5.312007
> # or two
> lapply(cts, "[[", 1:2)
Error in FUN(X[[1L]], ...) : attempt to select more than one element
おそらく、より基本的な質問は、coeftest
オブジェクトの肉をデータフレームに変換する方法があるかどうかです。これにより、列を個別に抽出してからmapply()
. ありがとう!
編集:最初と2番目の列を持つ行列(またはデータフレーム)になりたいと思います。
[[1]]
Estimate Std. Error
(Intercept) 5.0314196 0.1333705
b -0.1039264 0.0987044
[[2]]
Estimate Std. Error
(Intercept) 5.312007153 0.199485363
c -0.007378529 0.003429477