casacore
Loading...
Searching...
No Matches
MSColumns.h
Go to the documentation of this file.
1//# MSColumns.h: provides easy access to MeasurementSet columns
2//# Copyright (C) 1996,1999,2000
3//# Associated Universities, Inc. Washington DC, USA.
4//#
5//# This library is free software; you can redistribute it and/or modify it
6//# under the terms of the GNU Library General Public License as published by
7//# the Free Software Foundation; either version 2 of the License, or (at your
8//# option) any later version.
9//#
10//# This library is distributed in the hope that it will be useful, but WITHOUT
11//# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12//# FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public
13//# License for more details.
14//#
15//# You should have received a copy of the GNU Library General Public License
16//# along with this library; if not, write to the Free Software Foundation,
17//# Inc., 675 Massachusetts Ave, Cambridge, MA 02139, USA.
18//#
19//# Correspondence concerning AIPS++ should be addressed as follows:
20//# Internet email: casa-feedback@nrao.edu.
21//# Postal address: AIPS++ Project Office
22//# National Radio Astronomy Observatory
23//# 520 Edgemont Road
24//# Charlottesville, VA 22903-2475 USA
25
26#ifndef MS_MSCOLUMNS_H
27#define MS_MSCOLUMNS_H
28
29#include <casacore/casa/aips.h>
30#include <casacore/measures/Measures/MDirection.h>
31#include <casacore/measures/Measures/MEpoch.h>
32#include <casacore/measures/Measures/MCPosition.h>
33#include <casacore/measures/TableMeasures/ArrayMeasColumn.h>
34#include <casacore/measures/TableMeasures/ArrayQuantColumn.h>
35#include <casacore/measures/TableMeasures/ScalarMeasColumn.h>
36#include <casacore/measures/TableMeasures/ScalarQuantColumn.h>
37#include <casacore/ms/MeasurementSets/MSAntennaColumns.h>
38#include <casacore/ms/MeasurementSets/MSDataDescColumns.h>
39#include <casacore/ms/MeasurementSets/MSDopplerColumns.h>
40#include <casacore/ms/MeasurementSets/MSFeedColumns.h>
41#include <casacore/ms/MeasurementSets/MSFieldColumns.h>
42#include <casacore/ms/MeasurementSets/MSFlagCmdColumns.h>
43#include <casacore/ms/MeasurementSets/MSFreqOffColumns.h>
44#include <casacore/ms/MeasurementSets/MSHistoryColumns.h>
45#include <casacore/ms/MeasurementSets/MSMainColumns.h>
46#include <casacore/ms/MeasurementSets/MSObsColumns.h>
47#include <casacore/ms/MeasurementSets/MSPointingColumns.h>
48#include <casacore/ms/MeasurementSets/MSPolColumns.h>
49#include <casacore/ms/MeasurementSets/MSProcessorColumns.h>
50#include <casacore/ms/MeasurementSets/MSSourceColumns.h>
51#include <casacore/ms/MeasurementSets/MSSpWindowColumns.h>
52#include <casacore/ms/MeasurementSets/MSStateColumns.h>
53#include <casacore/ms/MeasurementSets/MSSysCalColumns.h>
54#include <casacore/ms/MeasurementSets/MSWeatherColumns.h>
55
56namespace casacore { //# NAMESPACE CASACORE - BEGIN
57
58class MeasurementSet;
59
60
61// <summary>
62// A class to provide easy access to MeasurementSet columns
63// </summary>
64
65// <use visibility=export>
66
67// <reviewed reviewer="Bob Garwood" date="1997/02/01" tests="" demos="">
68// </reviewed>
69
70// <prerequisite>
71// <li> MeasurementSet
72// <li> ArrayColumn
73// <li> ScalarColumn
74// </prerequisite>
75//
76// <etymology>
77// MSColumns stands for MeasurementSet Table columns.
78// </etymology>
79//
80// <synopsis>
81// This class provides access to all the subtables and direct access to all the
82// columns in the MeasurementSet. It does the declaration of all the Scalar
83// and ArrayColumns with the correct types, so the application programmer
84// doesn't have to worry about getting those right. There is an access function
85// for every predefined column. Access to non-predefined columns will still
86// have to be done with explicit declarations.
87// </synopsis>
88//
89// <example>
90// <srcblock>
91// // use as follows
92// MeasurementSet ms("myMS",Table::Update);
93// MSColumns msc(ms);
94// // show data from row 5
95// cout << msc.data()(5);
96// // change name of antenna on row 3 in antenna table
97// msc.antenna().name().put(3,"NewAnt-3");
98// </srcblock>
99// </example>
100//
101// <motivation>
102// Having to type long lists of Scalar and Array column declarations gets
103// very tedious. This class attempts to relieve some of that tedium, while
104// at the same time concentrating all the declarations in one place,
105// making Type errors in the column declaration (only caught at run-time) less
106// probable. Type errors in the use of the columns is caught at compile
107// time.
108// </motivation>
109//
110// <todo asof="1997/02/01">
111// <li> We might decide to merge this class with the MeasurementSet
112// </todo>
113
115{
116public:
117 // Create a columns object that accesses the data in the specified MS
119
120 // The destructor does nothing special
122
123 // Access to required subtables
124 // <group>
137 // </group>
138
139 // Access to optional subtables
140 // <group>
146 // </group>
147
148 // Access to required subtables
149 // <group>
150 const MSAntennaColumns& antenna() const {return antenna_p;}
152 const MSFeedColumns& feed() const {return feed_p;}
153 const MSFieldColumns& field() const {return field_p;}
154 const MSFlagCmdColumns& flagCmd() const {return flagCmd_p;}
155 const MSHistoryColumns& history() const {return history_p;}
157 const MSPointingColumns& pointing() const {return pointing_p;}
159 return polarization_p;}
160 const MSProcessorColumns& processor() const {return processor_p;}
162 return spectralWindow_p;}
163 const MSStateColumns& state() const {return state_p;}
164 // </group>
165
166 // Access to optional subtables
167 // <group>
168 const MSDopplerColumns& doppler() const {return doppler_p;}
170 const MSSourceColumns& source() const {return source_p;}
171 const MSSysCalColumns& sysCal() const {return sysCal_p;}
172 const MSWeatherColumns& weather() const {return weather_p;}
173 // </group>
174
175 // set the EPOCH reference type in all EPOCH columns in the MS. Note that
176 // only a single EPOCH reference is allowed in the MS. This
177 // <note role=tip>
178 // In principle this function can only be used if the table is empty,
179 // otherwise already written values may thereafter have an incorrect
180 // reference, offset, or unit. However, it is possible that part of the
181 // table gets written before these values are known. In that case the
182 // reference, offset, or units can be set by using a False
183 // <src>tableMustBeEmpty</src> argument.
184 // </note>
185 void setEpochRef(MEpoch::Types ref, Bool tableMustBeEmpty=True);
186
187 // set the DIRECTION reference type for FIELD, POINTING and SOURCE tables
188 // (except for antenna frame directions).
190
191private:
192 // Access to subtables
210};
211
212//# Define the RO version for backward compatibility.
214
215//# Declare extern templates for often used types.
216 extern template class ArrayMeasColumn<MDirection>;
217 extern template class ScalarMeasColumn<MPosition>;
218 extern template class ScalarMeasColumn<MEpoch>;
219 extern template class ArrayQuantColumn<Double>;
220 extern template class ScalarQuantColumn<Double>;
221
222} //# NAMESPACE CASACORE - END
223
224#endif
225
226
Types
Types of known MDirections Warning: The order defines the order in the translation matrix FromTo in ...
Definition MDirection.h:185
Types
Types of known MEpochs Caution: The order defines the order in the translation matrix in the MCEpoch...
Definition MEpoch.h:114
MSAntennaColumns antenna_p
Access to subtables.
Definition MSColumns.h:193
const MSSpWindowColumns & spectralWindow() const
Definition MSColumns.h:161
MSDopplerColumns & doppler()
Access to optional subtables.
Definition MSColumns.h:141
const MSPolarizationColumns & polarization() const
Definition MSColumns.h:158
const MSFeedColumns & feed() const
Definition MSColumns.h:152
MSSysCalColumns & sysCal()
Definition MSColumns.h:144
MSObservationColumns & observation()
Definition MSColumns.h:131
MSStateColumns state_p
Definition MSColumns.h:207
MSObservationColumns observation_p
Definition MSColumns.h:201
void setEpochRef(MEpoch::Types ref, Bool tableMustBeEmpty=True)
set the EPOCH reference type in all EPOCH columns in the MS.
MSWeatherColumns weather_p
Definition MSColumns.h:209
MSDataDescColumns dataDesc_p
Definition MSColumns.h:194
const MSHistoryColumns & history() const
Definition MSColumns.h:155
MSProcessorColumns & processor()
Definition MSColumns.h:134
MSFieldColumns & field()
Definition MSColumns.h:128
MSDopplerColumns doppler_p
Definition MSColumns.h:195
MSFlagCmdColumns & flagCmd()
Definition MSColumns.h:129
const MSDopplerColumns & doppler() const
Access to optional subtables.
Definition MSColumns.h:168
MSSysCalColumns sysCal_p
Definition MSColumns.h:208
MSFeedColumns feed_p
Definition MSColumns.h:196
MSFeedColumns & feed()
Definition MSColumns.h:127
const MSFreqOffsetColumns & freqOffset() const
Definition MSColumns.h:169
const MSFieldColumns & field() const
Definition MSColumns.h:153
const MSSourceColumns & source() const
Definition MSColumns.h:170
const MSObservationColumns & observation() const
Definition MSColumns.h:156
~MSColumns()
The destructor does nothing special.
const MSProcessorColumns & processor() const
Definition MSColumns.h:160
MSAntennaColumns & antenna()
Access to required subtables.
Definition MSColumns.h:125
MSPointingColumns pointing_p
Definition MSColumns.h:202
MSHistoryColumns history_p
Definition MSColumns.h:200
MSFlagCmdColumns flagCmd_p
Definition MSColumns.h:198
MSFreqOffsetColumns & freqOffset()
Definition MSColumns.h:142
MSSpWindowColumns spectralWindow_p
Definition MSColumns.h:206
const MSAntennaColumns & antenna() const
Access to required subtables.
Definition MSColumns.h:150
const MSDataDescColumns & dataDescription() const
Definition MSColumns.h:151
const MSSysCalColumns & sysCal() const
Definition MSColumns.h:171
void setDirectionRef(MDirection::Types ref)
set the DIRECTION reference type for FIELD, POINTING and SOURCE tables (except for antenna frame dire...
MSFieldColumns field_p
Definition MSColumns.h:197
MSSourceColumns & source()
Definition MSColumns.h:143
MSPolarizationColumns & polarization()
Definition MSColumns.h:133
MSDataDescColumns & dataDescription()
Definition MSColumns.h:126
MSWeatherColumns & weather()
Definition MSColumns.h:145
MSSpWindowColumns & spectralWindow()
Definition MSColumns.h:135
MSHistoryColumns & history()
Definition MSColumns.h:130
MSPointingColumns & pointing()
Definition MSColumns.h:132
MSFreqOffsetColumns freqOffset_p
Definition MSColumns.h:199
MSSourceColumns source_p
Definition MSColumns.h:205
MSProcessorColumns processor_p
Definition MSColumns.h:204
MSStateColumns & state()
Definition MSColumns.h:136
const MSFlagCmdColumns & flagCmd() const
Definition MSColumns.h:154
const MSWeatherColumns & weather() const
Definition MSColumns.h:172
const MSStateColumns & state() const
Definition MSColumns.h:163
const MSPointingColumns & pointing() const
Definition MSColumns.h:157
MSColumns(const MeasurementSet &ms)
Create a columns object that accesses the data in the specified MS.
MSPolarizationColumns polarization_p
Definition MSColumns.h:203
this file contains all the compiler specific defines
Definition mainpage.dox:28
MSColumns ROMSColumns
Definition MSColumns.h:213
bool Bool
Define the standard types used by Casacore.
Definition aipstype.h:40
const Bool True
Definition aipstype.h:41