
【Rでベイズ統計モデリング#7】ロジスティック回帰モデル
記事の目的
GLMであるロジスティック回帰モデルのベイズ推定を、RとStanを使用して実装していきます。データの作成から実装するので、コピペで再現することが可能です。
目次
0 前準備
0.1 今回のモデル

0.2 ワーキングディレクトリの設定
以下の画像のようにワーキングディレクトリを設定します。設定したディレクトリに、RファイルとStanファイルを保存します。

1 ライブラリ
# 1 ライブラリ library(dplyr) library(ggplot2) library(rstan) library(bayesplot) set.seed(1) rstan_options(auto_write=TRUE) options(mc.cores=parallel::detectCores())
2 データ
2.1 コード
# 2 データ
資格 <- rbinom(100, 1, 0.3)
年齢 <- rnorm(100, 50, 20) %>% round()
p <- 1/(1+exp(-(10-0.4*年齢 + 7*資格)))
試験 <- rbinom(100, 1, p)
data <- data.frame(資格, 年齢, 試験) %>% filter(年齢>18, 年齢<65)
data %>% head()
plot <- ggplot() +
  geom_point(aes(x=data$年齢, y=data$試験, color=factor(data$資格))) + 
  theme_classic(base_family = "HiraKakuPro-W3") +
  theme(text=element_text(size=25))+
  labs(x="年齢", y="試験", title="モデル") +
  scale_color_manual("資格",values=c("red","blue"))
plot
2.2 結果
| 7行目の結果 | 15行目の結果 | 
|  |  | 
3 Stanの利用
3.1 Stanファイル
data {
  int N;
  int y[N];
  vector[N] x1;
  vector[N] x2;
  
  int N_hat;
  vector[N_hat] x_hat;
}
parameters {
  vector[3] b;
}
transformed parameters{
  vector[N] p;
  p = inv_logit(b[1] + b[2]*x1 + b[3]*x2);
}
model{
  y ~ bernoulli(p);
}
generated quantities{
  vector[N_hat] p_hat1;
  vector[N_hat] p_hat0;
  
  for(n in 1:N_hat){
    p_hat1[n] = inv_logit(b[1] + b[2]*x_hat[n] + b[3]);
    p_hat0[n] = inv_logit(b[1] + b[2]*x_hat[n]);
  }
}
3.1 Stanを利用するRのコード
# 3 stanの使用 x_hat <- seq(min(data$年齢), max(data$年齢)) data_list <- list( N = nrow(data), y = data$試験, x1 = data$年齢, x2 = data$資格, N_hat = length(x_hat), x_hat = x_hat ) mcmc_result <- stan( file="7ロジスティック回帰モデル.stan", data=data_list, seed=1, iter = 1000, warmup = 200, chains = 4, thin=1 )
4 分析結果
4.1 コード
# 4 分析結果
## 4.1 推定結果
print(mcmc_result, probs = c(0.025, 0.5, 0.975), pars=c("b"))
## 4.2 収束の確認
mcmc_sample <- rstan::extract(mcmc_result, permuted=FALSE)
mcmc_combo(mcmc_sample, pars=c("b[1]","b[2]","b[3]"))
## 4.3 pの確認
mcmc_sample <- rstan::extract(mcmc_result)
func <- function(x){
  return (quantile(x, c(0.025, 0.5, 0.975)))
}
p_hat1 <- apply(mcmc_sample[["p_hat1"]], 2, func)
p_hat0 <- apply(mcmc_sample[["p_hat0"]], 2, func)
plot_p <- plot + 
  labs(title="pの推定結果") +
  geom_line(aes(x=x_hat, y=p_hat1[2,]), col="blue") + 
  geom_line(aes(x=x_hat, y=p_hat0[2,]), col="red") +
  geom_ribbon(aes(x=x_hat, ymin=p_hat1[1,],ymax=p_hat1[3,]), alpha=0.5, fill="gray", col="blue")+
  geom_ribbon(aes(x=x_hat, ymin=p_hat0[1,],ymax=p_hat0[3,]), alpha=0.5, fill="gray", col="red")
plot_p
4.2 結果
| 3行目の結果 | 7行目の結果 | 
|  |  | 
| 23行目の結果 | 
|  | 
 
                          
                          
                         