diff options
author | Thomas White <taw@physics.org> | 2010-10-06 18:15:54 +0200 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2012-02-22 15:27:01 +0100 |
commit | 3aa5c234a3c5f360c3e43c5e21d467819e74a050 (patch) | |
tree | b91f161ac812ba673a86f70c0684b1fd8d7add9a /src | |
parent | 65de3133245e38ea9244590af43d1a99f948ff8d (diff) |
get_hkl: Add --expand option
Diffstat (limited to 'src')
-rw-r--r-- | src/get_hkl.c | 78 |
1 files changed, 76 insertions, 2 deletions
diff --git a/src/get_hkl.c b/src/get_hkl.c index f59853b6..f1b4f9f3 100644 --- a/src/get_hkl.c +++ b/src/get_hkl.c @@ -177,6 +177,60 @@ static ReflItemList *twin_reflections(double *ref, ReflItemList *items, } +static ReflItemList *expand_reflections(double *ref, ReflItemList *items, + const char *target, const char *initial) +{ + int i; + ReflItemList *new; + + new = new_items(); + + for ( i=0; i<num_items(items); i++ ) { + + struct refl_item *it; + signed int h, k, l; + signed int hd, kd, ld; + int n, j; + double intensity; + + it = get_item(items, i); + h = it->h; k = it->k; l = it->l; + + /* Actually we don't really care what the equivalent is, + * we just want to be sure that there is nly be one version of + * this reflection. */ + find_unique_equiv(items, h, k, l, initial, &hd, &kd, &ld); + + /* Now find out how many reflections need to be filled in */ + n = num_equivs(h, k, l, initial); + intensity = lookup_intensity(ref, h, k, l); + + for ( j=0; j<n; j++ ) { + + signed int he, ke, le; + + /* Get the equivalent */ + get_equiv(h, k, l, &he, &ke, &le, initial, j); + + /* Put it into the asymmetric unit for the target */ + get_asymm(he, ke, le, &he, &ke, &le, target); + + /* Make sure the intensity is in the right place */ + set_intensity(ref, he, ke, le, intensity); + + /* Add the reflection, but only once */ + if ( !find_item(new, he, ke, le) ) { + add_item(new, he, ke, le); + } + + } + + } + + return new; +} + + int main(int argc, char *argv[]) { int c; @@ -190,6 +244,7 @@ int main(int argc, char *argv[]) int config_multi = 0; char *holo = NULL; char *mero = NULL; + char *expand = NULL; char *output = NULL; char *input = NULL; char *filename = NULL; @@ -204,8 +259,9 @@ int main(int argc, char *argv[]) {"poisson", 0, &config_poisson, 1}, {"noise", 0, &config_noise, 1}, {"output", 1, NULL, 'o'}, - {"twin", 1, NULL, 'w'}, {"symmetry", 1, NULL, 'y'}, + {"twin", 1, NULL, 'w'}, + {"expand", 1, NULL, 'e'}, {"intensities", 1, NULL, 'i'}, {"pdb", 1, NULL, 'p'}, {"no-phases", 0, &config_nophase, 1}, @@ -214,7 +270,7 @@ int main(int argc, char *argv[]) }; /* Short options */ - while ((c = getopt_long(argc, argv, "ht:o:i:p:w:y:", + while ((c = getopt_long(argc, argv, "ht:o:i:p:w:y:e:", longopts, NULL)) != -1) { switch (c) { @@ -246,6 +302,10 @@ int main(int argc, char *argv[]) holo = strdup(optarg); break; + case 'e' : + expand = strdup(optarg); + break; + case 0 : break; @@ -259,6 +319,12 @@ int main(int argc, char *argv[]) filename = strdup("molecule.pdb"); } + if ( (holo != NULL) && (expand != NULL) ) { + ERROR("You cannot 'twin' and 'expand' at the same time.\n"); + ERROR("Decide which one you want to do first.\n"); + exit(1); + } + mol = load_molecule(filename); cell = load_cell_from_pdb(filename); if ( !config_nophase ) { @@ -288,6 +354,14 @@ int main(int argc, char *argv[]) input_items = new; } + if ( expand != NULL ) { + ReflItemList *new; + STATUS("Expanding from %s into %s\n", mero, expand); + new = expand_reflections(ideal_ref, input_items, expand, mero); + delete_items(input_items); + input_items = new; + } + if ( config_multi ) { int i; |