File: beamGen.py

package info (click to toggle)
cassbeam 1.1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 920 kB
  • sloc: ansic: 8,483; python: 231; sh: 171; makefile: 48
file content (99 lines) | stat: -rwxr-xr-x 3,693 bytes parent folder | download | duplicates (4)
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
#!/usr/bin/env python

"""
Batch script to generate a multi-frequency FITS beam from a template cassBeam input file
"""

import sys,os
from subprocess import call
import numpy as n
import pyrap.tables as pt

#HARDCODE cassbeam and cass2fits.py locations
cbBin='/usr/local/bin/cassbeam'
c2fScript='/home/foster/VLA/cassbeam/scripts/cass2fits.py'


if __name__ == '__main__':
    from optparse import OptionParser
    o = OptionParser()
    o.set_usage('%prog [options] -t <CASSBEAM INPUT TEMPLATE>')
    o.set_description(__doc__)
    o.add_option('-c','--clobber',dest='clobber',action='store_true',
        help='Clobber/overwrite output FITS files if they exist')
    o.add_option('-f','--freq',dest='freq',default='1000,1200,50',
        help='Frequnecy range to generate beams at, can set to an MS and freqs \
        are pulled from the table or an a start,stop,step notaion (MHz). default: 1000,1200,50')
    o.add_option('-o','--output',dest='output',default='cassBeam',
        help='Output FITS filename prefix')
    o.add_option('-p','--pixels',dest='pixels',default=128, type='int',
        help='Number of pixels in the output FITS file, default: 128')
    o.add_option('-t','--template',dest='template',default=None,
        help='cassBeam input file to be used as the template, REQUIRED')
    o.add_option('--pixelsperbeam',dest='ppb',default=32, type='int',
        help='Pixels across the primary lobe for the lowest frequency, default: 32')
    opts, args = o.parse_args(sys.argv[1:])

    #Sort out the frequencies, either they are input or from an MS
    if os.path.exists(opts.freq):
        print 'Getteing frequencies from %s'%opts.freq
        ms=pt.table(opts.freq+'/SPECTRAL_WINDOW',readonly=True)
        freqs=ms.getcol('CHAN_FREQ')[0]
    else:
        startFreq,stopFreq,stepFreq=map(float,opts.freq.split(','))
        nfreqs=int((stopFreq-startFreq)/stepFreq)+1
        freqs=[]
        for f in range(nfreqs): freqs.append(startFreq+f*stepFreq)
        freqs=n.array(freqs)*1e6
    #convert freqs to GHz
    freqs/=1.e9

    gridsize=2*(opts.pixels)

    ppb=opts.ppb*freqs[0]/freqs
    ppb=ppb.astype(int)

    #read template file
    fh=open(opts.template)
    templateLines=fh.readlines()
    fh.close()

    inputFiles=[]
    print 'Generating cassBeam input files'
    for f,pix in zip(freqs,ppb):
        outStr=opts.output+'-'+str(f*1.e3)+'MHz'
        outLines=[]
        for l in templateLines:
            if l.startswith('freq'): outLines.append('freq=%f\n'%f)
            elif l.startswith('gridsize'): outLines.append('gridsize=%i\n'%gridsize)
            elif l.startswith('out'): outLines.append('out=%s\n'%outStr)
            elif l.startswith('pixelsperbeam'): outLines.append('pixelsperbeam=%i\n'%pix)
            else: outLines.append(l)
        cassBeamFile=outStr
        inputFiles.append(cassBeamFile)
        fh=open(cassBeamFile+'.in','w')
        fh.writelines(outLines)
        fh.close()

    #run cassbeam
    for fid,fn in enumerate(inputFiles):
        print 'Running cassbeam with %s.in (%i of %i)'%(fn,fid+1,len(inputFiles))
        print [cbBin,fn+'.in']
        rcode=call([cbBin,fn+'.in'])

    #get the beampixelscale from the lowest frequency output param file
    fh=open(opts.output+'-'+str(freqs[0]*1.e3)+'MHz.params')
    paramLines=fh.readlines()
    for l in paramLines:
        if l.startswith('beampixelscale'): bps=float(l.split('=')[-1])
    fh.close()

    #run cass2fits.py
    print 'Running %s'%c2fScript
    c2fArgs=' '
    if opts.clobber: c2fArgs+='-c '
    c2fArgs+='-p %f '%bps
    c2fArgs+='-o '+opts.output+'_ '
    for fn in inputFiles: c2fArgs+=fn+'.jones.dat '
    os.system(c2fScript+' '+c2fArgs)