| [2] | 1 | //#--------------------------------------------------------------------------- | 
|---|
|  | 2 | //# SDMemTable.h: A MemoryTable container for single dish integrations | 
|---|
|  | 3 | //#--------------------------------------------------------------------------- | 
|---|
|  | 4 | //# Copyright (C) 2004 | 
|---|
| [125] | 5 | //# ATNF | 
|---|
| [2] | 6 | //# | 
|---|
|  | 7 | //# This program is free software; you can redistribute it and/or modify it | 
|---|
|  | 8 | //# under the terms of the GNU General Public License as published by the Free | 
|---|
|  | 9 | //# Software Foundation; either version 2 of the License, or (at your option) | 
|---|
|  | 10 | //# any later version. | 
|---|
|  | 11 | //# | 
|---|
|  | 12 | //# This program is distributed in the hope that it will be useful, but | 
|---|
|  | 13 | //# WITHOUT ANY WARRANTY; without even the implied warranty of | 
|---|
|  | 14 | //# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General | 
|---|
|  | 15 | //# Public License for more details. | 
|---|
|  | 16 | //# | 
|---|
|  | 17 | //# You should have received a copy of the GNU General Public License along | 
|---|
|  | 18 | //# with this program; if not, write to the Free Software Foundation, Inc., | 
|---|
|  | 19 | //# 675 Massachusetts Ave, Cambridge, MA 02139, USA. | 
|---|
|  | 20 | //# | 
|---|
|  | 21 | //# Correspondence concerning this software should be addressed as follows: | 
|---|
|  | 22 | //#        Internet email: Malte.Marquarding@csiro.au | 
|---|
|  | 23 | //#        Postal address: Malte Marquarding, | 
|---|
|  | 24 | //#                        Australia Telescope National Facility, | 
|---|
|  | 25 | //#                        P.O. Box 76, | 
|---|
|  | 26 | //#                        Epping, NSW, 2121, | 
|---|
|  | 27 | //#                        AUSTRALIA | 
|---|
|  | 28 | //# | 
|---|
|  | 29 | //# $Id: | 
|---|
|  | 30 | //#--------------------------------------------------------------------------- | 
|---|
| [125] | 31 | #ifndef SDMEMTABLE_H | 
|---|
|  | 32 | #define SDMEMTABLE_H | 
|---|
| [2] | 33 |  | 
|---|
|  | 34 | // STL | 
|---|
|  | 35 | #include <string> | 
|---|
|  | 36 | #include <vector> | 
|---|
|  | 37 | // AIPS++ | 
|---|
| [236] | 38 | #include <casa/aips.h> | 
|---|
| [322] | 39 | #include <casa/Arrays/MaskedArray.h> | 
|---|
| [80] | 40 | #include <casa/BasicSL/String.h> | 
|---|
| [322] | 41 | #include <coordinates/Coordinates/SpectralCoordinate.h> | 
|---|
| [80] | 42 | #include <tables/Tables/Table.h> | 
|---|
| [322] | 43 | #include <tables/Tables/ArrayColumn.h> | 
|---|
|  | 44 | #include <tables/Tables/ScalarColumn.h> | 
|---|
|  | 45 |  | 
|---|
| [236] | 46 | #include "SDDefs.h" | 
|---|
| [2] | 47 |  | 
|---|
| [39] | 48 |  | 
|---|
| [322] | 49 |  | 
|---|
| [83] | 50 | namespace asap { | 
|---|
| [2] | 51 |  | 
|---|
|  | 52 | class SDContainer; | 
|---|
|  | 53 | class SDHeader; | 
|---|
|  | 54 | class SDFrequencyTable; | 
|---|
|  | 55 |  | 
|---|
|  | 56 |  | 
|---|
| [322] | 57 |  | 
|---|
|  | 58 |  | 
|---|
| [2] | 59 | class SDMemTable { | 
|---|
|  | 60 | public: | 
|---|
| [19] | 61 | // create a new (empty) SDMemTable | 
|---|
| [18] | 62 | SDMemTable(); | 
|---|
| [50] | 63 | // create a SDMemTable from an (aips++) table on disk | 
|---|
| [18] | 64 | SDMemTable(const std::string& name); | 
|---|
| [19] | 65 |  | 
|---|
|  | 66 | // Copy Construct a SDMemTable, if clear==True only header and | 
|---|
|  | 67 | // skeleton are copied, otherwise the whole table is copied. | 
|---|
| [147] | 68 | SDMemTable(const SDMemTable& other, casa::Bool clear=casa::False); | 
|---|
| [2] | 69 |  | 
|---|
| [161] | 70 | // Copy Construct (copy semantics) a SDMemTable, give a scanid constraint | 
|---|
| [19] | 71 | // see also getScan() | 
|---|
| [125] | 72 | SDMemTable(const casa::Table& tab, const std::string& expr); | 
|---|
| [161] | 73 |  | 
|---|
|  | 74 | // Assignment operator (copy semantics) | 
|---|
| [138] | 75 | SDMemTable &operator=(const SDMemTable& other); | 
|---|
|  | 76 |  | 
|---|
| [2] | 77 | virtual ~SDMemTable(); | 
|---|
| [19] | 78 |  | 
|---|
|  | 79 | // put data from meta conatiner into the table | 
|---|
| [39] | 80 | bool putSDContainer(const SDContainer& sdc); | 
|---|
|  | 81 | bool putSDHeader(const SDHeader& sdh); | 
|---|
|  | 82 | bool putSDFreqTable(const SDFrequencyTable& sdft); | 
|---|
| [21] | 83 |  | 
|---|
| [161] | 84 | //get the data wrapped up in a meta container | 
|---|
| [386] | 85 |  | 
|---|
| [125] | 86 | SDContainer getSDContainer(casa::uInt whichRow=0) const; | 
|---|
| [39] | 87 | SDHeader getSDHeader() const; | 
|---|
| [293] | 88 |  | 
|---|
| [306] | 89 | // Get SD Frequency table. | 
|---|
| [39] | 90 | SDFrequencyTable getSDFreqTable() const; | 
|---|
| [306] | 91 |  | 
|---|
| [19] | 92 | // get spectrum,mask and tsys for the given row, at the selected | 
|---|
| [21] | 93 | // cursor - all as stl vectors | 
|---|
| [125] | 94 | virtual std::vector<float> getSpectrum(casa::Int whichRow=0) const; | 
|---|
|  | 95 | virtual std::vector<bool> getMask(casa::Int whichRow=0) const; | 
|---|
| [21] | 96 |  | 
|---|
| [125] | 97 | virtual casa::Float getTsys(casa::Int whichRow=0) const; | 
|---|
| [21] | 98 | // get all as aips++ Vectors | 
|---|
| [125] | 99 | virtual void getSpectrum(casa::Vector<casa::Float>& spectrum, | 
|---|
| [164] | 100 | casa::Int whichRow=0) const; | 
|---|
| [2] | 101 |  | 
|---|
| [88] | 102 | //virtual void getMask(Vector<Bool>& mask,Int whichRow=0) const; | 
|---|
| [251] | 103 | std::vector<double> getRestFreqs() const; | 
|---|
|  | 104 |  | 
|---|
| [281] | 105 | // get info for current row | 
|---|
|  | 106 | // if whichRow == -1 the Header time is given | 
|---|
|  | 107 | std::string getTime(casa::Int whichRow=0, | 
|---|
|  | 108 | casa::Bool showDate=casa::False) const ; | 
|---|
| [286] | 109 | casa::MEpoch getEpoch(casa::Int whichRow=0) const; | 
|---|
|  | 110 | casa::MDirection getDirection(casa::Int whichRow=0, | 
|---|
|  | 111 | casa::Bool refBeam=casa::False) const; | 
|---|
|  | 112 | // | 
|---|
| [125] | 113 | std::string getSourceName(casa::Int whichRow=0) const; | 
|---|
|  | 114 | double getInterval(casa::Int whichRow=0) const; | 
|---|
| [50] | 115 |  | 
|---|
| [88] | 116 | virtual void setSpectrum(std::vector<float> spectrum, int whichRow=0); | 
|---|
| [105] | 117 | virtual void setCoordInfo(std::vector<string> theinfo); | 
|---|
| [206] | 118 |  | 
|---|
| [392] | 119 | // Set RestFreqID.  source="" and IF=-1 means select all | 
|---|
|  | 120 | virtual casa::Bool setRestFreqs (const casa::Vector<casa::Double>& restFreqs, | 
|---|
|  | 121 | const casa::String& unit, | 
|---|
|  | 122 | const casa::String& source, | 
|---|
|  | 123 | casa::Int whichIF=-1); | 
|---|
| [386] | 124 |  | 
|---|
| [218] | 125 | // Get/Set flux unit | 
|---|
| [206] | 126 | std::string getFluxUnit() const; | 
|---|
| [218] | 127 | void setFluxUnit (const std::string& unit); | 
|---|
| [206] | 128 |  | 
|---|
| [236] | 129 | // Set Instrument | 
|---|
|  | 130 | void setInstrument (const std::string& instrument); | 
|---|
|  | 131 |  | 
|---|
| [19] | 132 | // set the current value | 
|---|
| [125] | 133 | virtual bool setIF(casa::Int whichIF=0); | 
|---|
|  | 134 | virtual bool setBeam(casa::Int whichBeam=0); | 
|---|
|  | 135 | virtual bool setPol(casa::Int whichPol=0); | 
|---|
| [88] | 136 |  | 
|---|
| [303] | 137 | // REset cursor to 0 | 
|---|
|  | 138 | virtual void resetCursor(); | 
|---|
|  | 139 |  | 
|---|
| [88] | 140 | //sets the user mask applied to all spectra | 
|---|
| [68] | 141 | virtual bool setMask(std::vector<int> whichChans); | 
|---|
| [88] | 142 | // Hard flags the current spectrum, not reversible | 
|---|
|  | 143 | virtual void flag(int whichRow); | 
|---|
|  | 144 |  | 
|---|
| [19] | 145 | // return the currently selected values | 
|---|
| [154] | 146 | virtual casa::Int getIF() const { return IFSel_; } | 
|---|
|  | 147 | virtual casa::Int getBeam() const { return beamSel_; } | 
|---|
|  | 148 | virtual casa::Int getPol() const { return polSel_; } | 
|---|
| [263] | 149 |  | 
|---|
|  | 150 | // returns unit, conversion frame, doppler, base-frame | 
|---|
| [206] | 151 | virtual std::vector<std::string> getCoordInfo() const; | 
|---|
| [88] | 152 |  | 
|---|
| [50] | 153 | // number of scans in table | 
|---|
| [125] | 154 | virtual casa::Int nScan() const; | 
|---|
| [50] | 155 |  | 
|---|
| [206] | 156 | // get a summary of the table | 
|---|
| [380] | 157 | virtual std::string summary(bool verbose=false) const; | 
|---|
| [88] | 158 |  | 
|---|
| [206] | 159 | std::vector<std::string> history(int whichRow=0) const; | 
|---|
|  | 160 | bool appendHistory(const std::string& hist, int whichRow=0); | 
|---|
| [19] | 161 | // write to disk as aips++ table | 
|---|
| [2] | 162 | void makePersistent(const std::string& filename); | 
|---|
| [19] | 163 |  | 
|---|
| [88] | 164 | // get a new SDMemTable containing all rows with the same give SCANID | 
|---|
| [164] | 165 | SDMemTable getScan(casa::Int scanID) const; | 
|---|
|  | 166 | SDMemTable getSource(const std::string& source) const; | 
|---|
| [18] | 167 |  | 
|---|
| [125] | 168 | const casa::TableRecord& getHeader() const {return table_.keywordSet();} | 
|---|
| [19] | 169 | // get a handle to the "raw" aips++ table | 
|---|
| [138] | 170 | const casa::Table& table() const { return table_; } | 
|---|
| [2] | 171 |  | 
|---|
| [19] | 172 | // return the number of values | 
|---|
| [125] | 173 | casa::Int nBeam() const; | 
|---|
|  | 174 | casa::Int nIF() const; | 
|---|
|  | 175 | casa::Int nPol() const; | 
|---|
|  | 176 | casa::Int nChan() const; | 
|---|
| [18] | 177 |  | 
|---|
| [22] | 178 | // return the number of rows (integrations) in the table | 
|---|
| [125] | 179 | casa::Int nRow() const { return table_.nrow(); } | 
|---|
| [22] | 180 |  | 
|---|
| [19] | 181 | // return a row as a Masked array, internally converting uChar flags | 
|---|
|  | 182 | // to bool mask | 
|---|
| [125] | 183 | casa::MaskedArray<casa::Float> rowAsMaskedArray(casa::uInt whichRow, | 
|---|
| [206] | 184 | casa::Bool useSelection = | 
|---|
|  | 185 | casa::False) const; | 
|---|
| [19] | 186 |  | 
|---|
| [286] | 187 | // Return SC, setting only the basic construction state (i.e. | 
|---|
| [306] | 188 | // no conversion or velocity or rest frequency state). | 
|---|
|  | 189 | // Specify the index of the FreqID you want | 
|---|
| [286] | 190 | casa::SpectralCoordinate getSpectralCoordinate(casa::uInt whichIdx) const; | 
|---|
|  | 191 |  | 
|---|
| [386] | 192 | // Return SC. Set velocity conversion state (unit,doppler), and | 
|---|
|  | 193 | // rest frequency.  If row number given (>=0), also set | 
|---|
| [286] | 194 | // frame conversion layer (needs direction & time which require row) | 
|---|
| [386] | 195 | casa::SpectralCoordinate getSpectralCoordinate(casa::uInt freqID, | 
|---|
|  | 196 | casa::uInt restFreqID, | 
|---|
|  | 197 | casa::uInt row) const; | 
|---|
| [286] | 198 |  | 
|---|
|  | 199 | // Set just the reference value, pixel and increment into the table | 
|---|
|  | 200 | // No other state is extracted. | 
|---|
| [125] | 201 | casa::Bool setCoordinate(const casa::SpectralCoordinate& speccord, | 
|---|
|  | 202 | casa::uInt whichIdx); | 
|---|
| [50] | 203 |  | 
|---|
| [125] | 204 | casa::Int nCoordinates() const; | 
|---|
| [88] | 205 |  | 
|---|
| [164] | 206 | std::vector<double> getAbcissa(int whichRow=0) const; | 
|---|
|  | 207 | std::string getAbcissaString(casa::Int whichRow=0) const; | 
|---|
| [212] | 208 |  | 
|---|
| [286] | 209 | // Get global reference  types | 
|---|
| [281] | 210 | casa::MDirection::Types getDirectionReference() const; | 
|---|
|  | 211 | casa::MEpoch::Types getTimeReference() const; | 
|---|
| [212] | 212 |  | 
|---|
| [286] | 213 | // Get global antenna position | 
|---|
|  | 214 | casa::MPosition getAntennaPosition() const; | 
|---|
|  | 215 |  | 
|---|
| [236] | 216 | // Helper function to check instrument (antenna) name and give enum | 
|---|
| [281] | 217 | static Instrument convertInstrument(const casa::String& instrument, | 
|---|
|  | 218 | casa::Bool throwIt); | 
|---|
| [236] | 219 |  | 
|---|
| [2] | 220 | private: | 
|---|
| [105] | 221 | // utility func for nice printout | 
|---|
| [260] | 222 | casa::String formatSec(casa::Double x) const; | 
|---|
| [281] | 223 | casa::String formatDirection(const casa::MDirection& md) const; | 
|---|
| [2] | 224 | void setup(); | 
|---|
| [322] | 225 | void attach(); | 
|---|
| [380] | 226 | void renumber(); | 
|---|
| [19] | 227 | // the current cursor into the array | 
|---|
| [125] | 228 | casa::Int IFSel_,beamSel_,polSel_; | 
|---|
| [88] | 229 | std::vector<bool> chanMask_; | 
|---|
| [50] | 230 | // the underlying memory table | 
|---|
| [125] | 231 | casa::Table table_; | 
|---|
| [322] | 232 |  | 
|---|
|  | 233 | // Cached Columns to avoid reconstructing them for each row get/put | 
|---|
|  | 234 | casa::ScalarColumn<casa::Double> timeCol_, integrCol_; | 
|---|
|  | 235 | casa::ScalarColumn<casa::Float> azCol_, elCol_, paraCol_; | 
|---|
|  | 236 | casa::ScalarColumn<casa::String> srcnCol_, fldnCol_, tcaltCol_; | 
|---|
|  | 237 | casa::ScalarColumn<casa::Int> scanCol_, rbeamCol_; | 
|---|
|  | 238 | casa::ArrayColumn<casa::Float> specCol_, tsCol_, tcalCol_; | 
|---|
|  | 239 | casa::ArrayColumn<casa::Double> dirCol_; | 
|---|
|  | 240 | casa::ArrayColumn<casa::uChar> flagsCol_; | 
|---|
| [386] | 241 | casa::ArrayColumn<casa::uInt> freqidCol_, restfreqidCol_; | 
|---|
| [322] | 242 | casa::ArrayColumn<casa::String> histCol_; | 
|---|
| [2] | 243 | }; | 
|---|
|  | 244 |  | 
|---|
|  | 245 | }// namespace | 
|---|
|  | 246 | #endif | 
|---|