-
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathmmirs.py
143 lines (107 loc) · 4.34 KB
/
mmirs.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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
"""
mmirs
=====
A set of codes for MMIRS observing
"""
import sys, os
#from os.path import exists
#from astropy.io import ascii as asc
#from astropy.io import fits
import numpy as np
# import matplotlib.pyplot as plt
# import glob
#from astropy.table import Table
from astropy import log
import astropy.coordinates as coords
import astropy.units as u
from astropy.time import Time
def systime():
import time
return time.strftime("%d_%b_%Y_%H:%M:%S", time.localtime())
#enddef
def compute_mmirs_offsets(ra, dec, pm_ra, pm_dec, date='', epoch=0,
silent=False, verbose=True):
'''
This code computes offsets between two coordinates for a given epoch.
It factors in proper motion. The coordinate should be entered as:
(offset, target) for ra, dec, pm_ra, pm_dec, epoch
Parameters
----------
ra : list or array
J2000 RA in hours. Can either be a string or a decimal value
dec : list or array
J2000 Dec in degrees. Can either be a string or a decimal value
pm_ra : list or array
RA proper motion in units of mas/yr. The convention is:
pm_ra = mu_RA * cos(Dec)
pm_dec : list or array
Dec proper motion in units of mas/yr.
date : string
Date of observations in ISO format 'YYYY-MM-DD'
epoch : float
The epoch to compute offsets for. Optional. Will use
silent : boolean
Turns off stdout messages. Default: False
verbose : boolean
Turns on additional stdout messages. Default: True
Returns
-------
Offset values
Notes
-----
Created by Chun Ly, 10 April 2017
Modified by Chun Ly, 1 May 2017
- Output PA for with and without PM
- Adjust log.info call() to allow for silence
'''
if silent == False: log.info('### Begin compute_mmirs_offsets : '+systime())
if date != '':
epoch = Time(date).decimalyear
dtime = epoch - 2000.0
if verbose == True: print dtime
# J2000 coordinates
c0 = coords.SkyCoord(ra[0], dec[0], frame='icrs',
unit=(u.hr, u.deg)) # offset star
ct = coords.SkyCoord(ra[1], dec[1], frame='icrs',
unit=(u.hr, u.deg)) # target
if silent == False:
log.info('J2000 coord, offset star : '+ra[0]+' '+dec[0])
log.info('J2000 coord, target : '+ra[1]+' '+dec[1])
# offset star
pmRA = pm_ra[0] * dtime/np.cos(np.radians(c0.dec.value))
ra_off = coords.Angle(pmRA, unit=u.marcsec)
dec_off = coords.Angle(pm_dec[0] * dtime, unit=u.marcsec)
new_c0 = coords.SkyCoord(c0.ra + ra_off, c0.dec + dec_off, 'icrs')
# target
pmRA = pm_ra[1] * dtime/np.cos(np.radians(ct.dec.value))
ra_off = coords.Angle(pmRA, unit=u.marcsec)
dec_off = coords.Angle(pm_dec[1] * dtime, unit=u.marcsec)
new_ct = coords.SkyCoord(ct.ra + ra_off, ct.dec + dec_off, 'icrs')
new_c0_str = new_c0.to_string('hmsdms')
new_ct_str = new_ct.to_string('hmsdms')
if silent == False:
log.info('Epoch='+str(epoch)+' coord, offset star : '+new_c0_str)
log.info('Epoch='+str(epoch)+' coord, target : '+new_ct_str)
# For J2000
dra0 = (ct.ra.deg - c0.ra.deg) * 3600.0 # * np.cos(new_ct.dec.radian)
ddec0 = (ct.dec.deg - c0.dec.deg) * 3600.0
PA1 = c0.position_angle(ct).degree - 180.0 # + => East of North
if silent == False:
print ''
log.info('IF PROPER MOTION WAS NOT CONSIDERED!!!')
log.info('This offset in RA for alignboxmmirs : %.3f arcsec' % dra0)
log.info('This offset in Dec for alignboxmmirs : %.3f arcsec' % ddec0)
log.info('PA for longslit alignment : %.3f, %.3f, or %.3f' % (PA1, PA1-180,
PA1+180))
dra0 = (new_ct.ra.deg - new_c0.ra.deg) * 3600.0 # * np.cos(new_ct.dec.radian)
ddec0 = (new_ct.dec.deg - new_c0.dec.deg) * 3600.0
PA = new_c0.position_angle(new_ct).degree - 180.0 # + => East of North
if silent == False:
print ''; print ''
log.info('IF PROPER MOTION IS CONSIDERED!!!')
log.info('This offset in RA for alignboxmmirs : %.3f arcsec' % dra0)
log.info('This offset in Dec for alignboxmmirs : %.3f arcsec' % ddec0)
log.info('PA for longslit alignment : %.3f, %.3f, or %.3f' % (PA, PA-180, PA+180))
if silent == False: log.info('### End compute_mmirs_offsets : '+systime())
return PA1, PA
#enddef