-
-
Notifications
You must be signed in to change notification settings - Fork 477
/
Copy pathsalm.stan
53 lines (50 loc) · 1.22 KB
/
salm.stan
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
//# http://www.openbugs.net/Examples/Salm.html
//# this matches the jags implementation
data {
int<lower=0> Ndoses;
int<lower=0> Nplates;
array[Ndoses, Nplates] int<lower=0> y;
array[Ndoses] real x;
}
transformed data {
array[Ndoses] real logx;
real mean_x;
real mean_logx;
array[Ndoses] real centered_x;
array[Ndoses] real centered_logx;
mean_x = mean(x);
for (dose in 1 : Ndoses) {
centered_x[dose] = x[dose] - mean_x;
}
for (dose in 1 : Ndoses) {
logx[dose] = log(x[dose] + 10);
}
mean_logx = mean(logx);
for (dose in 1 : Ndoses) {
centered_logx[dose] = logx[dose] - mean_logx;
}
}
parameters {
real alpha_star;
real beta;
real gamma;
real<lower=0> tau;
array[Ndoses] vector[Nplates] lambda;
}
transformed parameters {
real<lower=0> sigma;
real alpha;
alpha = alpha_star - beta * mean_logx - gamma * mean_x;
sigma = 1.0 / sqrt(tau);
}
model {
alpha_star ~ normal(0.0, 1.0E3);
beta ~ normal(0.0, 1000);
gamma ~ normal(0.0, 1000);
tau ~ gamma(0.001, 0.001);
for (dose in 1 : Ndoses) {
lambda[dose] ~ normal(0.0, sigma);
y[dose] ~ poisson_log(alpha_star + beta * centered_logx[dose]
+ gamma * centered_x[dose] + lambda[dose]);
}
}