aboutsummaryrefslogtreecommitdiff
path: root/src/process_hkl.c
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2014-04-08 17:03:00 +0200
committerThomas White <taw@physics.org>2014-04-08 17:08:53 +0200
commit1d6fdfc003f46ea5cf618459d215a032390afc15 (patch)
tree104745e8ef17bf9c022ed7512e73f2537adc4205 /src/process_hkl.c
parent54176de692b7709e1148904089229f09758436f1 (diff)
process_hkl: Add --min-res
Diffstat (limited to 'src/process_hkl.c')
-rw-r--r--src/process_hkl.c23
1 files changed, 20 insertions, 3 deletions
diff --git a/src/process_hkl.c b/src/process_hkl.c
index c9e2c44a..54d0c8b4 100644
--- a/src/process_hkl.c
+++ b/src/process_hkl.c
@@ -82,6 +82,7 @@ static void show_help(const char *s)
" --min-snr=<n> Require individual intensity measurements to\n"
" have I > n * sigma(I). Default: -infinity.\n"
" --max-adu=<n> Maximum peak value. Default: infinity.\n"
+" --min-res=<n> Merge only crystals which diffract above <n> A.\n"
);
}
@@ -308,7 +309,7 @@ static int merge_all(Stream *st, RefList *model, RefList *reference,
signed int hist_k, signed int hist_l,
int *hist_i, int config_nopolar, int min_measurements,
double min_snr, double max_adu,
- int start_after, int stop_after)
+ int start_after, int stop_after, double min_res)
{
int rval;
int n_images = 0;
@@ -339,6 +340,10 @@ static int merge_all(Stream *st, RefList *model, RefList *reference,
n_crystals_seen++;
if ( n_crystals_seen <= start_after ) continue;
+ if ( crystal_get_resolution_limit(cr) < min_res ) {
+ continue;
+ }
+
n_crystals++;
r = merge_crystal(model, &image, cr, reference, sym,
hist_vals, hist_h, hist_k, hist_l,
@@ -414,6 +419,7 @@ int main(int argc, char *argv[])
int stop_after = 0;
double min_snr = -INFINITY;
double max_adu = +INFINITY;
+ double min_res = 0.0;
/* Long options */
const struct option longopts[] = {
@@ -434,6 +440,7 @@ int main(int argc, char *argv[])
{"min-measurements", 1, NULL, 2},
{"min-snr", 1, NULL, 3},
{"max-adu", 1, NULL, 4},
+ {"min-res", 1, NULL, 5},
{0, 0, NULL, 0}
};
@@ -516,6 +523,16 @@ int main(int argc, char *argv[])
}
break;
+ case 5 :
+ errno = 0;
+ min_res = strtod(optarg, &rval);
+ if ( *rval != '\0' ) {
+ ERROR("Invalid value for --min-res.\n");
+ return 1;
+ }
+ min_res = 1e10/min_res;
+ break;
+
case '?' :
break;
@@ -597,7 +614,7 @@ int main(int argc, char *argv[])
hist_i = 0;
r = merge_all(st, model, NULL, sym, &hist_vals, hist_h, hist_k, hist_l,
&hist_i, config_nopolar, min_measurements, min_snr,
- max_adu, start_after, stop_after);
+ max_adu, start_after, stop_after, min_res);
fprintf(stderr, "\n");
if ( r ) {
ERROR("Error while reading stream.\n");
@@ -629,7 +646,7 @@ int main(int argc, char *argv[])
r = merge_all(st, model, reference, sym,
&hist_vals, hist_h, hist_k, hist_l, &hist_i,
config_nopolar, min_measurements, min_snr,
- max_adu, start_after, stop_after);
+ max_adu, start_after, stop_after, min_res);
fprintf(stderr, "\n");
if ( r ) {
ERROR("Error while reading stream.\n");