-
Notifications
You must be signed in to change notification settings - Fork 0
/
gerard21.stan
94 lines (78 loc) · 2.17 KB
/
gerard21.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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
# F99 no distribution priors free RV, exponential AV
data {
int D; // Number of supernovae
int N_mags;
int N_EWs;
vector[N_mags] mag_obs[D];
vector[N_EWs] EW_obs[D];
matrix[N_mags, N_mags] mag_cov[D];
matrix[N_EWs, N_EWs] EW_cov[D];
vector[D] sivel_obs;
vector[D] sivel_err;
vector[5] a[9];
}
parameters {
vector[5] c_raw;
vector[5] alpha_raw;
vector[5] beta_raw;
vector<lower=0.0>[N_mags] L_sigma_raw;
vector[5] eta_raw;
real <lower=0> Delta_scale;
cholesky_factor_corr[N_mags] L_Omega;
vector[2] EW[D];
vector[D] sivel;
vector[N_mags] mag_int_raw[D];
simplex[D] Delta_unit;
vector<lower=0>[D] AV_raw;
vector<lower=0.9,upper=8>[D] RV;
real<lower=0> AV_scale;
}
transformed parameters {
vector[5] c;
vector[5] alpha;
vector[5] beta;
vector[5] eta;
vector[N_mags] L_sigma;
vector[D] Delta;
vector[5] gamma;
vector[5] rho1;
vector[N_mags] mag_int[D];
vector<lower=0,upper=1.8>[D] AV;
c = c_raw/1e2;
alpha = alpha_raw/5e2;
beta = beta_raw/2e2;
eta = eta_raw/6e2;
L_sigma = L_sigma_raw/100.;
Delta = 4.*Delta_scale*(Delta_unit-1./D);
# non-centered parameterization
{
matrix[5,5] L_Sigma;
L_Sigma = diag_pre_multiply(L_sigma, L_Omega);
for (d in 1:D) {
mag_int[d] = Delta[d] + c+ alpha*EW[d,1] + beta*EW[d,2] + eta*sivel[d] + L_Sigma * mag_int_raw[d];
}
}
AV = AV_raw*AV_scale;
}
model {
real ebv;
vector [5] AX;
target += cauchy_lpdf(L_sigma | 0.1,0.1);
target += lkj_corr_cholesky_lpdf(L_Omega | 4.);
for (d in 1:D) {
ebv = AV[d]/RV[d];
target += normal_lpdf(mag_int_raw[d]| 0, 1);
AX = a[1]* AV[d] + a[2] * AV[d]^2
+ a[3]* ebv+ a[4] * ebv^2
+ a[5] * AV[d]* ebv
+ a[6]* AV[d]^3
+ a[7] * ebv^3
+ a[8] * (AV[d]^2) * ebv
+ a[9] * AV[d] * (ebv^2);
target += multi_normal_lpdf(mag_obs[d] | mag_int[d] + AX, mag_cov[d]);
target += multi_normal_lpdf(EW_obs[d] | EW[d], EW_cov[d]);
}
target += (normal_lpdf(sivel_obs | sivel,sivel_err));
target += exponential_lpdf(AV_raw | 1.);
target += cauchy_lpdf(AV_scale|0,1);
}