-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcalreduce.py
80 lines (66 loc) · 2.31 KB
/
calreduce.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
import sys
from tasks import *
from taskinit import *
import casac
import pylab as pl
import os
from optparse import OptionParser
usage = "usage: %prog options"
parser = OptionParser(usage=usage);
parser.add_option('--vis', type='string', dest = 'vis', default=None,
help = 'Input MS [None]');
parser.add_option('--cal', type='string', dest='cal', default=None,
help = 'Calibrator [None]');
parser.add_option('--cal2', type='string', dest='cal2', default=None,
help = 'Second Calibrator to Solve for [None]')
parser.add_option('--gaspw', type='string', dest='gaspw', default=None,
help = 'SPW over which to solve for gain solutions [ALL]');
parser.add_option('--tag', type='string', dest='tag', default=None,
help = 'Optional prefix tag for table naming [None]')
parser.add_option('--refant', type='string', dest='refant', default='ant5',
help = 'Reference antenna for calibration [ant5]')
parser.add_option("--gasolint", type='string', dest='gasolint', default='inf',
help = 'Solution interval to be used when doing gaincal [\'inf\']')
(options, args) = parser.parse_args();
if len(sys.argv)==1:
parser.print_help();
dummy = sys.exit(0);
if options.tag!=None:
prefix = options.tag;
else:
prefix = options.vis;
btable = prefix+'.cr.btable';
gtable = prefix+'.cr.gtable';
ftable = prefix+'.cr.ftable';
print '\n'
print '-------------'
print 'Running SETJY'
print '-------------'
print '\n'
if options.cal=='1018-317':
setjy(vis = options.vis, field = options.cal, fluxdensity=[3.17,0.,0.,0.]);
else:
setjy(vis = options.vis, field = options.cal);
print '\n'
print '----------------'
print 'Running BANDPASS'
print '----------------'
print '\n'
bandpass(vis = options.vis, caltable = btable, interp = '',
field = options.cal, solint = 'inf', combine = 'scan',
refant = options.refant, minsnr=3.0, spw=options.gaspw);
print '\n'
print '-------------'
print 'Running GAINCAL'
print '-------------'
print '\n'
if options.cal2!=None:
fields = options.cal+','+options.cal2;
else:
fields = options.cal;
gaincal(vis = options.vis, caltable=gtable, field=fields,
interp='nearest', spw=options.gaspw, solint=options.gasolint,
refant = options.refant, gaintable = btable, minsnr=3.0);
if options.cal2!=None:
fluxscale(vis = options.vis, fluxtable = ftable, caltable = gtable,
reference = options.cal, transfer = options.cal2);