日々の記録簿

日々のできごとの記録

日記

surveyでR2値を計算する方法

投稿日:

Rのsurvey packageには通常の回帰分析におけるR2値を計算する関数が存在しないようである。なので計算方法。参考にしたのはこちらのサイト。コードを見るとわかるが、途中でヌルモデルを計算してるので複雑なデザインだと算出に時間がかかるかもしれない。ちなみに調整済R2は計算できない。モデル比較をしたいならanova関数を使うと良いらしい。

library(survey)

data(api)
dstrat <- svydesign(
  id = ~1, strata = ~stype, weights = ~pw, data = apistrat, fpc = ~fpc
)

lm1 <- svyglm(api00 ~ ell + meals + mobility, design = dstrat)
lm2 <- svyglm(api00 ~ ell, design = dstrat)
lm3 <- svyglm(api00 ~ ell * meals * mobility, design = dstrat)

svyrsq <- function(object) {
  if (!object$family$family == "gaussian") {
    stop("only applied 'family = gaussian'")
  }
  null_f <- update(object$formula, . ~ 1)
  null_e <- survey::svyglm(null_f, design = object$survey.design) # ヌルモデルを計算
  tot_var <- summary(null_e)$dispersion[1]
  res_var <- summary(object)$dispersion[1]
  rsq <- 1 - res_var / tot_var
  return(rsq)
}

svyrsq(lm1)
svyrsq(lm2)
svyrsq(lm3)

# モデル比較をしたい場合はanovaを使う
anova(lm2, lm1)
anova(lm3, lm1)

スポンサーリンク

スポンサーリンク

-日記

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

Thinkpad X1 Carbon 2016 (4th gen)に、Arch Linuxをインストールする方法(その2)

Thinkpad X1 Carbon 2016 (4th gen)でLinuxが起動しないという問題の続報です。 この問題は、X1 Carbonだけでなく、Yoga260やT460sでも発生しているよ …

php 7.4にしたら、wordpressの自動更新ができなくなっている(php-fpmの設定の問題)

php 7.4 に更新したら、wordpressの自動アップデートが止まるという問題が発生していた。その場しのぎでphpのアップデートを止めていたのだが、そろそろヤバイということで解決策をググってみた …

PISA2000から2012までのデータをダウンロードし、csvに変換するPisaDataToCsvを作成した!

タイトルで終わっていますが、pythonの勉強を兼ねて、以前に公開していたスクリプトを修正しました。いろいろ寄り道した分、以前よりはわかりやすいコードになっていると思います。 Python 3が動作す …

VLC3.0.4-3でTSファイルが再生できない【解決】

タイトルの通りですが、いつの間にかVLC(3.0.4-3)でTSファイルが再生できなくなっていました。OSはArch Linuxです。依存関係でダウングレードもできない模様。 ググってみると、【Mpe …

i3wm + xfce にしてみた!

興味がありつつも敷居が高そうで試してなかったタイル型ウィンドウマネジャーを試してみました。xmonadにいったん挫折したあと、i3wm + Xfce 4を試してみたら、イイ感じだったので、導入方法の記 …