From 1b5c5d980742c358debb6cf2783362d847a90230 Mon Sep 17 00:00:00 2001 From: Thomas White Date: Tue, 9 Feb 2010 17:50:22 +0100 Subject: Add compare_hkl utility for working out Lorentz factors --- src/compare_hkl.c | 133 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 133 insertions(+) create mode 100644 src/compare_hkl.c (limited to 'src/compare_hkl.c') diff --git a/src/compare_hkl.c b/src/compare_hkl.c new file mode 100644 index 00000000..00b8bfc1 --- /dev/null +++ b/src/compare_hkl.c @@ -0,0 +1,133 @@ +/* + * compare_hkl.c + * + * Compare reflection lists + * + * (c) 2006-2010 Thomas White + * + * Part of CrystFEL - crystallography with a FEL + * + */ + + +#ifdef HAVE_CONFIG_H +#include +#endif + +#include +#include +#include +#include +#include +#include + +#include "utils.h" +#include "sfac.h" +#include "reflections.h" + + +static void show_help(const char *s) +{ + printf("Syntax: %s [options] \n\n", s); + printf( +"Compare intensity lists.\n" +"\n" +" -h, --help Display this help message.\n" +" -o, --output= Specify output filename for correction factor.\n" +"\n"); +} + + +int main(int argc, char *argv[]) +{ + int c; + double *ref1; + double *ref2; + double *out; + struct molecule *mol; + char *outfile = NULL; + char *afile = NULL; + char *bfile = NULL; + signed int h, k, l; + + /* Long options */ + const struct option longopts[] = { + {"help", 0, NULL, 'h'}, + {"output", 1, NULL, 'o'}, + {0, 0, NULL, 0} + }; + + /* Short options */ + while ((c = getopt_long(argc, argv, "ho:a:b:", longopts, NULL)) != -1) { + + switch (c) { + case 'h' : { + show_help(argv[0]); + return 0; + } + + case 'o' : { + outfile = strdup(optarg); + break; + } + + case 'a' : { + afile = strdup(optarg); + break; + } + + case 'b' : { + bfile = strdup(optarg); + break; + } + + case 0 : { + break; + } + + default : { + return 1; + } + } + + } + + if ( outfile == NULL ) { + ERROR("You must specify the output filename with -o\n"); + return 1; + } + + mol = load_molecule(); + ref1 = read_reflections(afile); + if ( ref1 == NULL ) { + ERROR("Couldn't open file '%s'\n", afile); + return 1; + } + ref2 = read_reflections(bfile); + if ( ref2 == NULL ) { + ERROR("Couldn't open file '%s'\n", bfile); + return 1; + } + out = new_list_intensity(); + + for ( h=-INDMAX; hcell); + + return 0; +} -- cgit v1.2.3