diff options
author | Thomas White <taw@physics.org> | 2014-10-13 17:37:26 +0200 |
---|---|---|
committer | Thomas White <taw@physics.org> | 2014-10-13 17:38:21 +0200 |
commit | ab566d34cfa925eaf0c4ea4bbba5c088b276b119 (patch) | |
tree | 3de6dca077f2da3383f6ac9c5b2f2da0b996b55d | |
parent | ac1855498fdd44fda339011acfd248d116f37142 (diff) |
render_hkl: Add --highres
-rw-r--r-- | doc/man/render_hkl.1 | 5 | ||||
-rw-r--r-- | src/render_hkl.c | 14 |
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); |