aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2011-11-08 18:27:38 +0100
committerThomas White <taw@physics.org>2012-02-22 15:27:39 +0100
commiteb7d6184d861d4d9d15737c25101a3d5bcc927e0 (patch)
tree982a6920e2e893b68f5b77aa7f3c3ccc12c6c704 /src
parent58881c8f772dac2920d5cf1c2bf1638e0a086c21 (diff)
Do Poisson on photon counts, not ADU
Diffstat (limited to 'src')
-rw-r--r--src/peaks.c19
1 files changed, 12 insertions, 7 deletions
diff --git a/src/peaks.c b/src/peaks.c
index eef4ea31..3d90861b 100644
--- a/src/peaks.c
+++ b/src/peaks.c
@@ -32,6 +32,7 @@
#include "filters.h"
#include "diffraction.h"
#include "reflist-utils.h"
+#include "beam-parameters.h"
/* How close a peak must be to an indexed position to be considered "close"
@@ -156,6 +157,7 @@ int integrate_peak(struct image *image, int cfs, int css,
int pixel_counts = 0;
double noise_mean = 0.0;
double noise_meansq = 0.0;
+ const double aduph = image->beam->adu_per_photon;
p = find_panel(image->det, cfs, css);
if ( p == NULL ) return 1;
@@ -224,8 +226,9 @@ int integrate_peak(struct image *image, int cfs, int css,
/* If outside inner mask, estimate noise from this region */
if ( fs*fs + ss*ss > mid_lim_sq ) {
- /* Noise */
- noise += val;
+ /* Noise
+ * noise and noise_meansq are both in photons (^2) */
+ noise += val / image->beam->adu_per_photon;
noise_counts++;
noise_meansq += pow(val, 2.0);
@@ -242,7 +245,7 @@ int integrate_peak(struct image *image, int cfs, int css,
}
}
- noise_mean = noise / noise_counts;
+ noise_mean = noise / noise_counts; /* photons */
/* The centroid is excitingly undefined if there is no intensity */
centroid = 0;
@@ -254,23 +257,25 @@ int integrate_peak(struct image *image, int cfs, int css,
*pss = (double)css + 0.5;
}
if ( bgsub ) {
- *intensity = total - pixel_counts*noise_mean;
+ *intensity = total - aduph * pixel_counts*noise_mean; /* ADU */
} else {
- *intensity = total;
+ *intensity = total; /* ADU */
}
if ( in_bad_region(image->det, *pfs, *pss) ) return 1;
if ( sigma != NULL ) {
+
/* First term is standard deviation of background per pixel
* sqrt(pixel_counts) - increase of error for integrated value
* sqrt(2) - increase of error for background subtraction */
*sigma = sqrt(noise_meansq/noise_counts-(noise_mean*noise_mean))
- * sqrt(2.0*pixel_counts);
+ * sqrt(2.0*pixel_counts) * aduph;
+
}
if ( pbg != NULL ) {
- *pbg = (noise / noise_counts);
+ *pbg = aduph * (noise / noise_counts);
}
if ( pmax != NULL ) {
*pmax = max;