diff options
author | Thomas White <taw@physics.org> | 2023-07-13 17:18:54 +0200 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2023-07-28 13:22:05 +0200 |
commit | b1089d5a0b75fb1dc66a6d8384d5e3ff1d0d7d78 (patch) | |
tree | 2233e60d39abd2d0dc80654b3dc4f38ce6472107 | |
parent | 2501aedda111feaf139f9d8e94c4ab36926e93e3 (diff) |
Re-define geometry group labelling scheme
The old version was totally broken. The serial numbers have to contain
the complete hierarchy information, otherwise they aren't unique.
-rw-r--r-- | libcrystfel/src/crystfel-mille.c | 43 | ||||
-rw-r--r-- | libcrystfel/src/crystfel-mille.h | 2 | ||||
-rw-r--r-- | libcrystfel/src/datatemplate.c | 12 | ||||
-rw-r--r-- | libcrystfel/src/detgeom.c | 4 | ||||
-rw-r--r-- | libcrystfel/src/detgeom.h | 3 |
5 files changed, 21 insertions, 43 deletions
diff --git a/libcrystfel/src/crystfel-mille.c b/libcrystfel/src/crystfel-mille.c index 139f2e9e..974ecf27 100644 --- a/libcrystfel/src/crystfel-mille.c +++ b/libcrystfel/src/crystfel-mille.c @@ -54,20 +54,15 @@ static const enum gparam rv[] = }; -int mille_label(int hierarchy_level, int member_index, enum gparam param) +int mille_label(int group_serial, enum gparam param) { - int label; - - assert(member_index < 1000); - - label = 100000*hierarchy_level + 100*member_index; switch ( param ) { - case GPARAM_DET_TX : return label+1; /* x-shift */ - case GPARAM_DET_TY : return label+2; /* y-shift */ - case GPARAM_DET_TZ : return label+3; /* z-shift */ - case GPARAM_DET_RX : return label+4; /* Rotation around x */ - case GPARAM_DET_RY : return label+5; /* Rotation around y */ - case GPARAM_DET_RZ : return label+6; /* Rotation around z */ + case GPARAM_DET_TX : return group_serial+1; /* x-shift */ + case GPARAM_DET_TY : return group_serial+2; /* y-shift */ + case GPARAM_DET_TZ : return group_serial+3; /* z-shift */ + case GPARAM_DET_RX : return group_serial+4; /* Rotation around x */ + case GPARAM_DET_RY : return group_serial+5; /* Rotation around y */ + case GPARAM_DET_RZ : return group_serial+6; /* Rotation around z */ default : abort(); } } @@ -112,9 +107,7 @@ void write_mille(Mille *mille, int n, UnitCell *cell, Minvs[rps[i].peak->pn], 0, 0, 0, &global_gradients_fs[j], &global_gradients_ss[j]); - labels[j] = mille_label(group->hierarchy_level, - group->member_index, - GPARAM_DET_TX); + labels[j] = mille_label(group->serial, GPARAM_DET_TX); j++; fs_ss_gradient(GPARAM_DET_TY, rps[i].refl, cell, @@ -122,9 +115,7 @@ void write_mille(Mille *mille, int n, UnitCell *cell, Minvs[rps[i].peak->pn], 0, 0, 0, &global_gradients_fs[j], &global_gradients_ss[j]); - labels[j] = mille_label(group->hierarchy_level, - group->member_index, - GPARAM_DET_TY); + labels[j] = mille_label(group->serial, GPARAM_DET_TY); j++; fs_ss_gradient(GPARAM_DET_TZ, rps[i].refl, cell, @@ -132,9 +123,7 @@ void write_mille(Mille *mille, int n, UnitCell *cell, Minvs[rps[i].peak->pn], 0, 0, 0, &global_gradients_fs[j], &global_gradients_ss[j]); - labels[j] = mille_label(group->hierarchy_level, - group->member_index, - GPARAM_DET_TZ); + labels[j] = mille_label(group->serial, GPARAM_DET_TZ); j++; fs_ss_gradient(GPARAM_DET_RX, rps[i].refl, cell, @@ -142,9 +131,7 @@ void write_mille(Mille *mille, int n, UnitCell *cell, Minvs[rps[i].peak->pn], cx, cy, cz, &global_gradients_fs[j], &global_gradients_ss[j]); - labels[j] = mille_label(group->hierarchy_level, - group->member_index, - GPARAM_DET_RX); + labels[j] = mille_label(group->serial, GPARAM_DET_RX); j++; fs_ss_gradient(GPARAM_DET_RY, rps[i].refl, cell, @@ -152,9 +139,7 @@ void write_mille(Mille *mille, int n, UnitCell *cell, Minvs[rps[i].peak->pn], cx, cy, cz, &global_gradients_fs[j], &global_gradients_ss[j]); - labels[j] = mille_label(group->hierarchy_level, - group->member_index, - GPARAM_DET_RX); + labels[j] = mille_label(group->serial, GPARAM_DET_RY); j++; fs_ss_gradient(GPARAM_DET_RZ, rps[i].refl, cell, @@ -162,9 +147,7 @@ void write_mille(Mille *mille, int n, UnitCell *cell, Minvs[rps[i].peak->pn], cx, cy, cz, &global_gradients_fs[j], &global_gradients_ss[j]); - labels[j] = mille_label(group->hierarchy_level, - group->member_index, - GPARAM_DET_RZ); + labels[j] = mille_label(group->serial, GPARAM_DET_RZ); j++; group = group->parent; diff --git a/libcrystfel/src/crystfel-mille.h b/libcrystfel/src/crystfel-mille.h index fc290cbb..adec271a 100644 --- a/libcrystfel/src/crystfel-mille.h +++ b/libcrystfel/src/crystfel-mille.h @@ -48,7 +48,7 @@ extern Mille *crystfel_mille_new(const char *outFileName, extern void crystfel_mille_free(Mille *m); -extern int mille_label(int hierarchy_level, int member_index, enum gparam param); +extern int mille_label(int group_serial, enum gparam param); extern void write_mille(Mille *mille, int n, UnitCell *cell, struct reflpeak *rps, struct image *image, diff --git a/libcrystfel/src/datatemplate.c b/libcrystfel/src/datatemplate.c index 2c689a43..6adfb9f3 100644 --- a/libcrystfel/src/datatemplate.c +++ b/libcrystfel/src/datatemplate.c @@ -1819,8 +1819,7 @@ static void add_dg_point(const struct detgeom_panel *p, static struct detgeom_panel_group *walk_group(const DataTemplate *dtempl, struct panel_group_template *gt, struct detgeom *detgeom, - int hierarchy_level, - int member_index) + int serial, int c_mul) { struct detgeom_panel_group *gr; @@ -1872,8 +1871,8 @@ static struct detgeom_panel_group *walk_group(const DataTemplate *dtempl, } for ( i=0; i<gt->n_children; i++ ) { - gr->children[i] = walk_group(dtempl, gt->children[i], - detgeom, hierarchy_level+1, i); + gr->children[i] = walk_group(dtempl, gt->children[i], detgeom, + serial + c_mul*(i+1), c_mul*100); if ( gr->children[i] == NULL ) return NULL; gr->children[i]->parent = gr; tx += gr->children[i]->cx; @@ -1887,8 +1886,7 @@ static struct detgeom_panel_group *walk_group(const DataTemplate *dtempl, } - gr->member_index = member_index; - gr->hierarchy_level = hierarchy_level; + gr->serial = serial; return gr; } @@ -2017,7 +2015,7 @@ struct detgeom *create_detgeom(struct image *image, } - detgeom->top_group = walk_group(dtempl, find_group(dtempl, "all"), detgeom, 0, 0); + detgeom->top_group = walk_group(dtempl, find_group(dtempl, "all"), detgeom, 0, 100); if ( detgeom->top_group != NULL ) { detgeom->top_group->parent = NULL; } else { diff --git a/libcrystfel/src/detgeom.c b/libcrystfel/src/detgeom.c index 1e86eb95..eaf7c898 100644 --- a/libcrystfel/src/detgeom.c +++ b/libcrystfel/src/detgeom.c @@ -202,9 +202,7 @@ static void detgeom_show_group(const struct detgeom_panel_group *group, int leve return; } - STATUS("%s (level %i, index %i)\n", group->name, - group->hierarchy_level, - group->member_index); + STATUS("%s (serial %i)\n", group->name, group->serial); for ( i=0; i<group->n_children; i++ ) { detgeom_show_group(group->children[i], level+1); diff --git a/libcrystfel/src/detgeom.h b/libcrystfel/src/detgeom.h index 5a1a758e..53877b2e 100644 --- a/libcrystfel/src/detgeom.h +++ b/libcrystfel/src/detgeom.h @@ -96,8 +96,7 @@ struct detgeom_panel_group int n_children; struct detgeom_panel_group *parent; - int hierarchy_level; - int member_index; + int serial; /* Center of panel group, in lab coordinate system (metres) * This will be the rotation center. */ |