diff options
author | Thomas White <taw@physics.org> | 2013-06-25 15:54:14 -0700 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2013-06-25 15:54:14 -0700 |
commit | 2ebb48c1be2ec749f61422919b59838710c999c7 (patch) | |
tree | 075e662efa3d0411a56265515a7d6a284b73faba /libcrystfel/src/integration.c | |
parent | 0252a3dd4241f8465e58062b710cbc7b77a5502d (diff) |
Restore sigma calculation with --integration=rings
Diffstat (limited to 'libcrystfel/src/integration.c')
-rw-r--r-- | libcrystfel/src/integration.c | 44 |
1 files changed, 41 insertions, 3 deletions
diff --git a/libcrystfel/src/integration.c b/libcrystfel/src/integration.c index 11e58c57..ca8cbb08 100644 --- a/libcrystfel/src/integration.c +++ b/libcrystfel/src/integration.c @@ -1040,7 +1040,41 @@ static double calc_sigma(struct intcontext *ic, struct peak_box *bx) } -static double average_background(struct intcontext *ic, struct peak_box *bx) +static void mean_var_background(struct intcontext *ic, struct peak_box *bx, + double *pmean, double *pvar) +{ + int p, q; + double sum = 0.0; + double var = 0.0; + int n = 0; + double mean; + + for ( p=0; p<ic->w; p++ ) { + for ( q=0; q<ic->w; q++ ) { + if ( bx->bm[p + ic->w*q] != BM_BG ) continue; + sum += bx->a*p + bx->b*q + bx->c; + n++; + } + } + mean = sum/n; + + n = 0; + for ( p=0; p<ic->w; p++ ) { + for ( q=0; q<ic->w; q++ ) { + if ( bx->bm[p + ic->w*q] != BM_BG ) continue; + var += pow(bx->a*p + bx->b*q + bx->c - mean, 2.0); + n++; + } + } + + var = var/n; + + *pmean = mean; + *pvar = var; +} + + +static double bg_under_peak(struct intcontext *ic, struct peak_box *bx) { int p, q; double sum = 0.0; @@ -1090,7 +1124,7 @@ static int suitable_reference(struct intcontext *ic, struct peak_box *bx) } } - height_ok = max > 10.0 * average_background(ic, bx); + height_ok = max > 10.0 * bg_under_peak(ic, bx); return bg_ok(bx) && height_ok; } @@ -1639,6 +1673,7 @@ static void integrate_rings(IntegrationMethod meth, Crystal *cr, int saturated; double one_over_d; int r; + double bgmean, sig2_bg, sig2_poisson, aduph; set_redundancy(refl, 0); @@ -1692,7 +1727,10 @@ static void integrate_rings(IntegrationMethod meth, Crystal *cr, fit_bg(&ic, bx); intensity = tentative_intensity(&ic, bx); - sigma = 0.0; /* FIXME! */ + mean_var_background(&ic, bx, &bgmean, &sig2_bg); + aduph = bx->p->adu_per_eV * ph_lambda_to_eV(ic.image->lambda); + sig2_poisson = aduph * intensity; + sigma = sqrt(sig2_poisson + bx->m*sig2_bg); if ( bx->verbose ) show_peak_box(&ic, bx); |