diff options
author | Aaron LI <aly@aaronly.me> | 2018-06-13 22:28:11 +0800 |
---|---|---|
committer | Aaron LI <aly@aaronly.me> | 2018-06-13 22:28:11 +0800 |
commit | 49faa85463e322d076fe996686e6c06eb64ad6b1 (patch) | |
tree | f072319449dabfd1189d9cd66e37e835d779aabd | |
parent | 2455aff9436831768535c0ecb672aa377867185e (diff) | |
download | atoolbox-49faa85463e322d076fe996686e6c06eb64ad6b1.tar.bz2 |
astro/fitscube.py: Add "crop" sub-command
-rwxr-xr-x | astro/fits/fitscube.py | 36 |
1 files changed, 35 insertions, 1 deletions
diff --git a/astro/fits/fitscube.py b/astro/fits/fitscube.py index bb6a16b..af3400d 100755 --- a/astro/fits/fitscube.py +++ b/astro/fits/fitscube.py @@ -1,6 +1,6 @@ #!/usr/bin/env python3 # -# Copyright (c) Weitian LI <weitian@aaronly.me> +# Copyright (c) 2017-2018 Weitian LI <wt@liwt.net> # MIT license # @@ -292,6 +292,26 @@ def cmd_create(args): print("Created FITS cube: %s" % args.outfile) +def cmd_crop(args): + """ + Sub-command: "crop", crop the central region of a FITS cube + """ + if not args.clobber and os.path.exists(args.outfile): + raise FileExistsError("output file already exists: %s" % args.outfile) + + cube = FITSCube(args.infile) + print("Image/slice size: %dx%d" % (cube.width, cube.height)) + print("Cropping region size: %dx%d" % (args.size, args.size)) + s_width = slice((cube.width - args.size) // 2, + (cube.width + args.size) // 2) + s_height = slice((cube.height - args.size) // 2, + (cube.height + args.size) // 2) + cube.data = cube.data[:, s_height, s_width] + print("Saving FITS cube ...") + cube.write(args.outfile, clobber=args.clobber) + print("Created FITS cube: %s" % args.outfile) + + def cmd_calibrate(args): """ Sub-command: "calibrate", calibrate the z-axis slice/channel responses @@ -459,6 +479,20 @@ def main(): help="input image slices (in order)") parser_create.set_defaults(func=cmd_create) + # sub-command: "crop" + parser_crop = subparsers.add_parser( + "crop", + help="crop the central spatial region of the FITS cube") + parser_crop.add_argument("-C", "--clobber", action="store_true", + help="overwrite existing output file") + parser_crop.add_argument("-n", "--size", type=int, required=True, + help="crop region size (number of pixels)") + parser_crop.add_argument("-o", "--outfile", required=True, + help="output FITS cube filename") + parser_crop.add_argument("-i", "--infile", required=True, + help="input FITS cube") + parser_crop.set_defaults(func=cmd_crop) + # sub-command: "calibrate" parser_cal = subparsers.add_parser( "calibrate", |