aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas White <taw@physics.org>2014-10-13 17:37:26 +0200
committerThomas White <taw@physics.org>2014-10-13 17:38:21 +0200
commitab566d34cfa925eaf0c4ea4bbba5c088b276b119 (patch)
tree3de6dca077f2da3383f6ac9c5b2f2da0b996b55d
parentac1855498fdd44fda339011acfd248d116f37142 (diff)
render_hkl: Add --highres
-rw-r--r--doc/man/render_hkl.15
-rw-r--r--src/render_hkl.c14
2 files changed, 19 insertions, 0 deletions
diff --git a/doc/man/render_hkl.1 b/doc/man/render_hkl.1
index bd8b40c8..957b069e 100644
--- a/doc/man/render_hkl.1
+++ b/doc/man/render_hkl.1
@@ -101,6 +101,11 @@ Write the selected colour scale out to 'key.pdf' in the current directory.
.PD
Draw a resolution ring at \fIres\fR Angstroms. You can use this option multiple times to get more than one ring.
+.PD 0
+.IP \fB--highres=\fBres\fR
+.PD
+Render spots only up to \fIres\fR Angstroms.
+
.SH AUTHOR
This page was written by Thomas White.
diff --git a/src/render_hkl.c b/src/render_hkl.c
index 1b13be66..8804ba91 100644
--- a/src/render_hkl.c
+++ b/src/render_hkl.c
@@ -91,6 +91,7 @@ static void show_help(const char *s)
" reflection (no 'epsilon' correction).\n"
"\n"
" --res-ring=<r> Draw a resolution ring at <r> Angstroms.\n"
+" --highres=<r> Render spots only up to <r> Angstroms.\n"
"\n"
" --colour-key Draw (only) the key for the current colour scale.\n"
" The key will be written to 'key.pdf' in the\n"
@@ -760,6 +761,7 @@ int main(int argc, char *argv[])
long int zone = 0;
double res;
struct resrings rings;
+ float highres = -1.0;
rings.n_rings = 0;
@@ -781,6 +783,7 @@ int main(int argc, char *argv[])
{"scale-top", 1, NULL, 2},
{"zone", 1, NULL, 3},
{"res-ring", 1, NULL, 4},
+ {"highres", 1, NULL, 6},
{0, 0, NULL, 0}
};
@@ -869,6 +872,13 @@ int main(int argc, char *argv[])
add_ring(&rings, res);
break;
+ case 6 :
+ if ( sscanf(optarg, "%e", &highres) != 1 ) {
+ ERROR("Invalid value for --highres\n");
+ return 1;
+ }
+ break;
+
case 0 :
break;
@@ -990,6 +1000,10 @@ int main(int argc, char *argv[])
return 1;
}
+ if ( highres > 0.0 ) {
+ list = res_cutoff(list, cell, 0.0, 1.0/(highres*1e-10));
+ }
+
render_za(cell, list, boost, sym, wght, colscale,
rh, rk, rl, dh, dk, dl, outfile, scale_top, zone, &rings);