Bayesian Modeling with RJAGS
Alicia Johnson
Associate Professor, Macalester College


What does a "good" Markov chain look like?
How accurate is the Markov chain approximation of the posterior?
For how many iterations should we run the Markov chain?


Good: stability!

Bad: instability
# COMPILE the model
sleep_jags <- jags.model(..., n.chains = 1)

# COMPILE the model
sleep_jags <- jags.model(..., n.chains = 2)

# COMPILE the model
sleep_jags <- jags.model(..., n.chains = 4)

# COMPILE the model
sleep_jags <- jags.model(..., n.chains = 4)

summary(sleep_sim)
1. Empirical mean and standard deviation for each variable,
plus standard error of the mean:
Mean SD Naive SE Time-series SE
m 29.10 8.968 0.2836 0.2820
s 40.07 7.887 0.2494 0.4227
2. Quantiles for each variable:
2.5% 25% 50% 75% 97.5%
m 11.42 23.27 28.85 34.76 46.76
s 28.31 34.65 38.93 43.91 57.56
Estimate of the posterior mean of $m$ = 29.10 ms
(Naive) standard error of this estimate = 0.2836 ms
SD / $\sqrt{\text{number of iterations}}$

Estimated mean = 29.10 ms
(Naive) standard error = 0.2836 ms

Define, compile, simulate the model
Examine the following diagnostics:
Finalize the simulation
sleep_jags <- jags.model(textConnection(sleep_model),
data = list(Y = sleep_study$diff_3),
inits = list(.RNG.name = "base::Wichmann-Hill",
.RNG.seed = 1989))
Bayesian Modeling with RJAGS