diff options
author | Thomas White <taw@physics.org> | 2014-05-23 16:17:35 +0200 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2014-05-23 16:17:35 +0200 |
commit | 229cbd2c0377ed5595178d3c299fada519507233 (patch) | |
tree | cad418b76ad2ebc66b266e4096607d3bcffe3094 /src/hrs-scaling.c | |
parent | ddd55d93f37a76f30948a25baf5ae221dacd80ca (diff) |
Simplify criteria for scaling, merging and PR
Diffstat (limited to 'src/hrs-scaling.c')
-rw-r--r-- | src/hrs-scaling.c | 25 |
1 files changed, 12 insertions, 13 deletions
diff --git a/src/hrs-scaling.c b/src/hrs-scaling.c index 912993a5..2fef0925 100644 --- a/src/hrs-scaling.c +++ b/src/hrs-scaling.c @@ -47,6 +47,12 @@ #include "reflist.h" +/* Minimum partiality of a reflection for it to be used for scaling */ +#define MIN_PART_SCALE (0.05) + +/* Minimum partiality of a reflection for it to be merged */ +#define MIN_PART_MERGE (0.05) + /* Maximum number of iterations of scaling per macrocycle. */ #define MAX_CYCLES (10) @@ -105,19 +111,14 @@ static void run_scale_job(void *vwargs, int cookie) double Ih, Ihl, corr; Reflection *r; - if ( !get_scalable(refl) ) continue; + if ( get_partiality(refl) < MIN_PART_SCALE ) continue; /* Look up by asymmetric indices */ get_indices(refl, &h, &k, &l); r = find_refl(reference, h, k, l); - if ( r == NULL ) { - ERROR("%3i %3i %3i isn't in the " - "reference list, so why is it " - "marked as scalable?\n", h, k, l); - Ih = 0.0; - } else { - Ih = get_intensity(r); - } + if ( r == NULL ) continue; + + Ih = get_intensity(r); corr = get_partiality(refl) * get_lorentz(refl); @@ -228,7 +229,7 @@ static void run_merge_job(void *vwargs, int cookie) int red; double Ihl, corr; - if ( !get_scalable(refl) ) continue; + if ( get_partiality(refl) < MIN_PART_MERGE ) continue; get_indices(refl, &h, &k, &l); pthread_rwlock_rdlock(wargs->full_lock); @@ -385,7 +386,7 @@ static void run_esd_job(void *vwargs, int cookie) double num; double Ihl, Ih, corr; - if ( !get_scalable(refl) ) continue; + if ( get_partiality(refl) < MIN_PART_MERGE ) continue; get_indices(refl, &h, &k, &l); f = find_refl(full, h, k, l); @@ -482,8 +483,6 @@ static void reject_outliers(struct osfcheck *och, int n, Crystal **crystals) crystal_set_user_flag(crystals[och[i].n], 1); crystal_set_osf(crystals[och[i].n], och[i].old_osf); - } else { - crystal_set_user_flag(crystals[och[i].n], 0); } } } |