- Timestamp:
- 04/02/14 18:38:27 (11 years ago)
- Location:
- trunk/src
- Files:
-
- 6 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/STCalSkyPSAlma.cpp
r2786 r2915 17 17 #include "STSelector.h" 18 18 #include "STCalSkyPSAlma.h" 19 #include "RowAccumulator.h"20 #include "STIdxIter.h"21 19 #include "STDefs.h" 22 20 #include <atnf/PKSIO/SrcType.h> … … 27 25 namespace asap { 28 26 STCalSkyPSAlma::STCalSkyPSAlma(CountedPtr<Scantable> &s) 29 : STCalibration(s )27 : STCalibration(s, "SPECTRA") 30 28 { 31 29 applytable_ = new STCalSkyTable(*s, "PSALMA"); … … 51 49 } 52 50 } 53 54 void STCalSkyPSAlma::fillCalTable() 51 52 void STCalSkyPSAlma::appenddata(uInt scanno, uInt cycleno, 53 uInt beamno, uInt ifno, uInt polno, 54 uInt freqid, Double time, Float elevation, 55 Vector<Float> any_data) 55 56 { 56 RowAccumulator acc(W_TINT); 57 58 vector<string> cols(3); 59 cols[0] = "IFNO"; 60 cols[1] = "POLNO"; 61 cols[2] = "BEAMNO"; 62 STIdxIterAcc iter(scantable_, cols); 63 64 ROScalarColumn<Double> *tcol = new ROScalarColumn<Double>(scantable_->table(), "TIME"); 65 Vector<Double> timeSec = tcol->getColumn() * 86400.0; 66 tcol->attach(scantable_->table(), "INTERVAL"); 67 Vector<Double> intervalSec = tcol->getColumn(); 68 delete tcol; 69 ROScalarColumn<Float> *ecol = new ROScalarColumn<Float>(scantable_->table(), "ELEVATION"); 70 Vector<Float> elevation = ecol->getColumn(); 71 delete ecol; 72 73 ROArrayColumn<Float> specCol(scantable_->table(), "SPECTRA"); 74 ROArrayColumn<uChar> flagCol(scantable_->table(), "FLAGTRA"); 75 ROScalarColumn<uInt> freqidCol(scantable_->table(), "FREQ_ID"); 76 77 // dummy Tsys: the following process doesn't need Tsys but RowAccumulator 78 // requires to set it with spectral data 79 Vector<Float> tsys(1, 1.0); 80 81 Double timeCen = 0.0; 82 Float elCen = 0.0; 83 uInt count = 0; 84 85 while(!iter.pastEnd()) { 86 Vector<uInt> rows = iter.getRows(SHARE); 87 Vector<uInt> current = iter.current(); 88 uInt len = rows.nelements(); 89 if (len == 0) { 90 iter.next(); 91 continue; 92 } 93 else if (len == 1) { 94 STCalSkyTable *p = dynamic_cast<STCalSkyTable *>(&(*applytable_)); 95 uInt irow = rows[0]; 96 p->appenddata(0, 0, current[2], current[0], current[1], 97 freqidCol(irow), timeSec[irow], elevation[irow], specCol(irow)); 98 iter.next(); 99 continue; 100 } 101 102 uInt nchan = scantable_->nchan(scantable_->getIF(rows[0])); 103 Vector<uChar> flag(nchan); 104 Vector<Bool> bflag(nchan); 105 Vector<Float> spec(nchan); 106 107 Vector<Double> timeSep(len); 108 for (uInt i = 0; i < len-1; i++) { 109 timeSep[i] = timeSec[rows[i+1]] - timeSec[rows[i]] ; 110 } 111 Double tMedian = median(timeSep(IPosition(1,0), IPosition(1,len-2))); 112 timeSep[len-1] = tMedian * 10000.0 ; // any large value 113 114 uInt irow ; 115 uInt jrow ; 116 for (uInt i = 0; i < len; i++) { 117 irow = rows[i]; 118 jrow = (i < len-1) ? rows[i+1] : rows[i]; 119 // accumulate data 120 flagCol.get(irow, flag); 121 convertArray(bflag, flag); 122 specCol.get(irow, spec); 123 if ( !allEQ(bflag,True) ) 124 acc.add( spec, !bflag, tsys, intervalSec[irow], timeSec[irow] ) ; 125 timeCen += timeSec[irow]; 126 elCen += elevation[irow]; 127 count++; 128 129 // check time gap 130 double gap = 2.0 * timeSep[i] / (intervalSec[jrow] + intervalSec[irow]); 131 if ( gap > 1.1 ) { 132 if ( acc.state() ) { 133 acc.replaceNaN() ; 134 // const Vector<Bool> &msk = acc.getMask(); 135 // convertArray(flag, !msk); 136 // for (uInt k = 0; k < nchan; ++k) { 137 // uChar userFlag = 1 << 7; 138 // if (msk[k]==True) userFlag = 0 << 7; 139 // flag(k) = userFlag; 140 // } 141 timeCen /= (Double)count * 86400.0; // sec->day 142 elCen /= (Float)count; 143 STCalSkyTable *p = dynamic_cast<STCalSkyTable *>(&(*applytable_)); 144 p->appenddata(0, 0, current[2], current[0], current[1], 145 freqidCol(irow), timeCen, elCen, acc.getSpectrum()); 146 } 147 acc.reset() ; 148 timeCen = 0.0; 149 elCen = 0.0; 150 count = 0; 151 } 152 } 153 154 iter.next() ; 155 } 57 STCalSkyTable *p = dynamic_cast<STCalSkyTable *>(&(*applytable_)); 58 p->appenddata(scanno, cycleno, beamno, ifno, polno, 59 freqid, time, elevation, any_data); 156 60 } 157 61 -
trunk/src/STCalSkyPSAlma.h
r2786 r2915 43 43 protected: 44 44 virtual void setupSelector(const STSelector &sel); 45 virtual void fillCalTable(); 45 virtual void appenddata(casa::uInt scanno, casa::uInt cycleno, 46 casa::uInt beamno, casa::uInt ifno, casa::uInt polno, 47 casa::uInt freqid, casa::Double time, casa::Float elevation, 48 casa::Vector<casa::Float> any_data); 46 49 }; 47 50 -
trunk/src/STCalTsys.cpp
r2786 r2915 18 18 #include "STSelector.h" 19 19 #include "STCalTsys.h" 20 #include "RowAccumulator.h"21 #include "STIdxIter.h"22 20 #include "STDefs.h" 23 21 #include <atnf/PKSIO/SrcType.h> … … 28 26 namespace asap { 29 27 STCalTsys::STCalTsys(CountedPtr<Scantable> &s, vector<int> &iflist) 30 : STCalibration(s ),28 : STCalibration(s, "TSYS"), 31 29 iflist_(iflist) 32 30 { … … 59 57 } 60 58 61 void STCalTsys::fillCalTable() 59 void STCalTsys::appenddata(uInt scanno, uInt cycleno, 60 uInt beamno, uInt ifno, uInt polno, 61 uInt freqid, Double time, Float elevation, 62 Vector<Float> any_data) 62 63 { 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); 70 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; 79 80 ROArrayColumn<Float> specCol(scantable_->table(), "TSYS"); 81 ROArrayColumn<uChar> flagCol(scantable_->table(), "FLAGTRA"); 82 ROScalarColumn<uInt> freqidCol(scantable_->table(), "FREQ_ID"); 83 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); 87 88 Double timeCen = 0.0; 89 Float elCen = 0.0; 90 uInt count = 0; 91 92 while(!iter.pastEnd()) { 93 Vector<uInt> rows = iter.getRows(SHARE); 94 Vector<uInt> current = iter.current(); 95 //os_ << "current=" << current << LogIO::POST; 96 uInt len = rows.nelements(); 97 if (len == 0) { 98 iter.next(); 99 continue; 100 } 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 } 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); 114 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++) { 125 //os_ << "start row " << rows[i] << LogIO::POST; 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], 154 freqidCol(irow), timeCen, elCen, acc.getSpectrum()); 155 } 156 acc.reset() ; 157 timeCen = 0.0; 158 elCen = 0.0; 159 count = 0; 160 } 161 } 162 163 iter.next() ; 164 //os_ << "end " << current << LogIO::POST; 165 } 64 STCalTsysTable *p = dynamic_cast<STCalTsysTable *>(&(*applytable_)); 65 p->appenddata(scanno, cycleno, beamno, ifno, polno, 66 freqid, time, elevation, any_data); 166 67 } 167 68 -
trunk/src/STCalTsys.h
r2786 r2915 44 44 private: 45 45 void setupSelector(const STSelector &sel); 46 void fillCalTable(); 46 virtual void appenddata(casa::uInt scanno, casa::uInt cycleno, 47 casa::uInt beamno, casa::uInt ifno, casa::uInt polno, 48 casa::uInt freqid, casa::Double time, casa::Float elevation, 49 casa::Vector<casa::Float> any_data); 47 50 48 51 vector<int> iflist_; -
trunk/src/STCalibration.cpp
r2786 r2915 13 13 #include "STCalibration.h" 14 14 #include "STCalSkyTable.h" 15 #include "RowAccumulator.h" 16 #include "STIdxIter.h" 15 17 16 18 using namespace casa; 17 19 18 20 namespace asap { 19 STCalibration::STCalibration(CountedPtr<Scantable> &s) 20 : scantable_(s) 21 STCalibration::STCalibration(CountedPtr<Scantable> &s, const String target_column) 22 : scantable_(s), 23 target_column_(target_column) 21 24 { 22 25 } … … 33 36 } 34 37 38 void STCalibration::fillCalTable() 39 { 40 RowAccumulator acc(W_TINT); 41 42 vector<string> cols(3); 43 cols[0] = "IFNO"; 44 cols[1] = "POLNO"; 45 cols[2] = "BEAMNO"; 46 STIdxIterAcc iter(scantable_, cols); 47 48 ROScalarColumn<Double> *tcol = new ROScalarColumn<Double>(scantable_->table(), "TIME"); 49 Vector<Double> timeSec = tcol->getColumn() * 86400.0; 50 tcol->attach(scantable_->table(), "INTERVAL"); 51 Vector<Double> intervalSec = tcol->getColumn(); 52 delete tcol; 53 ROScalarColumn<Float> *ecol = new ROScalarColumn<Float>(scantable_->table(), "ELEVATION"); 54 Vector<Float> elevation = ecol->getColumn(); 55 delete ecol; 56 57 ROArrayColumn<Float> specCol(scantable_->table(), target_column_); 58 ROArrayColumn<uChar> flagCol(scantable_->table(), "FLAGTRA"); 59 ROScalarColumn<uInt> freqidCol(scantable_->table(), "FREQ_ID"); 60 61 // dummy Tsys: the following process doesn't need Tsys but RowAccumulator 62 // requires to set it with spectral data 63 Vector<Float> tsys(1, 1.0); 64 65 Double timeCen = 0.0; 66 Float elCen = 0.0; 67 uInt count = 0; 68 69 while(!iter.pastEnd()) { 70 Vector<uInt> rows = iter.getRows(SHARE); 71 Vector<uInt> current = iter.current(); 72 //os_ << "current=" << current << LogIO::POST; 73 uInt len = rows.nelements(); 74 if (len == 0) { 75 iter.next(); 76 continue; 77 } 78 else if (len == 1) { 79 uInt irow = rows[0]; 80 appenddata(0, 0, current[2], current[0], current[1], 81 freqidCol(irow), timeSec[irow], elevation[irow], specCol(irow)); 82 iter.next(); 83 continue; 84 } 85 86 uInt nchan = scantable_->nchan(scantable_->getIF(rows[0])); 87 Vector<uChar> flag(nchan); 88 Vector<Bool> bflag(nchan); 89 Vector<Float> spec(nchan); 90 91 Vector<Double> timeSep(len); 92 for (uInt i = 0; i < len-1; i++) { 93 timeSep[i] = timeSec[rows[i+1]] - timeSec[rows[i]] ; 94 } 95 Double tMedian = median(timeSep(IPosition(1,0), IPosition(1,len-2))); 96 timeSep[len-1] = tMedian * 10000.0 ; // any large value 97 98 uInt irow ; 99 uInt jrow ; 100 for (uInt i = 0; i < len; i++) { 101 //os_ << "start row " << rows[i] << LogIO::POST; 102 irow = rows[i]; 103 jrow = (i < len-1) ? rows[i+1] : rows[i]; 104 // accumulate data 105 flagCol.get(irow, flag); 106 convertArray(bflag, flag); 107 specCol.get(irow, spec); 108 if ( !allEQ(bflag,True) ) 109 acc.add( spec, !bflag, tsys, intervalSec[irow], timeSec[irow] ) ; 110 timeCen += timeSec[irow]; 111 elCen += elevation[irow]; 112 count++; 113 114 // check time gap 115 double gap = 2.0 * timeSep[i] / (intervalSec[jrow] + intervalSec[irow]); 116 if ( gap > 1.1 ) { 117 if ( acc.state() ) { 118 acc.replaceNaN() ; 119 // const Vector<Bool> &msk = acc.getMask(); 120 // convertArray(flag, !msk); 121 // for (uInt k = 0; k < nchan; ++k) { 122 // uChar userFlag = 1 << 7; 123 // if (msk[k]==True) userFlag = 0 << 7; 124 // flag(k) = userFlag; 125 // } 126 timeCen /= (Double)count * 86400.0; // sec->day 127 elCen /= (Float)count; 128 appenddata(0, 0, current[2], current[0], current[1], 129 freqidCol(irow), timeCen, elCen, acc.getSpectrum()); 130 } 131 acc.reset() ; 132 timeCen = 0.0; 133 elCen = 0.0; 134 count = 0; 135 } 136 } 137 138 iter.next() ; 139 //os_ << "end " << current << LogIO::POST; 140 } 35 141 } 142 143 } -
trunk/src/STCalibration.h
r2786 r2915 35 35 class STCalibration { 36 36 public: 37 STCalibration(casa::CountedPtr<Scantable> &s );37 STCalibration(casa::CountedPtr<Scantable> &s, const casa::String target_column); 38 38 39 39 void calibrate(); … … 49 49 protected: 50 50 virtual void setupSelector(const STSelector &sel) = 0; 51 virtual void fillCalTable() = 0; 51 virtual void fillCalTable(); 52 virtual void appenddata(casa::uInt scanno, casa::uInt cycleno, 53 casa::uInt beamno, casa::uInt ifno, casa::uInt polno, 54 casa::uInt freqid, casa::Double time, casa::Float elevation, 55 casa::Vector<casa::Float> any_data) = 0; 52 56 53 57 STSelector sel_; … … 56 60 casa::LogIO os_; 57 61 casa::Record options_; 62 const casa::String target_column_; 58 63 }; 59 64 60 65 } 61 66 #endif
Note:
See TracChangeset
for help on using the changeset viewer.