diff options
author | Thomas White <taw@physics.org> | 2014-03-06 19:57:39 +0100 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2014-03-06 19:57:39 +0100 |
commit | 017ab36327202c4548460b7a12ae21db066fc0d2 (patch) | |
tree | 4f987f93facbc2dfd0a8ba8e39602e9e2008ef34 | |
parent | 0b4786372baf696b2b8f34fc4ae455187c4f6f54 (diff) |
Show mean number of correlations per crystal
-rw-r--r-- | src/ambigator.c | 15 |
1 files changed, 13 insertions, 2 deletions
diff --git a/src/ambigator.c b/src/ambigator.c index 9aed3b3f..03c0c476 100644 --- a/src/ambigator.c +++ b/src/ambigator.c @@ -313,11 +313,14 @@ struct cc_list static struct cc_list *calc_ccs(struct flist **crystals, int n_crystals, - int ncorr, SymOpList *amb, gsl_rng *rng) + int ncorr, SymOpList *amb, gsl_rng *rng, + float *pmean_nac) { struct cc_list *ccs; int i; gsl_permutation *p; + long int mean_nac = 0; + int nmean_nac = 0; assert(n_crystals >= ncorr); ncorr++; /* Extra value at end for sentinel */ @@ -365,6 +368,8 @@ static struct cc_list *calc_ccs(struct flist **crystals, int n_crystals, } ccs[i].ind[k] = 0; + mean_nac += k; + nmean_nac++; if ( amb != NULL ) { @@ -390,6 +395,8 @@ static struct cc_list *calc_ccs(struct flist **crystals, int n_crystals, } ccs[i].ind_reidx[k] = 0; + mean_nac += k; + nmean_nac++; } @@ -399,6 +406,8 @@ static struct cc_list *calc_ccs(struct flist **crystals, int n_crystals, gsl_permutation_free(p); + *pmean_nac = (float)mean_nac/nmean_nac; + return ccs; } @@ -506,6 +515,7 @@ int main(int argc, char *argv[]) struct cc_list *ccs; int ncorr = 1000; int stop_after = 0; + float mean_nac; /* Long options */ const struct option longopts[] = { @@ -732,11 +742,12 @@ int main(int argc, char *argv[]) } } - ccs = calc_ccs(crystals, n_crystals, ncorr, amb, rng); + ccs = calc_ccs(crystals, n_crystals, ncorr, amb, rng, &mean_nac); if ( ccs == NULL ) { ERROR("Failed to allocate CCs\n"); return 1; } + STATUS("Mean number of correlations per crystal: %.1f\n", mean_nac); /* FIXME: Free crystals */ |