source: trunk/python/asapmath.py@ 175

Last change on this file since 175 was 174, checked in by kil064, 20 years ago

add cursor selection to function 'hanning'

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 5.6 KB
RevLine 
[101]1from scantable import scantable
2
[143]3def average_time(*args, **kwargs):
[101]4 """
[113]5 Return the (time) average of a scan or list of scans. [in channels only]
6 Parameters:
7 one scan or comma separated scans
[143]8 mask: an optional mask (only used for 'var' and 'tsys' weighting)
9 scanav: False (default) averages all scans together,
10 True averages each scan separately
11 weight: Weighting scheme. 'none' (default), 'var' (variance
12 weighted), 'tsys'
[113]13 Example:
14 # return a time averaged scan from scana and scanb
15 # without using a mask
[129]16 scanav = average_time(scana,scanb)
[113]17 # return the (time) averaged scan, i.e. the average of
18 # all correlator cycles
19 scanav = average_time(scan)
[143]20
[101]21 """
[143]22 scanAv = False
23 if kwargs.has_key('scanav'):
24 scanAv = kwargs.get('scanav')
25#
26 weight = 'none'
27 if kwargs.has_key('weight'):
28 weight = kwargs.get('weight')
29#
30 mask = ()
31 if kwargs.has_key('mask'):
32 mask = kwargs.get('mask')
33#
34 lst = tuple(args)
35 from asap._asap import average as _av
[113]36 for s in lst:
[101]37 if not isinstance(s,scantable):
38 print "Please give a list of scantables"
39 return
[143]40 return scantable(_av(lst, mask, scanAv, weight))
[101]41
42def quotient(source, reference):
43 """
44 Return the quotient of a 'source' scan and a 'reference' scan
45 Parameters:
46 source: the 'on' scan
47 reference: the 'off' scan
48 """
49 from asap._asap import quotient as _quot
50 return scantable(_quot(source, reference))
51
[150]52def scale(scan, factor, insitu=False, all=True):
[101]53 """
54 Return a scan where all spectra are scaled by the give 'factor'
55 Parameters:
56 scan: a scantable
[113]57 factor: the scaling factor
[150]58 insitu: if False (default) a new scantable is returned.
59 Otherwise, the scaling is done in-situ
60 all: if True (default) apply to all spectra. Otherwise
61 apply only to the selected (beam/pol/if)spectra only
[101]62 """
[141]63 if not insitu:
64 from asap._asap import scale as _scale
[150]65 return scantable(_scale(scan, factor, all))
[141]66 else:
67 from asap._asap import scale_insitu as _scale
[150]68 _scale(scan, factor, all)
[141]69 return
70
[101]71
[150]72def add(scan, offset, insitu=False, all=True):
[113]73 """
[150]74 Return a scan where all spectra have the offset added
[113]75 Parameters:
76 scan: a scantable
[150]77 offset: the offset
78 insitu: if False (default) a new scantable is returned.
79 Otherwise, the addition is done in-situ
80 all: if True (default) apply to all spectra. Otherwise
81 apply only to the selected (beam/pol/if)spectra only
[113]82 """
[150]83 if not insitu:
84 from asap._asap import add as _add
85 return scantable(_add(scan, offset, all))
86 else:
87 from asap._asap import add_insitu as _add
88 _add(scan, offset, all)
89 return
90
[167]91def bin(scan, width=5, insitu=False):
[101]92 """
[167]93 Return a scan where all spectra have been binned up
[172]94 width: The bin width (default=5) in pixels
[167]95 insitu: if False (default) a new scantable is returned.
96 Otherwise, the addition is done in-situ
[101]97 """
[167]98 if not insitu:
99 from asap._asap import bin as _bin
100 return scantable(_bin(scan, width))
101 else:
102 from asap._asap import bin_insitu as _bin
103 _bin(scan, width)
104 return
[113]105
[166]106def average_pol(scan, mask=None, insitu=False):
[113]107 """
108 Average the Polarisations together.
109 Parameters:
[172]110 scan: The scantable
111 mask: An optional mask defining the region, where the
112 averaging will be applied. The output will have all
113 specified points masked.
114 insitu: If False (default) a new scantable is returned.
[166]115 Otherwise, the averaging is done in-situ
[113]116 Example:
117 polav = average_pols(myscan)
118 """
119 if mask is None:
[166]120 mask = ()
121 if not insitu:
122 from asap._asap import averagepol as _avpol
123 return scantable(_avpol(scan, mask))
124 else:
125 from asap._asap import averagepol_insitu as _avpol
126 _avpol(scan, mask)
127 return
[113]128
[174]129def hanning(scan, insitu=False, all=True):
[113]130 """
131 Hanning smooth the channels.
132 Parameters:
[172]133 scan: The input scan
134 insitu: If False (default) a new scantable is returned.
135 Otherwise, the scaling is done in-situ
[174]136 all: if True (default) apply to all spectra. Otherwise
137 apply only to the selected (beam/pol/if)spectra only
[113]138 Example:
139 none
140 """
[172]141 if not insitu:
142 from asap._asap import hanning as _hann
[174]143 return scantable(_hann(scan,all))
[172]144 else:
145 from asap._asap import hanning_insitu as _hann
[174]146 _hann(scan,all)
[172]147 return
[113]148
149def poly_baseline(scan, mask=None, order=0):
150 """
[160]151 Return a scan which has been baselined (all rows) by a polynomial.
[113]152 Parameters:
153 scan: a scantable
154 mask: an optional mask
155 order: the order of the polynomial (default is 0)
156 Example:
157 # return a scan baselined by a third order polynomial,
158 # not using a mask
159 bscan = poly_baseline(scan, order=3)
160 """
161 from asap.asapfitter import fitter
162 if mask is None:
163 from numarray import ones
164 mask = tuple(ones(scan.nchan()))
165 f = fitter()
166 f._verbose(True)
167 f.set_scan(scan, mask)
168 f.set_function(poly=order)
169 sf = f.auto_fit()
170 return sf
Note: See TracBrowser for help on using the repository browser.