aboutsummaryrefslogtreecommitdiff
path: root/libcrystfel/src/taketwo.c
diff options
context:
space:
mode:
Diffstat (limited to 'libcrystfel/src/taketwo.c')
-rw-r--r--libcrystfel/src/taketwo.c42
1 files changed, 26 insertions, 16 deletions
diff --git a/libcrystfel/src/taketwo.c b/libcrystfel/src/taketwo.c
index ddad7cf7..2c6b4f06 100644
--- a/libcrystfel/src/taketwo.c
+++ b/libcrystfel/src/taketwo.c
@@ -86,13 +86,13 @@ int global_nrlps;
#define MAX_NETWORK_MEMBERS (500)
/* Maximum dead ends for a single branch extension during indexing */
-#define MAX_DEAD_ENDS (15)
+#define MAX_DEAD_ENDS (10)
/* Tolerance for two angles to be considered the same */
#define ANGLE_TOLERANCE (deg2rad(1.0))
/* Tolerance for rot_mats_are_similar */
-#define TRACE_TOLERANCE (deg2rad(7.0))
+#define TRACE_TOLERANCE (deg2rad(4.0))
/** TODO:
*
@@ -617,10 +617,10 @@ static signed int find_next_index(gsl_matrix *rot, struct SpotVec *obs_vecs,
if (ok)
{
- generate_rot_mat(obs_vecs[idx0].obsvec,
+ /* generate_rot_mat(obs_vecs[idx0].obsvec,
obs_vecs[i].obsvec,
member_match,
- a_match, 1);
+ a_match, 0);*/
*match_found = j;
return i;
}
@@ -678,12 +678,10 @@ static int grow_network(gsl_matrix *rot, struct SpotVec *obs_vecs,
}
if ( next_index < 0 ) {
- STATUS("dead end number %i..\n", dead_ends);
- /* If there have been too many dead ends, give up
+ /* If there have been too many dead ends, give up
* on indexing altogether.
**/
if ( dead_ends > MAX_DEAD_ENDS ) {
- STATUS("Too many dead ends!\n");
dead_ends = 0;
continue;
}
@@ -693,7 +691,6 @@ static int grow_network(gsl_matrix *rot, struct SpotVec *obs_vecs,
start++;
member_num--;
dead_ends++;
- STATUS("Shaving back one.\n");
continue;
}
@@ -744,7 +741,7 @@ static int start_seed(struct SpotVec *obs_vecs, int obs_vec_count, int i,
rot_mat = generate_rot_mat(obs_vecs[i].obsvec,
obs_vecs[j].obsvec,
obs_vecs[i].matches[i_match],
- obs_vecs[j].matches[j_match], 1);
+ obs_vecs[j].matches[j_match], 0);
/* Try to expand this rotation matrix to a larger network */
STATUS("idx: %i %i %i %i spots %i %i and %i %i\n",
@@ -801,7 +798,7 @@ static int find_seed(struct SpotVec *obs_vecs, int obs_vec_count,
/* We have seeds! Pass each of them through the seed-starter */
int k;
- for ( k=0; k<matches; k++ ) {
+ for ( k=0; k<1; k++ ) {
int success = start_seed(obs_vecs, obs_vec_count, i, j,
i_idx[k], j_idx[k],
rotation);
@@ -912,11 +909,8 @@ static int gen_observed_vecs(struct rvec *rlps, int rlp_count,
double sqlength = sq_length(diff);
if ( sqlength > max_sq_length ) continue;
- STATUS("obs %i (spots %i and %i)", count, i, j);
- struct rvec norm = new_rvec(diff.u, diff.v, diff.w);
- normalise_rvec(&norm);
- show_rvec(norm);
-
+// STATUS("obs %i (spots %i and %i)", count, i, j);
+
count++;
struct SpotVec *temp_obs_vecs;
@@ -1098,8 +1092,23 @@ int taketwo_index(struct image *image, IndexingPrivate *ipriv)
UnitCell *cell;
struct rvec *rlps;
int n_rlps = 0;
+ int i;
struct taketwo_private *tp = (struct taketwo_private *)ipriv;
+ rlps = malloc((image_feature_count(image->features)+1)*sizeof(struct rvec));
+ for ( i=0; i<image_feature_count(image->features); i++ ) {
+ struct imagefeature *pk = image_get_feature(image->features, i);
+ if ( pk == NULL ) continue;
+ rlps[n_rlps].u = pk->rx;
+ rlps[n_rlps].v = pk->ry;
+ rlps[n_rlps].w = pk->rz;
+ n_rlps++;
+ }
+ rlps[n_rlps].u = 0.0;
+ rlps[n_rlps].v = 0.0;
+ rlps[n_rlps++].w = 0.0;
+
+/*
FILE *fh = fopen("../../spots.csv", "r");
rlps = malloc(500*sizeof(struct rvec));
while ( (fh != NULL) && !feof(fh) ) {
@@ -1122,7 +1131,8 @@ int taketwo_index(struct image *image, IndexingPrivate *ipriv)
rlps[n_rlps].u = 0.0;
rlps[n_rlps].v = 0.0;
rlps[n_rlps++].w = 0.0;
- if ( fh != NULL ) fclose(fh);
+
+ if ( fh != NULL ) fclose(fh);*/
cell = run_taketwo(tp->cell, rlps, n_rlps);
if ( cell == NULL ) return 0;