aboutsummaryrefslogtreecommitdiff
path: root/libcrystfel/src/geometry.c
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2021-03-22 16:28:54 +0100
committerThomas White <taw@physics.org>2021-03-23 18:19:36 +0100
commit66eff85bd922212ffc5b6332abdeffff9c75e761 (patch)
tree0503b2f0a87ce7e98cec17799d5ff6a9f3732ac4 /libcrystfel/src/geometry.c
parent5d42a5a07530509f156bf56dcbcbbfce85e025c7 (diff)
Use crystal's detector shift during prediction
Previously, this was handled by updating the detector, but this could easily lead to strange double accounting.
Diffstat (limited to 'libcrystfel/src/geometry.c')
-rw-r--r--libcrystfel/src/geometry.c26
1 files changed, 17 insertions, 9 deletions
diff --git a/libcrystfel/src/geometry.c b/libcrystfel/src/geometry.c
index adb95e69..68a532b8 100644
--- a/libcrystfel/src/geometry.c
+++ b/libcrystfel/src/geometry.c
@@ -53,6 +53,7 @@
static int locate_peak_on_panel(double x, double y, double z, double k,
struct detgeom_panel *p,
+ double det_shift_x, double det_shift_y,
double *pfs, double *pss)
{
double ctt, tta, phi;
@@ -79,10 +80,10 @@ static int locate_peak_on_panel(double x, double y, double z, double k,
gsl_vector_set(t, 1, sin(tta)*sin(phi));
gsl_vector_set(t, 2, ctt);
- gsl_matrix_set(M, 0, 0, p->cnx);
+ gsl_matrix_set(M, 0, 0, p->cnx+(det_shift_x/p->pixel_pitch));
gsl_matrix_set(M, 0, 1, p->fsx);
gsl_matrix_set(M, 0, 2, p->ssx);
- gsl_matrix_set(M, 1, 0, p->cny);
+ gsl_matrix_set(M, 1, 0, p->cny+(det_shift_y/p->pixel_pitch));
gsl_matrix_set(M, 1, 1, p->fsy);
gsl_matrix_set(M, 1, 2, p->ssy);
gsl_matrix_set(M, 2, 0, p->cnz);
@@ -118,6 +119,7 @@ static int locate_peak_on_panel(double x, double y, double z, double k,
static signed int locate_peak(double x, double y, double z, double k,
struct detgeom *det,
+ double det_shift_x, double det_shift_y,
double *pfs, double *pss)
{
int i;
@@ -130,12 +132,9 @@ static signed int locate_peak(double x, double y, double z, double k,
p = &det->panels[i];
- if ( locate_peak_on_panel(x, y, z, k, p, pfs, pss) ) {
-
- /* Woohoo! */
- return i;
-
- }
+ if ( locate_peak_on_panel(x, y, z, k, p,
+ det_shift_x, det_shift_y,
+ pfs, pss) ) return i; /* Woohoo! */
}
@@ -387,9 +386,13 @@ static Reflection *check_reflection(struct image *image, Crystal *cryst,
if ( (image->detgeom != NULL) && (updateme != NULL) ) {
double fs, ss;
+ double det_shift_x, det_shift_y;
+
assert(get_panel_number(updateme) <= image->detgeom->n_panels);
+ crystal_get_det_shift(cryst, &det_shift_x, &det_shift_y);
locate_peak_on_panel(xl, yl, zl, mean_kpred,
&image->detgeom->panels[get_panel_number(updateme)],
+ det_shift_x, det_shift_y,
&fs, &ss);
set_detector_pos(refl, fs, ss);
@@ -401,8 +404,13 @@ static Reflection *check_reflection(struct image *image, Crystal *cryst,
double fs, ss; /* position on detector */
signed int p; /* panel number */
+ double det_shift_x, det_shift_y;
+
+ crystal_get_det_shift(cryst, &det_shift_x, &det_shift_y);
p = locate_peak(xl, yl, zl, mean_kpred,
- image->detgeom, &fs, &ss);
+ image->detgeom,
+ det_shift_x, det_shift_y,
+ &fs, &ss);
if ( p == -1 ) {
reflection_free(refl);
return NULL;