From b372f84351579326ba71c95c309a90e7c6f47ce5 Mon Sep 17 00:00:00 2001 From: Aaron LI Date: Fri, 16 Nov 2018 00:29:11 +0800 Subject: astro/fitsimage.py: Add "shift" sub-command --- astro/fitsimage.py | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) (limited to 'astro') diff --git a/astro/fitsimage.py b/astro/fitsimage.py index af49f7e..620373b 100755 --- a/astro/fitsimage.py +++ b/astro/fitsimage.py @@ -170,6 +170,17 @@ class FITSImage: raise ValueError("invalid rotate to: %s" % to) return self.image + def shift(self, x, y=None): + y = y or x + ny, nx = self.image.shape + image = np.zeros((ny, nx)) + image[y:, x:] = self.image[:ny-y, :nx-x] + image[:y, :x] = self.image[ny-y:, nx-x:] + image[:y, x:] = self.image[ny-y:, :nx-x] + image[y:, :x] = self.image[:ny-y, nx-x:] + self.image = image + return self.image + def write(self, outfile, clobber=False): self.header.add_history(" ".join(sys.argv)) hdu = fits.PrimaryHDU(data=self.data, header=self.header) @@ -364,6 +375,17 @@ def cmd_rotate(args): print("Saved rotated FITS image to: %s" % args.outfile) +def cmd_shift(args): + """ + Sub-command: "shift", shift the image and padding accordingly. + """ + fimage = FITSImage(args.infile) + print("Shift image by (%d,%d) ..." % (args.x, args.y or args.x)) + fimage.shift(x=args.x, y=args.y) + fimage.write(args.outfile, clobber=args.clobber) + print("Saved shifted FITS image to: %s" % args.outfile) + + def main(): parser = argparse.ArgumentParser( description="FITS image manipulation tool") @@ -514,6 +536,22 @@ def main(): help="rotate 180 degree") parser_rot.set_defaults(func=cmd_rotate) + # sub-command: "shift" + parser_sft = subparsers.add_parser( + "sft", aliases=["shift"], + help="shift the image and pad accordingly") + parser_sft.add_argument("-C", "--clobber", action="store_true", + help="overwrite existing output file") + parser_sft.add_argument("-i", "--infile", required=True, + help="input FITS image") + parser_sft.add_argument("-o", "--outfile", required=True, + help="output shifted and padded FITS image") + parser_sft.add_argument("-x", type=int, required=True, + help="numer of horizontal pixels") + parser_sft.add_argument("-y", type=int, + help="numer of vertical pixels") + parser_sft.set_defaults(func=cmd_shift) + args = parser.parse_args() args.func(args) -- cgit v1.2.2