source: trunk/src/STCalTsys.cpp@ 2838

Last change on this file since 2838 was 2786, checked in by Takeshi Nakazato, 12 years ago

New Development: No

JIRA Issue: Yes CAS-4770

Ready for Test: Yes

Interface Changes: No

What Interface Changed: Please list interface changes

Test Programs: test_sdcal2

Put in Release Notes: No

Module(s): Module Names change impacts.

Description: Describe your changes here...

Bug fix on handling data selection of input Scantable object.


File size: 4.7 KB
RevLine 
[2696]1//
2// C++ Implementation: STCalTsys
3//
4// Description:
5//
6//
[2703]7// Author: Takeshi Nakazato <takeshi.nakazato@nao.ac.jp> (C) 2012
[2696]8//
9// Copyright: See COPYING file that comes with this distribution
10//
11//
12
[2703]13#include <vector>
[2786]14
15#include <casa/Arrays/ArrayMath.h>
16#include <casa/Logging/LogIO.h>
17
[2703]18#include "STSelector.h"
[2696]19#include "STCalTsys.h"
[2703]20#include "RowAccumulator.h"
21#include "STIdxIter.h"
22#include "STDefs.h"
23#include <atnf/PKSIO/SrcType.h>
[2696]24
[2703]25using namespace std;
[2696]26using namespace casa;
27
28namespace asap {
[2703]29 STCalTsys::STCalTsys(CountedPtr<Scantable> &s, vector<int> &iflist)
30 : STCalibration(s),
31 iflist_(iflist)
[2696]32{
[2703]33 applytable_ = new STCalTsysTable(*s);
[2696]34}
35
[2786]36void STCalTsys::setupSelector(const STSelector &sel)
[2696]37{
[2786]38 sel_ = sel;
39 vector<int> ifnos = sel_.getIFs();
40 if (ifnos.size() > 0) {
41 int nif = 0;
42 int nifOrg = iflist_.size();
43 vector<int> iflistNew(iflist_);
44 for (int i = 0; i < nifOrg; i++) {
45 if (find(ifnos.begin(), ifnos.end(), iflist_[i]) != ifnos.end()) {
46 iflistNew[nif] = iflist_[i];
47 ++nif;
48 }
49 }
50 if (nif == 0) {
51 LogIO os(LogOrigin("STCalTsys", "setupSelector", WHERE));
52 os << LogIO::SEVERE << "Selection contains no data." << LogIO::EXCEPTION;
53 }
54 sel_.setIFs(iflistNew);
55 }
56 else {
57 sel_.setIFs(iflist_);
58 }
[2696]59}
60
[2703]61void STCalTsys::fillCalTable()
[2696]62{
[2703]63 RowAccumulator acc(W_TINT);
64
65 vector<string> cols(3);
66 cols[0] = "IFNO";
67 cols[1] = "POLNO";
68 cols[2] = "BEAMNO";
69 STIdxIterAcc iter(scantable_, cols);
[2696]70
[2703]71 ROScalarColumn<Double> *tcol = new ROScalarColumn<Double>(scantable_->table(), "TIME");
72 Vector<Double> timeSec = tcol->getColumn() * 86400.0;
73 tcol->attach(scantable_->table(), "INTERVAL");
74 Vector<Double> intervalSec = tcol->getColumn();
75 delete tcol;
76 ROScalarColumn<Float> *ecol = new ROScalarColumn<Float>(scantable_->table(), "ELEVATION");
77 Vector<Float> elevation = ecol->getColumn();
78 delete ecol;
[2696]79
[2703]80 ROArrayColumn<Float> specCol(scantable_->table(), "TSYS");
81 ROArrayColumn<uChar> flagCol(scantable_->table(), "FLAGTRA");
[2720]82 ROScalarColumn<uInt> freqidCol(scantable_->table(), "FREQ_ID");
[2696]83
[2703]84 // dummy Tsys: the following process doesn't need Tsys but RowAccumulator
85 // requires to set it with spectral data
86 Vector<Float> tsys(1, 1.0);
[2696]87
[2703]88 Double timeCen = 0.0;
89 Float elCen = 0.0;
90 uInt count = 0;
[2696]91
[2703]92 while(!iter.pastEnd()) {
93 Vector<uInt> rows = iter.getRows(SHARE);
94 Vector<uInt> current = iter.current();
[2749]95 //os_ << "current=" << current << LogIO::POST;
[2703]96 uInt len = rows.nelements();
97 if (len == 0) {
98 iter.next();
99 continue;
100 }
[2749]101 else if (len == 1) {
102 STCalTsysTable *p = dynamic_cast<STCalTsysTable *>(&(*applytable_));
103 uInt irow = rows[0];
104 p->appenddata(0, 0, current[2], current[0], current[1],
105 freqidCol(irow), timeSec[irow], elevation[irow], specCol(irow));
106 iter.next();
107 continue;
108 }
[2703]109
110 uInt nchan = scantable_->nchan(scantable_->getIF(rows[0]));
111 Vector<uChar> flag(nchan);
112 Vector<Bool> bflag(nchan);
113 Vector<Float> spec(nchan);
[2696]114
[2703]115 Vector<Double> timeSep(len);
116 for (uInt i = 0; i < len-1; i++) {
117 timeSep[i] = timeSec[rows[i+1]] - timeSec[rows[i]] ;
118 }
119 Double tMedian = median(timeSep(IPosition(1,0), IPosition(1,len-2)));
120 timeSep[len-1] = tMedian * 10000.0 ; // any large value
121
122 uInt irow ;
123 uInt jrow ;
124 for (uInt i = 0; i < len; i++) {
[2749]125 //os_ << "start row " << rows[i] << LogIO::POST;
[2703]126 irow = rows[i];
127 jrow = (i < len-1) ? rows[i+1] : rows[i];
128 // accumulate data
129 flagCol.get(irow, flag);
130 convertArray(bflag, flag);
131 specCol.get(irow, spec);
132 if ( !allEQ(bflag,True) )
133 acc.add( spec, !bflag, tsys, intervalSec[irow], timeSec[irow] ) ;
134 timeCen += timeSec[irow];
135 elCen += elevation[irow];
136 count++;
137
138 // check time gap
139 double gap = 2.0 * timeSep[i] / (intervalSec[jrow] + intervalSec[irow]);
140 if ( gap > 5.0 ) {
141 if ( acc.state() ) {
142 acc.replaceNaN() ;
143// const Vector<Bool> &msk = acc.getMask();
144// convertArray(flag, !msk);
145// for (uInt k = 0; k < nchan; ++k) {
146// uChar userFlag = 1 << 7;
147// if (msk[k]==True) userFlag = 0 << 7;
148// flag(k) = userFlag;
149// }
150 timeCen /= (Double)count * 86400.0; // sec->day
151 elCen /= (Float)count;
152 STCalTsysTable *p = dynamic_cast<STCalTsysTable *>(&(*applytable_));
153 p->appenddata(0, 0, current[2], current[0], current[1],
[2720]154 freqidCol(irow), timeCen, elCen, acc.getSpectrum());
[2703]155 }
156 acc.reset() ;
157 timeCen = 0.0;
158 elCen = 0.0;
159 count = 0;
160 }
161 }
162
163 iter.next() ;
[2749]164 //os_ << "end " << current << LogIO::POST;
[2703]165 }
[2696]166}
167
168}
Note: See TracBrowser for help on using the repository browser.