J'ai essayé d'ajouter un commentaire ci-dessus, mais mon représentant est trop faible.
Devrait
y[i] ~ dnorm(mu[i], tau / weight[i])
ne pas être
y[i] ~ dnorm(mu[i], tau * weight[i])
dans JAGS? J'exécute des tests comparant les résultats de cette méthode dans JAGS aux résultats d'une régression pondérée via lm () et ne peut trouver de conformité qu'en utilisant cette dernière. Voici un exemple simple:
aggregated <-
data.frame(x=1:5) %>%
mutate( y = round(2 * x + 2 + rnorm(length(x)) ),
freq = as.numeric(table(sample(1:5, 100,
replace=TRUE, prob=c(.3, .4, .5, .4, .3)))))
x <- aggregated$x
y <- aggregated$y
weight <- aggregated$freq
N <- length(y)
# via lm()
lm(y ~ x, data = aggregated, weight = freq)
et comparer à
lin_wt_mod <- function() {
for (i in 1:N) {
y[i] ~ dnorm(mu[i], tau*weight[i])
mu[i] <- beta[1] + beta[2] * x[i]
}
for(j in 1:2){
beta[j] ~ dnorm(0,0.0001)
}
tau ~ dgamma(0.001, 0.001)
sigma <- 1/sqrt(tau)
}
dat <- list("N","x","y","weight")
params <- c("beta","tau","sigma")
library(R2jags)
fit_wt_lm1 <- jags.parallel(data = dat, parameters.to.save = params,
model.file = lin_wt_mod, n.iter = 3000, n.burnin = 1000)
fit_wt_lm1$BUGSoutput$summary