From eca592e6ab2d7ddb51a46e326cae3b8c0dcf55a0 Mon Sep 17 00:00:00 2001 From: Aaron LI Date: Mon, 22 May 2017 21:18:35 +0800 Subject: Add utils/wcs.py with function "make_wcs()" --- fg21sim/utils/wcs.py | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 fg21sim/utils/wcs.py (limited to 'fg21sim') diff --git a/fg21sim/utils/wcs.py b/fg21sim/utils/wcs.py new file mode 100644 index 0000000..b4a9ed1 --- /dev/null +++ b/fg21sim/utils/wcs.py @@ -0,0 +1,54 @@ +# Copyright (c) 2017 Weitian LI +# MIT license + +""" +Create WCS for sky projection. +""" + +import numpy as np +from astropy.wcs import WCS + + +def make_wcs(center, size, pixelsize, frame="ICRS", projection="TAN"): + """ + Make WCS for sky projection usages, etc. + + Parameters + ---------- + center : (xcenter, ycenter) float tuple + The equatorial/galactic coordinate of the sky/image center [ deg ]. + size : (xsize, ysize) int tuple + The size (width, height) of the sky/image. + pixelsize : float + The pixel size of the sky/image [ arcmin ] + frame : str, "ICRS" or "Galactic" + The coordinate frame, only one of ``ICRS`` or ``Galactic``. + projection : str, "TAN" or "CAR" + The projection algorithm used by the sky/image, currently only + support ``TAN`` (tangential), ``CAR`` (Cartesian). + + Returns + ------- + w : `~astropy.wcs.WCS` + Created WCS header/object + """ + xcenter, ycenter = center # [ deg ] + xsize, ysize = size + delt = pixelsize / 60.0 # [ deg ] + if projection.upper() not in ["TAN", "CAR"]: + raise ValueError("unsupported projection: " % projection) + if frame.upper() == "ICRS": + ctype = ["RA---" + projection.upper(), "DEC--" + projection.upper()] + elif frame.upper() == "GALACTIC": + ctype = ["GLON-" + projection.upper(), "GLAT-" + projection.upper()] + else: + raise ValueError("unknown frame: " % frame) + + w = WCS(naxis=2) + w.wcs.ctype = ctype + w.wcs.crval = np.array([xcenter, ycenter]) + w.wcs.crpix = np.array([xsize/2.0-0.5, ysize/2.0-0.5]) + w.wcs.cdelt = np.array([-delt, delt]) + w.wcs.cunit = ["deg", "deg"] + w.wcs.equinox = 2000.0 + return w -- cgit v1.2.2