-
Notifications
You must be signed in to change notification settings - Fork 3
/
modweights_freq.py
executable file
·66 lines (45 loc) · 1.94 KB
/
modweights_freq.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
#!/usr/bin/python
# TO DO, need to fix input datasets with more than 1 freq. channels per MS
import numpy
import pyrap.tables as pt
import sys
import scipy.signal
msname = str(sys.argv[1])
ionnormfactor = numpy.float(sys.argv[2])
ionscalefactor = numpy.float(sys.argv[3])
nblockconcat = numpy.int(sys.argv[4])
colname = str(sys.argv[5])
chanperblock = numpy.int(sys.argv[6])
t = pt.table(msname, readonly=False)
freq_tab = pt.table(msname + '/SPECTRAL_WINDOW')
freq = freq_tab.getcol('REF_FREQUENCY')
chanfreq = freq_tab.getcol('CHAN_FREQ')[0]
wav = 3e8/freq
anttab = pt.table(msname + '/ANTENNA')
antlist = anttab.getcol('NAME')
centerfreq = numpy.mean(chanfreq)
freq_res = numpy.abs(chanfreq[0]-chanfreq[1])
for t2 in t.iter(["ANTENNA1","ANTENNA2"]):
if (t2.getcell('ANTENNA1',0)) < (t2.getcell('ANTENNA2',0)):
#print antlist[t2.getcell('ANTENNA1',0)],antlist[t2.getcell('ANTENNA2',0)]
weightscol = t2.getcol(colname)
uvw = t2.getcol('UVW')
uvw_dist = numpy.sqrt(uvw[:,0]**2 + uvw[:,1]**2 + uvw[:,2]**2)
weightscol_modified = numpy.copy(weightscol)
#timepersample = t2[1]['TIME']-t2[0]['TIME']
dist = numpy.mean(uvw_dist)/1e3
stddev = ionnormfactor*((1./dist)**ionscalefactor)*(centerfreq/150e6)
#print 'STEDDV', stddev
fwhm = 2.3548*stddev/freq_res
gauss = scipy.signal.gaussian(len(weightscol[0,:,0]),(stddev))
# special case, set weightes of central block always to 1.0
if ((nblockconcat*2)+1) != len(chanfreq):
for chan_number in range(0,chanperblock):
gauss[chanperblock*nblockconcat + chan_number] = 1.0
#sys.exit()
for chan in range(0,len(weightscol[0,:,0])):
weightscol_modified[:,chan,:] = weightscol[:,chan,:]*gauss[chan]
#print numpy.mean(weightscol[:,chan,:]),numpy.mean(weightscol_modified[:,chan,:])
t2.putcol(colname, weightscol_modified)
t.close()
freq_tab.close()