aboutsummaryrefslogtreecommitdiff
path: root/src/partialator.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/partialator.c')
-rw-r--r--src/partialator.c34
1 files changed, 22 insertions, 12 deletions
diff --git a/src/partialator.c b/src/partialator.c
index 03bdd8aa..db25a8ca 100644
--- a/src/partialator.c
+++ b/src/partialator.c
@@ -175,37 +175,49 @@ static int select_scalable_reflections(RefList *list, RefList *reference)
{
Reflection *refl;
RefListIterator *iter;
- int nobs = 0;
+ int n_acc = 0;
+ int n_red = 0;
+ int n_par = 0;
+ int n_ref = 0;
for ( refl = first_refl(list, &iter);
refl != NULL;
refl = next_refl(refl, iter) ) {
int sc = 1;
- double v, esd;
/* This means the reflection was not found on the last check */
- if ( get_redundancy(refl) == 0 ) sc = 0;
+ if ( get_redundancy(refl) == 0 ) {
+ sc = 0;
+ n_red++;
+ }
- if ( get_partiality(refl) < 0.1 ) sc = 0;
- v = fabs(get_intensity(refl));
- esd = get_esd_intensity(refl);
- //if ( v < 0.5*esd ) sc = 0;
+ /* Don't try to scale up reflections which are hardly there */
+ if ( get_partiality(refl) < 0.1 ) {
+ sc = 0;
+ n_par++;
+ }
/* If we are scaling against a reference set, we additionally
* require that this reflection is in the reference list. */
if ( reference != NULL ) {
signed int h, k, l;
get_indices(refl, &h, &k, &l);
- if ( find_refl(reference, h, k, l) == NULL ) sc = 0;
+ if ( find_refl(reference, h, k, l) == NULL ) {
+ sc = 0;
+ n_ref++;
+ }
}
set_scalable(refl, sc);
- if ( sc ) nobs++;
+ if ( sc ) n_acc++;
}
- return nobs;
+ //STATUS("List %p: %i accepted, %i red zero, %i small part, %i no ref\n",
+ // list, n_acc, n_red, n_par, n_ref);
+
+ return n_acc;
}
@@ -224,8 +236,6 @@ static void select_reflections_for_refinement(Crystal **crystals, int n,
int n_fewmatch = 0;
int n_ref = 0;
- if ( crystal_get_user_flag(crystals[i]) ) continue;
-
reflist = crystal_get_reflections(crystals[i]);
for ( refl = first_refl(reflist, &iter);
refl != NULL;