Diferenças
Aqui você vê as diferenças entre duas revisões dessa página.
Ambos lados da revisão anteriorRevisão anteriorPróxima revisão | Revisão anterior | ||
disciplinas:ce227-2018-01:historico [2018/04/24 18:26] – paulojus | disciplinas:ce227-2018-01:historico [2019/11/04 11:52] (atual) – paulojus | ||
---|---|---|---|
Linha 33: | Linha 33: | ||
| 16/04 Seg |Resolução e discussão do exercício 6.1. Obtendo a preditiva: (i) analiticamente, | | 16/04 Seg |Resolução e discussão do exercício 6.1. Obtendo a preditiva: (i) analiticamente, | ||
| 18/04 Qua |Algoritmo amostrador de Gibbs (Gibbs sampler). Exemplo na inferência para distribuição normal | | 18/04 Qua |Algoritmo amostrador de Gibbs (Gibbs sampler). Exemplo na inferência para distribuição normal | ||
- | | 23/04 Seg |Revisão Gibbs sampler. Modelo Poisson com priori Gamma e hiperpriori InvGamma. Derivação da posteriori | + | | 23/04 Seg |Revisão Gibbs sampler. Modelo Poisson com priori Gamma e hiperpriori InvGamma. Derivação da posteriori, condicionais completas e implementação do algoritmo de Gibbs. Regressão linear: expressões para amostragem exata e via Gibbs| |[[# |
- | Regressão linear: expressões para amostragem exata e via Gibbs| |[[# | + | | 25/04 Qua |Gibbs sampler compasso Metrópolis. Modelo Poisson com priori Normal. Derivação da posteriori, condicionais completas e implementação do algoritmo de Gibbs com um passo metrópolis. | |[[# |
+ | | 30/04 Seg |Feriado | | | | ||
+ | | 02/05 Qua |1a prova | | | | ||
+ | | 07/05 Seg |Discussão das questões da 1a prova. Definição de atividades para sequencia do curso | |[[# | ||
+ | | 09/05 Qua |Recursos computacionais para inferência Bayesiana - Atividades indicadas na aula anterior. Sem aula expositiva. | | | | ||
+ | | 14/05 Seg |Gibbs sampler: exemplo das minas de carvão. Programação e utilização do JAGS | |[[# | ||
+ | | 16/05 Qua |Modelo de componentes de variância e correlação intraclasse, | ||
+ | | 21/05 Seg |Sem aula expositiva: semana dedicada às atividades do RDay e RBras | | | | ||
+ | | 23/05 Qua |Sem aula expositiva: semana dedicada às atividades do RDay e RBras | | | | ||
+ | | 28/05 Seg |Sem aula expositiva: interrupção de aulas na UFPR | | | | ||
+ | | 30/05 Qua |Sem aula expositiva: interrupção de aulas na UFPR | | | | ||
+ | | 04/06 Seg |Reorganização do curso. Dúvidas e perguntas dos alunos | | | | ||
+ | | 06/06 Qua |2a prova. Toda matéria discutida até aqui | | | | ||
+ | | 11/06 Qua |Bayesiano empírico - modelo Poisson-Gamma para taxas | | | | ||
+ | | 13/06 Qua |Apresentações | ||
+ | | 18/06 Qua |Apresentações | ||
+ | | 20/06 Qua |3a prova. | | | ||
=== 19/02 === | === 19/02 === | ||
Linha 65: | Linha 81: | ||
=== 26/02 === | === 26/02 === | ||
- Completar problemas propostas nas aulas anteriores após as discussões em aula | - Completar problemas propostas nas aulas anteriores após as discussões em aula | ||
- | - Escrever um código para o Exemplo da Poisson (2.3 do material), que permita | + | - Escrever um código para o Exemplo da Poisson (2.3 do material), que permita |
- Ler e resolver exercícios do Capítulo 2 da apostila | - Ler e resolver exercícios do Capítulo 2 da apostila | ||
Linha 154: | Linha 170: | ||
=== 09/04 === | === 09/04 === | ||
- Fazer um código (com operações matriciais) para os cálculos do Exemplo 1. O código deve permitir definir diferentes prioris e verossimilhanças. Experimentar com valores diferentes do exemplo. | - Fazer um código (com operações matriciais) para os cálculos do Exemplo 1. O código deve permitir definir diferentes prioris e verossimilhanças. Experimentar com valores diferentes do exemplo. | ||
- | - Especificar valores para os hiperparâmetros p e q no Exemplo 2 e simular um conjunto de dados. Obter a posteriori e maginais. Fazer gráficos conjuntos e marginais da priori e posteriori. | + | - Especificar valores para os hiperparâmetros |
- No Exemplo 3 obter a marginal < | - No Exemplo 3 obter a marginal < | ||
- Ainda no exemplo 3 definir os hiperparâmetros de obter uma simulação de dados do modelo | - Ainda no exemplo 3 definir os hiperparâmetros de obter uma simulação de dados do modelo | ||
Linha 274: | Linha 290: | ||
## | ## | ||
## A estratégia de Gibbs é alternar as simulações entre **as distribuições condicionais** | ## A estratégia de Gibbs é alternar as simulações entre **as distribuições condicionais** | ||
- | ## o que " | + | ## o que " |
## [\mu|\sigma^2, | ## [\mu|\sigma^2, | ||
## [\sigma^2|\mu, | ## [\sigma^2|\mu, | ||
Linha 293: | Linha 309: | ||
sigma2.simG[1] <- 100 | sigma2.simG[1] <- 100 | ||
- | {for(i in 2:N){ | + | { |
+ | for(i in 2:N){ | ||
A <- with(dados, SQ + n*(mu.simG[i-1]-m)^2) | A <- with(dados, SQ + n*(mu.simG[i-1]-m)^2) | ||
sigma2.simG[i] <- with(dados, 1/rgamma(1, shape=n/2, scale=2/A)) | sigma2.simG[i] <- with(dados, 1/rgamma(1, shape=n/2, scale=2/A)) | ||
Linha 325: | Linha 342: | ||
=== 23/04 === | === 23/04 === | ||
- | - Implementar modelo semelhante ao visto em aula porém com < | + | - Implementar modelo semelhante ao visto em aula porém com < |
- Implementar a regressão linear via algoritmo de Gibbs. Usar dados simulados de uma regressão linear simples. Incluir amostras da preditiva no algoritmo | - Implementar a regressão linear via algoritmo de Gibbs. Usar dados simulados de uma regressão linear simples. Incluir amostras da preditiva no algoritmo | ||
- | - Código para o modelo visto em aula: | + | - Código para o modelo visto em aula:< |
- | <code R> | + | |
- | ## | + | |
- | ## função para cálculo de E[] e Var[] da Gamma inversa para ajudar definir modelo a ser simulado | + | |
- | EVIG <- function(a, | + | |
- | E <- ifelse(a > 1, 1/(b * (a-1)), "não pode ser calculada para este valor de a") | + | |
- | V <- ifelse(a > 2, 1/((b^2) * ((a-1)^2) * (a-2)), "não pode ser calculada para este valor de a") | + | |
- | return(c(E, | + | |
- | ## | + | |
## Simulando dados do modelo sendo estudado | ## Simulando dados do modelo sendo estudado | ||
set.seed(2018) | set.seed(2018) | ||
Linha 387: | Linha 396: | ||
plot(density(beta.sam, | plot(density(beta.sam, | ||
plot(density(lambda.sam, | plot(density(lambda.sam, | ||
- | </code R> | + | </code> |
+ | |||
+ | === 07/05 === | ||
+ | - **Atividade 1** (individual ou duplas) Buscar algum pacote do R ou outro programa que permita obter os resultados (analíticos) vistos até aqui no curso. Evitar coincidẽncias entre os escolhidos | ||
+ | - **Atividade 2** (individual ou duplas) Buscar algum pacote do R ou outro programa que permita obter por simulação resultados pera os exemplos vistos até aqui no curso. Evitar coincidẽncias entre os escolhidos | ||
+ | - **Atividade 3** (individual ou duplas) Utilizar o recurso visto na Atividade 2 para analizar algum modelo/ | ||
+ | |||
+ | === 14/05 === | ||
+ | - {{: | ||
+ | |||
+ | === 16/05 === | ||
+ | - Coeficiente de correlação | ||
+ | ## Dados simulados do modelo: | ||
+ | ## Y_{ij} \sim N(\mu_{i}, \sigma^2_y) | ||
+ | ## | ||
+ | ## b_{i} \sim N(0, \sigma^2_b) | ||
+ | ## que, por ser normal (com ligação identidade) | ||
+ | ## pode ser escrito por: | ||
+ | ## Y_{ij} = \beta_0 + b_{i} + \epsilon_{ij} | ||
+ | ## | ||
+ | ## simulando dados: | ||
+ | Ngr <- 25 | ||
+ | Nobs <- 10 | ||
+ | set.seed(12) | ||
+ | sim <- data.frame(id | ||
+ | gr = rep(1:Ngr, each=Nobs), | ||
+ | bs = rep(rnorm(Ngr, | ||
+ | eps = rnorm(Ngr*Nobs, | ||
+ | ) | ||
+ | sim <- transform(sim, | ||
+ | sim | ||
+ | |||
+ | ## estimativas " | ||
+ | resumo <- function(x) c(media=mean(x), | ||
+ | (sim.res <- aggregate(y~gr, | ||
+ | var(sim.res$y[, | ||
+ | mean(sim.res$y[, | ||
+ | mean(sim$y) | ||
+ | |||
+ | ## A seguir serão obtidas inferências de três formas diferentes: | ||
+ | ## - ajuste modelo de efeito aleatório (não bayesiano) | ||
+ | ## - ajuste via JAGS (inferência por simulação da posteriori) | ||
+ | ## - ajuste via INLA (inferência por aproximação da posteriori) | ||
+ | |||
+ | ## | ||
+ | ## Modelo de efeitos aleatórios | ||
+ | ## | ||
+ | require(lme4) | ||
+ | fit.lme <- lmer(y ~ 1|gr, data=sim) | ||
+ | summary(fit.lme) | ||
+ | ranef(fit.lme) | ||
+ | coef(fit.lme)$gr - fixef(fit.lme) | ||
+ | print(VarCorr(fit.lme), | ||
+ | |||
+ | ## JAGS | ||
+ | require(rjags) | ||
+ | |||
+ | sim.lst <- as.list(sim[c(" | ||
+ | sim.lst$N <- nrow(sim) | ||
+ | sim.lst$Ngr <- length(unique(sim$gr)) | ||
+ | mean(sim.lst$y) | ||
+ | |||
+ | cat(" | ||
+ | for(j in 1:N){ | ||
+ | y[j] ~ dnorm(mu[gr[j]], | ||
+ | } | ||
+ | for(i in 1:Ngr){ | ||
+ | mu[i] ~ dnorm(theta, | ||
+ | } | ||
+ | theta ~ dnorm(0, 1.0E-6) | ||
+ | tau.b ~ dgamma(0.001, | ||
+ | sigma2.b <- 1/tau.b | ||
+ | tau.e ~ dgamma(0.001, | ||
+ | sigma2.e <- 1/tau.e | ||
+ | cci <- sigma2.e/ | ||
+ | }", file=" | ||
+ | |||
+ | sim.jags <- jags.model(file=" | ||
+ | ## inits = ... | ||
+ | |||
+ | fit.jags <- coda.samples(sim.jags, | ||
+ | |||
+ | summary(fit.jags) | ||
+ | plot(fit.jags) | ||
+ | |||
+ | ## | ||
+ | require(INLA) | ||
+ | |||
+ | fit.inla <- inla(y ~ f(gr) , family=" | ||
+ | summary(fit.inla) | ||
+ | sqrt(1/ | ||
+ | </ | ||
+ | |||
+ | <fs large> | ||
+ | - Complementar as análise acima com exploração dos resultados, obtenção de gráficos e resultados de interesse | ||
+ | - Ajustar o modelo acima aos dados de:\\ Julio M. Singer, Carmen Diva Saldiva de André, Clóvis de Araújo Peres\\ **Confiabilidade e Precisão na Estimação de Médias**\\ [[http:// | ||
+ | - Identificar e ajustar modelos (não bayesianos, bayesianos por simulação ou aproximados) para dados simulados da seguinte forma: <code R> | ||
+ | set.seed(123456L) | ||
+ | n <- 50 | ||
+ | m <- 10 | ||
+ | w <- rnorm(n, sd=1/3) | ||
+ | u <- rnorm(m, sd=1/4) | ||
+ | b0 <- 0 | ||
+ | b1 <- 1 | ||
+ | idx <- sample(1:m, n, replace=TRUE) | ||
+ | y <- rpois(n, lambda = exp(b0 + b1 * w + u[idx] | ||
+ | </code> |