Skip to content

Commit

Permalink
bob's review comments
Browse files Browse the repository at this point in the history
  • Loading branch information
adamhaber committed Jul 15, 2022
1 parent e582e79 commit 06a20e2
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 18 deletions.
17 changes: 10 additions & 7 deletions transforms/cholesky/stan_transform.stan
Original file line number Diff line number Diff line change
@@ -1,22 +1,25 @@
#include transform_functions.stan
data {
int<lower=0> K;
}
parameters {
vector[(K*(K-1)) %/% 2] y;
// y is a vector K-choose-2 unconstrained parameters
vector[choose_2(K)] y;
}
transformed parameters {
matrix[K, K] L = diag_matrix(rep_vector(1, K));
vector<lower=-1, upper=1>[(K*(K-1)) %/% 2] z = tanh(y);
// L is a Cholesky factor of a K x K correlation matrix
cholesky_factor_corr[K] L = diag_matrix(rep_vector(1, K));
real log_det_jacobian = 0;
{
int counter = 1;
real sum_sqs;

for (i in 2:K) {
vector[choose_2(K)] z = tanh(y);

for (i in 2 : K) {
L[i, 1] = z[counter];
counter += 1;
sum_sqs = square(L[i, 1]);
for (j in 2:(i-1)) {
for (j in 2 : (i - 1)) {
log_det_jacobian += 0.5 * log1m(sum_sqs);
L[i, j] = z[counter] * sqrt(1 - sum_sqs);
counter += 1;
Expand All @@ -28,5 +31,5 @@ transformed parameters {
}
model {
target += log_det_jacobian;
target += lkj_corr_cholesky_lpdf(L | 2.);
target += lkj_corr_cholesky_lpdf(L | 2);
}
22 changes: 11 additions & 11 deletions transforms/cholesky/tfp_transform.stan
Original file line number Diff line number Diff line change
@@ -1,31 +1,31 @@
#include transform_functions.stan
data {
int<lower=0> K;
}
transformed data {

}
parameters {
vector[(K*(K-1)) %/% 2] y;
// y is a vector K-choose-2 unconstrained parameters
vector[choose_2(K)] y;
}
transformed parameters {
matrix[K, K] L = diag_matrix(rep_vector(1, K));
// L is a Cholesky factor of a K x K correlation matrix
cholesky_factor_corr[K] L = diag_matrix(rep_vector(1, K));
real log_det_jacobian;
{
int counter = 1;

for (i in 2:K) {
for (i in 2 : K) {
L[i, 1] = y[counter];
counter += 1;
for (j in 2:(i-1)) {
for (j in 2 : (i - 1)) {
L[i, j] = y[counter];
counter += 1;
}
L[i , :i] = L[i , :i] / sqrt(sum(square(L[i , :i ])));
log_det_jacobian += (K - i + 1) * log(L[i,i]);
L[i, : i] = L[i, : i] / sqrt(sum(square(L[i, : i])));
log_det_jacobian += (K - i + 1) * log(L[i, i]);
}
}
}
model {
target += log_det_jacobian;
target += lkj_corr_cholesky_lpdf(L | 2.);
target += lkj_corr_cholesky_lpdf(L | 2);
}
5 changes: 5 additions & 0 deletions transforms/cholesky/transform_functions.stan
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
functions {
int choose_2(int K) {
return (K * (K - 1)) %/% 2;
}
}

0 comments on commit 06a20e2

Please sign in to comment.