source: branches/alma/external/atnf/PKSIO/PKSMS2reader.h@ 1398

Last change on this file since 1398 was 1393, checked in by TakTsutsumi, 17 years ago

Changes to handle GBT MS data

File size: 7.3 KB
Line 
1//#---------------------------------------------------------------------------
2//# PKSMS2reader.h: Class to read Parkes Multibeam data from a v2 MS.
3//#---------------------------------------------------------------------------
4//# Copyright (C) 2000-2006
5//# Associated Universities, Inc. Washington DC, USA.
6//#
7//# This library is free software; you can redistribute it and/or modify it
8//# under the terms of the GNU Library General Public License as published by
9//# the Free Software Foundation; either version 2 of the License, or (at your
10//# option) any later version.
11//#
12//# This library is distributed in the hope that it will be useful, but WITHOUT
13//# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
14//# FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
15//# License for more details.
16//#
17//# You should have received a copy of the GNU Library General Public License
18//# along with this library; if not, write to the Free Software Foundation,
19//# Inc., 675 Massachusetts Ave, Cambridge, MA 02139, USA.
20//#
21//# Correspondence concerning AIPS++ should be addressed as follows:
22//# Internet email: aips2-request@nrao.edu.
23//# Postal address: AIPS++ Project Office
24//# National Radio Astronomy Observatory
25//# 520 Edgemont Road
26//# Charlottesville, VA 22903-2475 USA
27//#
28//# $Id$
29//#---------------------------------------------------------------------------
30//# Original: 2000/08/03, Mark Calabretta, ATNF
31//#---------------------------------------------------------------------------
32
33#ifndef ATNF_PKSMS2READER_H
34#define ATNF_PKSMS2READER_H
35
36#include <atnf/PKSIO/PKSreader.h>
37
38#include <casa/aips.h>
39#include <casa/Arrays/Matrix.h>
40#include <casa/Arrays/Slicer.h>
41#include <casa/Arrays/Vector.h>
42#include <casa/BasicSL/Complex.h>
43#include <casa/BasicSL/String.h>
44#include <ms/MeasurementSets/MeasurementSet.h>
45#include <tables/Tables/ArrayColumn.h>
46#include <tables/Tables/ScalarColumn.h>
47
48// <summary>
49// Class to read Parkes Multibeam data from a v2 MS.
50// </summary>
51
52#include <casa/namespace.h>
53
54class PKSMS2reader : public PKSreader
55{
56 public:
57 // Default constructor.
58 PKSMS2reader();
59
60 // Destructor.
61 virtual ~PKSMS2reader();
62
63 // Open the MS for reading.
64 virtual Int open(
65 const String msName,
66 Vector<Bool> &beams,
67 Vector<Bool> &IFs,
68 Vector<uInt> &nChan,
69 Vector<uInt> &nPol,
70 Vector<Bool> &haveXPol,
71 Bool &haveBase,
72 Bool &haveSpectra);
73
74 // Get parameters describing the data.
75 virtual Int getHeader(
76 String &observer,
77 String &project,
78 String &antName,
79 Vector<Double> &antPosition,
80 String &obsMode,
81 Float &equinox,
82 String &freqRef,
83 Double &mjd,
84 Double &refFreq,
85 Double &bandwidth,
86 String &fluxunit);
87
88 // Get frequency parameters for each IF.
89 virtual Int getFreqInfo(
90 Vector<Double> &startFreq,
91 Vector<Double> &endFreq);
92
93 // Set data selection criteria. Channel numbering is 1-relative, zero or
94 // negative channel numbers are taken to be offsets from the last channel.
95 virtual uInt select(
96 const Vector<Bool> beamSel,
97 const Vector<Bool> IFsel,
98 const Vector<Int> startChan,
99 const Vector<Int> endChan,
100 const Vector<Int> refChan,
101 const Bool getSpectra = True,
102 const Bool getXPol = False,
103 const Bool getFeedPos = False);
104
105 // Find the range of the data selected in time and position.
106 virtual Int findRange(
107 Int &nRow,
108 Int &nSel,
109 Vector<Double> &timeSpan,
110 Matrix<Double> &positions);
111
112 // Read the next data record.
113 virtual Int read(
114 Int &scanNo,
115 Int &cycleNo,
116 Double &mjd,
117 Double &interval,
118 String &fieldName,
119 String &srcName,
120 Vector<Double> &srcDir,
121 Vector<Double> &srcPM,
122 Double &srcVel,
123 String &obsMode,
124 Int &IFno,
125 Double &refFreq,
126 Double &bandwidth,
127 Double &freqInc,
128 Double &restFreq,
129 Vector<Float> &tcal,
130 String &tcalTime,
131 Float &azimuth,
132 Float &elevation,
133 Float &parAngle,
134 Float &focusAxi,
135 Float &focusTan,
136 Float &focusRot,
137 Float &temperature,
138 Float &pressure,
139 Float &humidity,
140 Float &windSpeed,
141 Float &windAz,
142 Int &refBeam,
143 Int &beamNo,
144 Vector<Double> &direction,
145 Vector<Double> &scanRate,
146 Vector<Float> &tsys,
147 Vector<Float> &sigma,
148 Vector<Float> &calFctr,
149 Matrix<Float> &baseLin,
150 Matrix<Float> &baseSub,
151 Matrix<Float> &spectra,
152 Matrix<uChar> &flagged,
153 Complex &xCalFctr,
154 Vector<Complex> &xPol);
155
156 // Read the next data record, just the basics.
157 virtual Int read(
158 Int &IFno,
159 Vector<Float> &tsys,
160 Vector<Float> &calFctr,
161 Matrix<Float> &baseLin,
162 Matrix<Float> &baseSub,
163 Matrix<Float> &spectra,
164 Matrix<uChar> &flagged);
165
166 // Close the MS.
167 virtual void close(void);
168
169 private:
170 Bool cHaveBaseLin, cHaveCalFctr, cHaveSrcVel, cHaveTsys, cHaveXCalFctr,
171 cMSopen, cHaveTcal;
172 Int cCycleNo, cIdx, cNRow, cScanNo;
173 Double cTime, lastmjd;
174 Vector<Int> cEndChan, cRefChan, cStartChan;
175 Vector<Bool> cBeams, cIFs;
176 Vector<Slicer> cDataSel;
177 MeasurementSet cPKSMS;
178 Table cSysCalTab, tmptab, tmptab2;
179
180 ROScalarColumn<Int> cScanNoCol;
181 ROScalarColumn<Double> cTimeCol;
182 ROScalarColumn<Double> cIntervalCol;
183 ROScalarColumn<Int> cFieldIdCol;
184 ROScalarColumn<String> cFieldNameCol;
185 ROArrayColumn<Double> cFieldDelayDirCol;
186 ROScalarColumn<Int> cSrcIdCol;
187 ROScalarColumn<Int> cSrcId2Col;
188 ROScalarColumn<String> cSrcNameCol;
189 ROArrayColumn<Double> cSrcDirCol;
190 ROArrayColumn<Double> cSrcPMCol;
191 ROArrayColumn<Double> cSrcVelCol;
192 ROScalarColumn<Int> cStateIdCol;
193 ROScalarColumn<Double> cCalCol;
194 ROScalarColumn<String> cObsModeCol;
195 ROArrayColumn<Double> cSrcRestFrqCol;
196 ROScalarColumn<Int> cDataDescIdCol;
197 ROScalarColumn<Int> cSpWinIdCol;
198 ROArrayColumn<Double> cChanFreqCol;
199 ROScalarColumn<Double> cWeatherTimeCol;
200 ROScalarColumn<Float> cTemperatureCol;
201 ROScalarColumn<Float> cPressureCol;
202 ROScalarColumn<Float> cHumidityCol;
203 ROArrayColumn<Float> cTcalCol;
204 ROScalarColumn<Int> cBeamNoCol;
205 ROArrayColumn<Double> cPointingCol;
206 ROArrayColumn<Float> cTsysCol;
207 ROArrayColumn<Float> cSigmaCol;
208 ROArrayColumn<Float> cCalFctrCol;
209 ROArrayColumn<Float> cBaseLinCol;
210 ROArrayColumn<Float> cBaseSubCol;
211 ROArrayColumn<Float> cFloatDataCol;
212 ROArrayColumn<Bool> cFlagCol;
213 ROScalarColumn<Complex> cXCalFctrCol;
214 ROArrayColumn<Complex> cDataCol;
215 ROScalarColumn<Int> cNumReceptorCol;
216 ROScalarColumn<Bool> cSigStateCol;
217 ROScalarColumn<Bool> cRefStateCol;
218
219};
220
221#endif
Note: See TracBrowser for help on using the repository browser.