source: trunk/src/FillerBase.cpp @ 1876

Last change on this file since 1876 was 1876, checked in by Takeshi Nakazato, 14 years ago

New Development: No

JIRA Issue: No

Ready for Test: Yes

Interface Changes: No

What Interface Changed: Please list interface changes

Test Programs: List test programs

Put in Release Notes: Yes/No?

Module(s): Module Names change impacts.

Description: Describe your changes here...

Fixed a bug that causes regression failure.


File size: 4.9 KB
Line 
1//
2// C++ Interface: FillerBase
3//
4// Description:
5//
6//
7// Author: Malte Marquarding <asap@atnf.csiro.au>, (C) 2010
8//
9// Copyright: See COPYING file that comes with this distribution
10//
11//
12
13#include <casa/Containers/RecordField.h>
14
15#include "FillerBase.h"
16
17using namespace casa;
18
19namespace asap {
20
21FillerBase::FillerBase(casa::CountedPtr<Scantable> stable) :
22  table_(stable)
23{
24    row_ = TableRow(table_->table());
25}
26
27void FillerBase::setHeader(const STHeader& header)
28{
29  table_->setHeader(header);
30}
31
32void FillerBase::setSpectrum(const Vector<Float>& spectrum,
33                             const Vector<uChar>& flags,
34                             const Vector<Float>& tsys)
35{
36  RecordFieldPtr< Array<Float> > specCol(row_.record(), "SPECTRA");
37  RecordFieldPtr< Array<uChar> > flagCol(row_.record(), "FLAGTRA");
38  RecordFieldPtr< Array<Float> > tsysCol(row_.record(), "TSYS");
39
40  //*specCol = spectrum;
41  //*flagCol = flags;
42  //*tsysCol = tsys;
43  specCol.define(spectrum);
44  flagCol.define(flags);
45  tsysCol.define(tsys);
46}
47
48void FillerBase::setFlagrow(uInt flag)
49{
50  RecordFieldPtr<uInt> flagrowCol(row_.record(), "FLAGROW");
51  *flagrowCol = flag;
52}
53
54void FillerBase::setOpacity(Float opacity)
55{
56  RecordFieldPtr<Float> tauCol(row_.record(), "OPACITY") ;
57  *tauCol = opacity ;
58}
59
60void FillerBase::setIndex(uInt scanno, uInt cycleno, uInt ifno, uInt polno,
61                          uInt beamno)
62{
63  RecordFieldPtr<uInt> beamCol(row_.record(), "BEAMNO");
64  RecordFieldPtr<uInt> ifCol(row_.record(), "IFNO");
65  RecordFieldPtr<uInt> polCol(row_.record(), "POLNO");
66  RecordFieldPtr<uInt> cycleCol(row_.record(), "CYCLENO");
67  RecordFieldPtr<uInt> scanCol(row_.record(), "SCANNO");
68  *beamCol = beamno;
69  *cycleCol = cycleno;
70  *ifCol = ifno;
71  *polCol = polno;
72  *scanCol = scanno;
73}
74
75void FillerBase::setFrequency(Double refpix, Double refval,
76                              Double incr)
77{
78  /// @todo this has to change when nchan isn't global anymore
79  uInt id= table_->frequencies().addEntry(refpix, refval, incr);
80  RecordFieldPtr<uInt> mfreqidCol(row_.record(), "FREQ_ID");
81  *mfreqidCol = id;
82
83}
84
85
86void FillerBase::setMolecule(const Vector<Double>& restfreq)
87{
88  Vector<String> tmp;
89  uInt id = table_->molecules().addEntry(restfreq, tmp, tmp);
90  RecordFieldPtr<uInt> molidCol(row_.record(), "MOLECULE_ID");
91  *molidCol = id;
92}
93
94void FillerBase::setDirection(const Vector<Double>& dir,
95                              Float az, Float el)
96{
97  RecordFieldPtr<Array<Double> > dirCol(row_.record(), "DIRECTION");
98  *dirCol = dir;
99  RecordFieldPtr<Float> azCol(row_.record(), "AZIMUTH");
100  *azCol = az;
101  RecordFieldPtr<Float> elCol(row_.record(), "ELEVATION");
102  *elCol = el;
103}
104
105void FillerBase::setFocus(Float pa, Float faxis,
106                      Float ftan, Float frot)
107{
108  RecordFieldPtr<uInt> mfocusidCol(row_.record(), "FOCUS_ID");
109  uInt id = table_->focus().addEntry(pa, faxis, ftan, frot);
110  *mfocusidCol = id;
111}
112
113void FillerBase::setTime(Double mjd, Double interval)
114{
115    RecordFieldPtr<Double> mjdCol(row_.record(), "TIME");
116    *mjdCol = mjd;
117    RecordFieldPtr<Double> intCol(row_.record(), "INTERVAL");
118    *intCol = interval;
119
120}
121
122void FillerBase::setWeather(Float temperature, Float pressure,
123                        Float humidity,
124                        Float windspeed, Float windaz)
125{
126    uInt id = table_->weather().addEntry(temperature, pressure,
127                                         humidity, windspeed, windaz);
128    RecordFieldPtr<uInt> mweatheridCol(row_.record(), "WEATHER_ID");
129    *mweatheridCol = id;
130}
131
132void FillerBase::setTcal(const String& tcaltime,
133                     const Vector<Float>& tcal)
134{
135    uInt id = table_->tcal().addEntry(tcaltime, tcal);
136    RecordFieldPtr<uInt> mcalidCol(row_.record(), "TCAL_ID");
137    *mcalidCol = id;
138}
139
140void FillerBase::setScanRate(const Vector<Double>& srate)
141{
142    RecordFieldPtr<Array<Double> > srateCol(row_.record(), "SCANRATE");
143    *srateCol = srate;
144}
145
146void FillerBase::setReferenceBeam(Int beamno)
147{
148  RecordFieldPtr<Int> rbCol(row_.record(), "REFBEAMNO");
149  *rbCol = beamno;
150}
151
152void FillerBase::setSource(const std::string& name, Int type,
153                           const std::string& fieldname,
154                           const Vector<Double>& dir,
155                           const Vector<Double>& propermot,
156                           Double velocity)
157{
158    RecordFieldPtr<String> srcnCol(row_.record(), "SRCNAME");
159    *srcnCol = name;
160    RecordFieldPtr<Int> srctCol(row_.record(), "SRCTYPE");
161    *srctCol = type;
162    RecordFieldPtr<String> fieldnCol(row_.record(), "FIELDNAME");
163    *fieldnCol = fieldname;
164    RecordFieldPtr<Array<Double> > spmCol(row_.record(), "SRCPROPERMOTION");
165    *spmCol = propermot;
166    RecordFieldPtr<Array<Double> > sdirCol(row_.record(), "SRCDIRECTION");
167    *sdirCol = dir;
168    RecordFieldPtr<Double> svelCol(row_.record(), "SRCVELOCITY");
169    *svelCol = velocity;
170}
171
172void FillerBase::commitRow()
173{
174  table_->table().addRow();
175  row_.put(table_->table().nrow()-1);
176}
177
178};
Note: See TracBrowser for help on using the repository browser.