aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libcrystfel/src/reax.c70
1 files changed, 29 insertions, 41 deletions
diff --git a/libcrystfel/src/reax.c b/libcrystfel/src/reax.c
index 680e7d31..37e1ca05 100644
--- a/libcrystfel/src/reax.c
+++ b/libcrystfel/src/reax.c
@@ -46,7 +46,7 @@
/* Maximum number of candidate vectors to find (we will take the best ones) */
-#define MAX_CANDIDATES (32)
+#define MAX_CANDIDATES (1024)
struct dvec
@@ -73,6 +73,7 @@ struct reax_search_v
struct reax_candidate *cand; /* Candidate vectors go here */
int n_cand; /* There are this many candidates */
+ int max_warned;
};
@@ -147,42 +148,22 @@ static void fill_and_transform(struct dvec *dir, ImageFeatureList *flist,
}
-static void add_candidate(struct reax_search_v *s, struct dvec *dir,
- double fom, double peak_mod)
+static void add_candidate(struct reax_search_v *s, struct reax_candidate *c)
{
- struct reax_candidate cshift;
- size_t ns;
- int i, cpos;
+ int idx;
- cpos = s->n_cand;
- for ( i=0; i<s->n_cand; i++ ) {
- if ( fom > s->cand[i].fom ) {
- cpos = i;
- break;
+ if ( s->n_cand == MAX_CANDIDATES ) {
+ if ( !s->max_warned ) {
+ ERROR("Warning: Too many candidates.\n");
+ s->max_warned = 1;
}
+ return;
}
- cshift.v.x = dir->x*peak_mod;
- cshift.v.y = dir->y*peak_mod;
- cshift.v.z = dir->z*peak_mod;
- cshift.v.th = dir->th;
- cshift.v.ph = dir->ph;
- cshift.fom = fom;
+ idx = s->n_cand++;
- for ( i=cpos; i<s->n_cand; i++ ) {
-
- struct reax_candidate cshift2;
- cshift2 = s->cand[i];
- s->cand[i] = cshift;
- cshift = cshift2;
-
- }
-
- if ( s->n_cand >= MAX_CANDIDATES ) {
- /* "cshift" just fell off the end of the list */
- } else {
- s->cand[s->n_cand++] = cshift;
- }
+ s->cand[idx].v = c->v;
+ s->cand[idx].fom = c->fom;
}
@@ -247,11 +228,14 @@ static double check_dir(struct dvec *dir, ImageFeatureList *flist,
/* If sufficiently strong, add to list of candidates */
if ( peak > mean+MIN_SIGMAS*sd ) {
- double fom;
+ struct reax_candidate c;
- fom = peak;
+ c.v.x = dir->x * peak_mod;
+ c.v.y = dir->y * peak_mod;
+ c.v.z = dir->z * peak_mod;
+ c.fom = peak;
- add_candidate(&s->search[i], dir, fom, peak_mod);
+ add_candidate(&s->search[i], &c);
}
@@ -261,7 +245,9 @@ static double check_dir(struct dvec *dir, ImageFeatureList *flist,
}
-/* Refine a direct space vector. From Clegg (1984) */
+/* Refine a direct space vector. From Clegg (1984)
+ * with added iteration because more reflections might get included as the
+ * refinement proceeds. */
static double iterate_refine_vector(double *x, double *y, double *z,
ImageFeatureList *flist)
{
@@ -479,6 +465,8 @@ static void find_candidates(struct reax_private *p,
s, NULL, NULL);
}
+ squash_vectors(s, INC_TOL_MULTIPLIER*p->angular_inc);
+
//show_vectors(s, "BEFORE");
for ( i=0; i<s->n_search; i++ ) {
@@ -487,12 +475,9 @@ static void find_candidates(struct reax_private *p,
int j;
sv = &s->search[i];
- for ( j=0; j<smallest(sv->n_cand, 3); j++ ) {
-// refine_vector(flist, &sv->cand[j].v);
- }
- }
+ refine_vector(flist, &sv->cand[j].v);
-// squash_vectors(s, INC_TOL_MULTIPLIER*p->angular_inc);
+ }
//show_vectors(s, "FINAL");
}
@@ -531,10 +516,13 @@ static struct reax_search *search_all_axes(UnitCell *cell, double pmax)
s->search = malloc(3*sizeof(struct reax_search_v));
smin = 2.0*pmax * amin; smax = 2.0*pmax * amax;
s->search[0].smin = smin; s->search[0].smax = smax;
+ s->search[0].max_warned = 0;
smin = 2.0*pmax * bmin; smax = 2.0*pmax * bmax;
s->search[1].smin = smin; s->search[1].smax = smax;
+ s->search[1].max_warned = 0;
smin = 2.0*pmax * cmin; smax = 2.0*pmax * cmax;
s->search[2].smin = smin; s->search[2].smax = smax;
+ s->search[2].max_warned = 0;
return s;
}
@@ -1053,7 +1041,7 @@ IndexingPrivate *reax_prepare()
p->base.indm = INDEXING_REAX;
- p->angular_inc = deg2rad(1.7); /* From Steller (1997) */
+ p->angular_inc = deg2rad(1.0);
/* Reserve memory, over-estimating the number of directions */
samp = 2.0*M_PI / p->angular_inc;