-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathskyview_func.py
82 lines (75 loc) · 2.92 KB
/
skyview_func.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
import warnings
warnings.filterwarnings('ignore')
import sys
import os
from astroquery.skyview import SkyView
from astropy.coordinates import SkyCoord
import astropy.units as u
import aplpy
import matplotlib.pyplot as plt
from astropy.io import fits
import astropy
def coords_from_name(field_name):
"""Get ra, dec coordinates from a field name using astropy
Args:
field_name (str): Field name, e.g. 'M101'
Returns:
(float, float): ra, dec in degrees
Example:
>>> coords_from_name('M101')
(210.80242917, 54.34875)
"""
coords = SkyCoord.from_name(field_name)
print(f"Source coordinates for {field_name}: {coords.ra} {coords.dec}")
return coords
def plot_fits(fits_name, plot_title=None, cmap_name='viridis', colorbar=True, contour=True):
"""Make a PNG plot out of a FITS file
Args:
fits_name (str): path of fits file
plot_title (str): plot title, default is name of the fits file
cmap_name (str): name of colormap, default is viridis
colorbar (bool): include colorbar, default is True
contour (bool): include contour, default is True
"""
f = aplpy.FITSFigure(fits_name, figsize=(10, 8))
if plot_title == None:
plot_title = fits_name.replace('.fits', '')
plt.title(plot_title)
f.show_colorscale(cmap=cmap_name, stretch='linear')
f.ticks.set_color('k')
if colorbar:
f.add_colorbar()
if 'BMAJ' in fits.open(fits_name)[0].header:
f.add_beam()
print(f'Adding beam for {fits_name}')
if contour:
f.show_contour()
output_name = fits_name.replace('.fits', '.png')
plt.savefig(output_name, dpi=200, bbox_inches='tight')
def call_skyview(source_name, survey, fov=1):
"""Call Skyview to download data from a survey based on input parameters
Args:
source_name (str): name of astronomical source
survey (str): name of survey, from https://skyview.gsfc.nasa.gov/current/cgi/survey.pl
fov (float): FOV in degrees
Examples:
>>> call_skyview('M31', 'DSS', 2.)
>>> call_skyview('NGC6680', 'NVSS', 0.5)
"""
coords = coords_from_name(source_name)
print(f"Looking for survey {survey} for source {source_name}")
images = SkyView.get_images(coords, survey,
coordinates='J2000',
projection='Car', pixels=500,
height=fov*u.deg, width=fov*u.deg)
fitsname = f'{source_name}_{survey}_{fov}d.fits'
try:
images[0][0].writeto(fitsname, overwrite=True)
except astropy.io.fits.verify.VerifyError:
print('Data not available')
pass
plot_fits(fitsname, plot_title=None, cmap_name='viridis', colorbar=True)
print(f"Fits file: {fitsname}")
print(f"png file: {fitsname.replace('.fits', '.png')}")
if __name__ == '__main__':
call_skyview(source_name=sys.argv[1], survey=sys.argv[2], fov=float(sys.argv[3]))