aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2014-04-29 14:39:53 +0200
committerThomas White <taw@physics.org>2014-04-29 14:39:53 +0200
commit0a4634e81f02306a0d1acd1193761921be39b4cd (patch)
tree77df54e856689ac98baf92ee006c5c84b6883564
parent4a0506f0da48081e99daa2e14e84bf44be502fab (diff)
get_hkl: Add --reindex
-rw-r--r--src/get_hkl.c48
1 files changed, 45 insertions, 3 deletions
diff --git a/src/get_hkl.c b/src/get_hkl.c
index 8ba77ebf..ae82858c 100644
--- a/src/get_hkl.c
+++ b/src/get_hkl.c
@@ -3,11 +3,11 @@
*
* Small program to manipulate reflection lists
*
- * Copyright © 2013 Deutsches Elektronen-Synchrotron DESY,
- * a research centre of the Helmholtz Association.
+ * Copyright © 2013-2014 Deutsches Elektronen-Synchrotron DESY,
+ * a research centre of the Helmholtz Association.
*
* Authors:
- * 2009-2013 Thomas White <taw@physics.org>
+ * 2009-2014 Thomas White <taw@physics.org>
*
* This file is part of CrystFEL.
*
@@ -73,6 +73,9 @@ static void show_help(const char *s)
" --no-need-all-parts Output a twinned reflection even if not all\n"
" the necessary equivalents were present.\n"
"\n"
+"You can reindex the reflections according to an operation, e.g. k,h,-l:\n"
+" --reindex=<op> Reindex according to <op>.\n"
+"\n"
"Use this option with care, and only if you understand why it might sometimes\n"
" be necessary:\n"
" --trim-centrics Remove reflections which are duplicated in the\n"
@@ -409,6 +412,8 @@ int main(int argc, char *argv[])
double cutiso = 0.0;
float cutn1, cutn2, cutn3;
char *pdb = NULL;
+ char *reindex_str = NULL;
+ SymOpList *reindex = NULL;
/* Long options */
const struct option longopts[] = {
@@ -427,6 +432,7 @@ int main(int argc, char *argv[])
{"no-need-all-parts", 0, &config_nap, 0},
{"adu-per-photon", 1, NULL, 2},
{"cutoff-angstroms", 1, NULL, 3},
+ {"reindex", 1, NULL, 4},
{0, 0, NULL, 0}
};
@@ -477,6 +483,10 @@ int main(int argc, char *argv[])
cutoff_str = strdup(optarg);
break;
+ case 4 :
+ reindex_str = strdup(optarg);
+ break;
+
case 0 :
break;
@@ -555,6 +565,12 @@ int main(int argc, char *argv[])
expand = NULL;
}
+ if ( reindex_str != NULL ) {
+ reindex = parse_symmetry_operations(reindex_str);
+ if ( reindex == NULL ) return 1;
+ set_symmetry_name(reindex, "Reindex");
+ }
+
if ( (expand != NULL) || (holo != NULL) || config_trimc
|| config_multi ) {
if ( mero == NULL ) {
@@ -778,6 +794,32 @@ int main(int argc, char *argv[])
}
+ if ( reindex != NULL ) {
+
+ RefList *n;
+ Reflection *refl;
+ RefListIterator *iter;
+
+ n = reflist_new();
+
+ for ( refl = first_refl(input, &iter);
+ refl != NULL;
+ refl = next_refl(refl, iter) )
+ {
+ signed int h, k, l;
+ Reflection *rn;
+
+ get_indices(refl, &h, &k, &l);
+ get_equiv(reindex, NULL, 0, h, k, l, &h, &k, &l);
+ rn = add_refl(n, h, k, l);
+ copy_data(rn, refl);
+
+ }
+
+ reflist_free(input);
+ input = n;
+
+ }
write_reflist(output, input);