日々の記録簿

日々のできごとの記録

日記

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

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

関連記事

nvim-Rの使い方(2018年度版)

nvim-Rの使い方(2019年度版)を書きました。2019年現在、nvim-completion-managerは更新されていません。 vimからRを使うNvim-Rですが、まだまだ深化しています。 …

WordPressの投稿一覧で【この投稿タイプの投稿を編集する権限がありません】と表示される

その他、【プラグインの管理画面にアクセスできない】【ファイルをアップロードできない(この親ディレクトリのアクセス権はサーバーによる書き込みを許可していますか?)】等のエラー表示がでていました。 一方で …

全国学力・学習状況調査の何が問題なのか(その2)

その1の続きです。まだの人は、先にどうぞ。 テストで成績を測るにはどうすればよいのか? あまりにも巷に学力テストがありふれているため忘れられがちだが、「テストで成績を測る」というのは、それほどかんたん …

knitrで複数頁に渡る表を作成する

knitrで複数頁に渡る表を作成する必要があったので、メモです。 と言っても、longtable をセットするだけなのですが。 仮に、longtable.Rというファイルがあったとします。データはTI …

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

またまた物欲に負けて、Thinkpad X1 Carbon 2016 (4th gen)を購入してしまいました。 さっそく、Arch Linuxをインストールしようとしたのですが、起動してこない・・・ …