aboutsummaryrefslogtreecommitdiffstats
path: root/astro
diff options
context:
space:
mode:
authorAaron LI <aly@aaronly.me>2017-11-03 10:34:33 +0800
committerAaron LI <aly@aaronly.me>2017-11-03 10:34:33 +0800
commit075c628a8c3c429b246744996781e5e58218a76c (patch)
treeb5dc0d5318dc50be9026cc5306a891c96f854746 /astro
parent498e32c7c579970341c6dad9317ae79e2ef2c53f (diff)
downloadatoolbox-075c628a8c3c429b246744996781e5e58218a76c.tar.bz2
astro/calc_psd.py: Support image pixel size
Diffstat (limited to 'astro')
-rwxr-xr-xastro/calc_psd.py18
1 files changed, 17 insertions, 1 deletions
diff --git a/astro/calc_psd.py b/astro/calc_psd.py
index 018c52a..a18e755 100755
--- a/astro/calc_psd.py
+++ b/astro/calc_psd.py
@@ -249,6 +249,9 @@ def main():
"at every frequency point will be calculated, " +
"i.e., using a even grid, which may be very slow " +
"for very large images!")
+ parser.add_argument("-p", "--pixelsize", dest="pixelsize", type=float,
+ help="image spatial pixel size [arcsec] " +
+ "(will try to obtain from FITS header)")
parser.add_argument("-P", "--plot", dest="plot", action="store_true",
help="plot the PSD and save as a PNG image")
parser.add_argument("-i", "--infile", dest="infile", nargs="+",
@@ -271,8 +274,21 @@ def main():
header, image = open_image(args.infile[0])
bunit = header.get("BUNIT", "???")
print("Read image from: %s" % args.infile[0])
+ print("Image size: %dx%d" % tuple(reversed(image.shape)))
print("Data unit: %s" % bunit)
+ if args.pixelsize:
+ pixel = (args.pixelsize/60, "arcmin") # [arcsec]->[arcmin]
+ else:
+ try:
+ pixel = (header["PixSize"]/60, "arcmin") # [arcsec]->[arcmin]
+ except KeyError:
+ try:
+ pixel = (abs(header["CDELT1"])*60, "arcmin") # [deg]->[arcmin]
+ except KeyError:
+ pixel = (1.0, "pixel")
+ print("Image pixel size: %.2f [%s]" % pixel)
+
for fn in args.infile[1:]:
print("Adding additional image: %s" % fn)
header2, image2 = open_image(fn)
@@ -282,7 +298,7 @@ def main():
else:
raise ValueError("image has different unit: %s" % bunit2)
- psdobj = PSD(image=image, step=args.step)
+ psdobj = PSD(image=image, pixel=pixel, step=args.step)
freqs, psd, psd_err = psdobj.calc_psd()
# Write out PSD results