LCOV - code coverage report
Current view: top level - alma/ASDMBinaries - Integration.cc (source / functions) Hit Total Coverage
Test: casacpp_coverage.info Lines: 255 1032 24.7 %
Date: 2024-12-11 20:54:31 Functions: 29 87 33.3 %

          Line data    Source code
       1             : #include <sstream>
       2             : #include <iostream>
       3             : #include <stdlib.h> // for atoi()
       4             : #include <stdint.h>
       5             : 
       6             : #include <alma/ASDMBinaries/Integration.h>
       7             : #include <alma/ASDMBinaries/Error.h>
       8             : 
       9             : using namespace sdmbin;
      10             : using namespace std;
      11             : 
      12             : using namespace AxisNameMod;
      13             : using namespace CorrelationModeMod;
      14             : using namespace NetSidebandMod;
      15             : 
      16             : namespace sdmbin{
      17             : // ============================================================================================
      18             : // DataStructure: the base
      19             : // ============================================================================================
      20             : 
      21           0 :   DataStructure::DataStructure()
      22             :   {
      23           0 :   }
      24             : 
      25           0 :   DataStructure::DataStructure(  uint32_t      numPolProduct, 
      26             :                                  uint32_t      numBin,
      27             :                                  Enum<NetSideband> e_sideband,            
      28             :                                  uint32_t      numBaseband,   
      29             :                                  uint32_t      numAnt,
      30             :                                  CorrelationMode   correlationMode 
      31           0 :                                  )
      32             :   {
      33           0 :     v_numSpectralWindow_.resize(0); 
      34           0 :     vv_numAutoPolProduct_.resize(numBaseband);
      35           0 :     vv_numSpectralPoint_.resize(numBaseband);
      36           0 :     vv_numBin_.resize(numBaseband);
      37           0 :     vv_e_sideband_.resize(numBaseband);
      38           0 :     for(uint32_t nbb=0; nbb<numBaseband; nbb++){
      39           0 :       v_numSpectralWindow_.push_back(1);
      40           0 :       for(uint32_t nspw=0; nspw<numBaseband; nspw++){
      41           0 :         vv_numAutoPolProduct_[nbb].push_back(numPolProduct);
      42           0 :         vv_numSpectralPoint_[nbb].push_back(1);
      43           0 :         vv_numBin_[nbb].push_back(numBin);
      44           0 :         vv_e_sideband_[nbb].push_back(e_sideband);
      45             :       }
      46             :     }
      47           0 :     numApc_          = 1;
      48           0 :     numBaseband_     = numBaseband;
      49           0 :     numAnt_          = numAnt;
      50           0 :     correlationMode_ = correlationMode;
      51           0 :     axisSequence_    = setStructureProperties();
      52           0 :   }
      53             : 
      54           0 :   DataStructure::DataStructure(  uint32_t      numPolProduct,
      55             :                                  uint32_t      numSpectralPoint,
      56             :                                  uint32_t      numBin,
      57             :                                  Enum<NetSideband> e_sideband,
      58             :                                  uint32_t      numBaseband,
      59             :                                  uint32_t      numAnt,
      60           0 :                                  CorrelationMode   correlationMode)
      61             :   {
      62           0 :     v_numSpectralWindow_.resize(0); 
      63           0 :     vv_numAutoPolProduct_.resize(numBaseband);
      64           0 :     vv_numSpectralPoint_.resize(numSpectralPoint);
      65           0 :     vv_numBin_.resize(numBaseband);
      66           0 :     vv_e_sideband_.resize(numBaseband);
      67           0 :     for(uint32_t nbb=0; nbb<numBaseband; nbb++){
      68           0 :       v_numSpectralWindow_.push_back(1);
      69           0 :       for(uint32_t nspw=0; nspw<numBaseband; nspw++){
      70           0 :         vv_numAutoPolProduct_[nbb].push_back(numPolProduct);
      71           0 :         vv_numSpectralPoint_[nbb].push_back(1);
      72           0 :         vv_numBin_[nbb].push_back(numBin);
      73           0 :         vv_e_sideband_[nbb].push_back(e_sideband);
      74             :       }
      75             :     }
      76           0 :     numAnt_          = numAnt;
      77           0 :     numApc_          = 1;
      78           0 :     numBaseband_     = numBaseband;
      79           0 :     correlationMode_ = correlationMode;
      80           0 :     axisSequence_    = setStructureProperties();
      81           0 :   }
      82             : 
      83       22865 :   DataStructure::DataStructure( vector<vector<uint32_t> >       vv_numCrossPolProduct,// /bb/spw
      84             :                                 vector<vector<uint32_t> >       vv_numAutoPolProduct, // /bb/spw
      85             :                                 vector<vector<uint32_t> >       vv_numSpectralPoint,  // /bb/spw
      86             :                                 vector<vector<uint32_t> >       vv_numBin,            // /bb/spw
      87             :                                 vector<vector<Enum<NetSideband> > > vv_e_sideband,        // /bb/spw
      88             :                                 uint32_t                        numApc,
      89             :                                 vector<uint32_t>                v_numSpectralWindow,  // /bb
      90             :                                 uint32_t                        numBaseband,
      91             :                                 uint32_t                        numAnt,
      92       22865 :                                 CorrelationMode                     correlationMode):
      93       22865 :     vv_numCrossPolProduct_(vv_numCrossPolProduct),
      94       22865 :     vv_numAutoPolProduct_(vv_numAutoPolProduct),
      95       22865 :     vv_numSpectralPoint_(vv_numSpectralPoint),
      96       22865 :     vv_numBin_(vv_numBin),
      97       22865 :     vv_e_sideband_(vv_e_sideband),
      98       22865 :     numApc_(numApc),
      99       22865 :     v_numSpectralWindow_(v_numSpectralWindow),
     100       22865 :     numBaseband_(numBaseband),
     101       22865 :     numAnt_(numAnt),
     102       22865 :     correlationMode_(correlationMode)
     103             :   {
     104       22865 :     axisSequence_ = setStructureProperties();
     105       22865 :   }
     106             : 
     107           0 :   DataStructure::DataStructure( vector<vector<uint32_t> >       vv_numAutoPolProduct, // /bb/spw
     108             :                                 vector<vector<uint32_t> >       vv_numSpectralPoint,  // /bb/spw
     109             :                                 vector<vector<uint32_t> >       vv_numBin,            // /bb/spw
     110             :                                 vector<vector<Enum<NetSideband> > > vv_e_sideband,        // /bb/spw
     111             :                                 uint32_t                        numApc,
     112             :                                 vector<uint32_t>                v_numSpectralWindow,  // /bb
     113             :                                 uint32_t                        numBaseband,
     114             :                                 uint32_t                        numAnt,
     115           0 :                                 CorrelationMode                     correlationMode):
     116           0 :     vv_numAutoPolProduct_(vv_numAutoPolProduct),
     117           0 :     vv_numSpectralPoint_(vv_numSpectralPoint),
     118           0 :     vv_numBin_(vv_numBin),
     119           0 :     vv_e_sideband_(vv_e_sideband),
     120           0 :     numApc_(numApc),
     121           0 :     v_numSpectralWindow_(v_numSpectralWindow),
     122           0 :     numBaseband_(numBaseband),
     123           0 :     numAnt_(numAnt),
     124           0 :     correlationMode_(correlationMode)
     125             :   {
     126           0 :     vv_numCrossPolProduct_.clear();
     127           0 :     axisSequence_ = setStructureProperties();
     128           0 :   }
     129             : 
     130           0 :   DataStructure::DataStructure( const DataStructure & a)
     131             :   {
     132           0 :     vv_numCrossPolProduct_ = a.vv_numCrossPolProduct_;
     133           0 :     vv_numAutoPolProduct_  = a.vv_numAutoPolProduct_;
     134           0 :     vv_numSpectralPoint_   = a.vv_numSpectralPoint_;
     135           0 :     vv_numBin_             = a.vv_numBin_;
     136           0 :     vv_e_sideband_         = a.vv_e_sideband_;
     137           0 :     numApc_                = a.numApc_;
     138           0 :     v_numSpectralWindow_   = a.v_numSpectralWindow_;
     139           0 :     numBaseband_           = a.numBaseband_;
     140           0 :     numAnt_                = a.numAnt_;
     141           0 :     correlationMode_       = a.correlationMode_;
     142           0 :     axisSequence_          = a.axisSequence_;
     143           0 :     v_minSize_             = a.v_minSize_;
     144           0 :     v_maxSize_             = a.v_maxSize_;
     145           0 :   }
     146             : 
     147       22865 :   DataStructure::~DataStructure()
     148             :   {
     149       22865 :   }
     150             : 
     151       22865 :   string DataStructure::setStructureProperties()
     152             :   {
     153             :     uint32_t  minSize,maxSize;
     154             :     bool          newLevel;
     155       22865 :     ostringstream axisSequence;
     156             :   
     157       22865 :     newLevel = false;
     158       22865 :     minSize  = 100000;
     159       22865 :     maxSize  = 0;
     160       22865 :     if(vv_numAutoPolProduct_.size()){
     161       67382 :       for(uint32_t nbb=0; nbb<numBaseband_; nbb++){
     162      105188 :         for(uint32_t nspw=0; nspw<v_numSpectralWindow_[nbb]; nspw++){
     163       60559 :           if(vv_numAutoPolProduct_[nbb][nspw]<minSize)minSize=vv_numAutoPolProduct_[nbb][nspw];
     164       60559 :           if(vv_numAutoPolProduct_[nbb][nspw]>maxSize)maxSize=vv_numAutoPolProduct_[nbb][nspw];
     165       60559 :           if(vv_numAutoPolProduct_[nbb][nspw]>1)newLevel=true;
     166             :         }
     167             :       }
     168             :     }
     169       22865 :     if(vv_numCrossPolProduct_.size()){
     170       50324 :       for(uint32_t nbb=0; nbb<numBaseband_; nbb++){
     171       82670 :         for(uint32_t nspw=0; nspw<v_numSpectralWindow_[nbb]; nspw++){
     172       49300 :           if(vv_numCrossPolProduct_[nbb][nspw]<minSize)minSize=vv_numCrossPolProduct_[nbb][nspw];
     173       49300 :           if(vv_numCrossPolProduct_[nbb][nspw]>maxSize)maxSize=vv_numCrossPolProduct_[nbb][nspw];
     174       49300 :           if(vv_numCrossPolProduct_[nbb][nspw]>1)newLevel=true;
     175             :         }
     176             :       }
     177             :     }
     178       22865 :     if( newLevel ){
     179       10446 :       v_minSize_.push_back(minSize);
     180       10446 :       v_maxSize_.push_back(maxSize);
     181       10446 :       axisSequence << "1";
     182             :     }
     183             : 
     184       22865 :     newLevel=false;
     185       22865 :     minSize  = 1000000;
     186       22865 :     maxSize  = 0;
     187       67606 :     for(uint32_t nbb=0; nbb<numBaseband_; nbb++){
     188      105412 :       for(uint32_t nspw=0; nspw<v_numSpectralWindow_[nbb]; nspw++){
     189       60671 :         if(vv_numSpectralPoint_[nbb][nspw]<minSize)minSize=vv_numSpectralPoint_[nbb][nspw];
     190       60671 :         if(vv_numSpectralPoint_[nbb][nspw]>maxSize)maxSize=vv_numSpectralPoint_[nbb][nspw];
     191       60671 :         if(vv_numSpectralPoint_[nbb][nspw]>1)newLevel=true;
     192             :       }
     193             :     }
     194       22865 :     if( newLevel ){
     195       11505 :       v_minSize_.push_back(minSize);
     196       11505 :       v_maxSize_.push_back(maxSize);
     197       11505 :       axisSequence << "2";
     198             :     }
     199             : 
     200       22865 :     if( numApc_>1 ){
     201           0 :       v_minSize_.push_back(numApc_);
     202           0 :       v_maxSize_.push_back(numApc_);
     203           0 :       axisSequence << "3";
     204             :     }
     205             : 
     206       22865 :     newLevel=false;
     207       22865 :     minSize  = 100000;
     208       22865 :     maxSize  = 0;
     209       67606 :     for(uint32_t nbb=0; nbb<numBaseband_; nbb++){
     210      105412 :       for(uint32_t nspw=0; nspw<v_numSpectralWindow_[nbb]; nspw++){
     211       60671 :         if(vv_numBin_[nbb][nspw]<minSize)minSize=vv_numBin_[nbb][nspw];
     212       60671 :         if(vv_numBin_[nbb][nspw]>maxSize)maxSize=vv_numBin_[nbb][nspw];
     213       60671 :         if(vv_numBin_[nbb][nspw]>1)newLevel=true;
     214             :       }
     215             :     }
     216       22865 :     if( newLevel ){
     217           0 :       v_minSize_.push_back(minSize);
     218           0 :       v_maxSize_.push_back(maxSize);
     219           0 :       axisSequence << "4";
     220             :     }
     221             : 
     222       22865 :     newLevel=false;
     223       22865 :     minSize  = 100000;
     224       22865 :     maxSize  = 0;
     225       67606 :     for(uint32_t nbb=0; nbb<numBaseband_; nbb++){
     226       44741 :       if(v_numSpectralWindow_[nbb]<minSize)minSize=v_numSpectralWindow_[nbb];
     227       44741 :       if(v_numSpectralWindow_[nbb]>maxSize)maxSize=v_numSpectralWindow_[nbb];
     228       44741 :       if(v_numSpectralWindow_[nbb]>1)newLevel=true;
     229             :     }
     230       22865 :     if( newLevel ){
     231         354 :       v_minSize_.push_back(minSize);
     232         354 :       v_maxSize_.push_back(maxSize);
     233         354 :       axisSequence << "5";
     234             :     }
     235             : 
     236       22865 :     if( numBaseband_>1 ){
     237        7934 :       v_minSize_.push_back(numBaseband_);
     238        7934 :       v_maxSize_.push_back(numBaseband_);
     239        7934 :       axisSequence << "6";
     240             :     }
     241             : 
     242       22865 :     if(correlationMode_!=AUTO_ONLY){
     243       16954 :       v_minSize_.push_back(numAnt_);
     244       16954 :       v_maxSize_.push_back(numAnt_);
     245       16954 :       axisSequence << "7";
     246             :     }
     247             : 
     248       22865 :     if(correlationMode_!=CROSS_ONLY){
     249       22753 :       v_minSize_.push_back(numAnt_);
     250       22753 :       v_maxSize_.push_back(numAnt_);
     251       22753 :       axisSequence << "8";
     252             :     }
     253             : 
     254       45730 :     return axisSequence.str();
     255             : 
     256       22865 :   }
     257             : 
     258           0 :   vector<vector<uint32_t> >       DataStructure::numCrossPolProducts(){ return vv_numCrossPolProduct_; }
     259             : 
     260           0 :   vector<vector<uint32_t> >       DataStructure::numAutoPolProducts() { return vv_numAutoPolProduct_;  }
     261             : 
     262           0 :   vector<vector<uint32_t> >       DataStructure::numSpectralPoints()  { return vv_numSpectralPoint_;   }
     263             : 
     264           0 :   vector<vector<uint32_t> >       DataStructure::numBins()            { return vv_numBin_;             }
     265             : 
     266           0 :   vector<vector<Enum<NetSideband> > > DataStructure::sidebands()          { return vv_e_sideband_;         }
     267             : 
     268           0 :   uint32_t                        DataStructure::numApc()             { return numApc_;                }
     269             : 
     270           0 :   vector<uint32_t>                DataStructure::numSpectralWindows() { return v_numSpectralWindow_;   }
     271             : 
     272           0 :   uint32_t                        DataStructure::numBaseband()        { return numBaseband_;           }
     273             : 
     274           0 :   uint32_t                        DataStructure::numAnt()             { return  numAnt_;               }
     275             : 
     276           0 :   CorrelationMode                     DataStructure::correlationMode()    { return correlationMode_;       }
     277             : 
     278             : 
     279           0 :   vector<uint32_t> DataStructure::leafAxisSizes(){
     280           0 :     if(!isIndexible()){
     281           0 :       vector<uint32_t> las;
     282           0 :       return las;
     283           0 :     }
     284           0 :     return leafAxisSizes(0,0);
     285             :   }
     286             : 
     287           0 :   vector<uint32_t> DataStructure::leafAxisSizes(uint32_t basebandIndex, uint32_t spectralWindowIndex){
     288           0 :     vector<uint32_t> las;
     289           0 :     if(vv_numBin_[basebandIndex][spectralWindowIndex]!=1)
     290           0 :       las.push_back(vv_numBin_[basebandIndex][spectralWindowIndex]);
     291           0 :     if(numApc_!=1)
     292           0 :       las.push_back(numApc_);
     293           0 :     if(vv_numSpectralPoint_[basebandIndex][spectralWindowIndex]!=1)
     294           0 :       las.push_back(vv_numSpectralPoint_[basebandIndex][spectralWindowIndex]);
     295           0 :     if(vv_numAutoPolProduct_[basebandIndex][spectralWindowIndex]!=1)
     296           0 :       las.push_back(vv_numAutoPolProduct_[basebandIndex][spectralWindowIndex]);
     297           0 :     return las;
     298           0 :   }
     299             : 
     300           0 :   vector<uint32_t> DataStructure::leafAxisSizes(uint32_t ndd){
     301           0 :     vector<uint32_t> las;
     302           0 :     if(ndd==0){
     303           0 :       return leafAxisSizes(0,0);
     304             :     }else{
     305           0 :       uint32_t k=0;
     306             :       uint32_t nb;
     307           0 :       uint32_t nspw=0;
     308           0 :       for(nb=0; nb<numBaseband_; nb++){
     309           0 :         for(nspw=0; nspw<v_numSpectralWindow_[nb]; nspw++){
     310           0 :           if(k==ndd)break;
     311           0 :           k++;
     312             :         }
     313             :       }
     314           0 :       return leafAxisSizes(nb,nspw);
     315             :     }
     316           0 :   }
     317             : 
     318             : 
     319           0 :   uint32_t DataStructure::isIndexible() const
     320             :   {
     321           0 :     uint32_t multidim=0;
     322           0 :     for(uint32_t n=0; n<v_minSize_.size(); n++)
     323           0 :       if(v_minSize_[n]==v_maxSize_[n])multidim++;
     324           0 :     if(multidim==v_minSize_.size())return multidim;
     325           0 :     return 0;
     326             :   }
     327             : 
     328             :   // todo
     329           0 :   vector<uint32_t> DataStructure::eAxisSizes() const
     330             :   {
     331           0 :     vector<uint32_t> v_size;
     332           0 :     if(!isIndexible())return v_size;         // 
     333             :     // 12345678 
     334             :     //v_size.push_back(vv_numCrossPolProduct_[0][0]);
     335           0 :     v_size.push_back(vv_numAutoPolProduct_[0][0]);
     336           0 :     v_size.push_back(vv_numSpectralPoint_[0][0]);
     337           0 :     v_size.push_back(numApc_);
     338           0 :     v_size.push_back(vv_numBin_[0][0]);
     339           0 :     v_size.push_back(v_numSpectralWindow_[0]);
     340           0 :     v_size.push_back(numBaseband_);
     341           0 :     if(correlationMode_!=AUTO_ONLY) v_size.push_back((numAnt_*(numAnt_-1))/2); 
     342           0 :     if(correlationMode_!=CROSS_ONLY)v_size.push_back(numAnt_);
     343           0 :     return v_size;
     344           0 :   }
     345             : 
     346             :   // todo
     347           0 :   vector<uint32_t> DataStructure::axisSizes() const
     348             :   {
     349           0 :     vector<uint32_t> v_size;
     350           0 :     for(uint32_t n=0; n<v_minSize_.size(); n++)
     351           0 :       if(v_minSize_[n]==v_maxSize_[n])v_size.push_back(v_minSize_[n]);     
     352           0 :     return v_size;
     353           0 :   }
     354             : 
     355           0 :   uint32_t DataStructure::dimension() const
     356             :   {
     357           0 :     return (uint32_t)axisSequence_.length();
     358             :   }
     359             : 
     360           0 :   vector<uint32_t> DataStructure::minAxSize() const
     361             :   {
     362           0 :     return v_minSize_;
     363             :   }
     364             : 
     365           0 :   vector<uint32_t> DataStructure::maxAxSize() const
     366             :   {
     367           0 :     return v_maxSize_;
     368             :   }
     369             : 
     370           0 :   uint32_t DataStructure::numCrossData() const
     371             :   {
     372           0 :     uint32_t numCrossData = 1;
     373           0 :     for(uint32_t nbb=0; nbb<numBaseband_; nbb++){
     374           0 :       for(uint32_t nspw=0; nspw<v_numSpectralWindow_[nbb]; nspw++){
     375           0 :         numCrossData *= 
     376           0 :           vv_numBin_[nbb][nspw] *
     377           0 :           vv_numSpectralPoint_[nbb][nspw] *
     378           0 :           vv_numCrossPolProduct_[nbb][nspw]; 
     379             :       }
     380             :     }
     381           0 :     return numCrossData;
     382             :   }
     383             : 
     384           0 :   uint32_t DataStructure::numAutoData() const
     385             :   {
     386           0 :     uint32_t numAutoData = 1;
     387           0 :     for(uint32_t nbb=0; nbb<numBaseband_; nbb++){
     388           0 :       for(uint32_t nspw=0; nspw<v_numSpectralWindow_[nbb]; nspw++){
     389           0 :         numAutoData *= 
     390           0 :           vv_numBin_[nbb][nspw] *
     391           0 :           vv_numSpectralPoint_[nbb][nspw] *
     392           0 :           vv_numAutoPolProduct_[nbb][nspw]; 
     393             :       }
     394             :     }
     395             : 
     396             :     //   if( numBaseline_>1 ){
     397             :     //     v_minSize_.push_back(numBaseline_);
     398             :     //     v_maxSize_.push_back(numBaseline_);
     399             :     //     axisSequence << "7";
     400             :     //   }
     401             :     //   numData *= numApc_*numAnt_;         // for total power only!
     402             : 
     403           0 :     return numAutoData;
     404             :   }
     405             : 
     406           0 :   string DataStructure::axisSequence() const
     407             :   {
     408           0 :     return axisSequence_;
     409             :   }
     410             : 
     411           0 :   void DataStructure::summary() const
     412             :   {
     413           0 :     cout<<"Data for "<<numAnt_<<" antenna."<<endl;
     414           0 :     for(uint32_t nbb=0; nbb<numBaseband_; nbb++){
     415           0 :       cout<<"  Baseband "<<nbb+1
     416           0 :           <<" has "<<v_numSpectralWindow_[nbb]
     417           0 :           <<" spectral windows."<<endl;
     418           0 :       for(uint32_t nspw=0; nspw<v_numSpectralWindow_[nbb]; nspw++){
     419           0 :         cout<<"    Spectral window "<<nspw+1
     420           0 :             <<"  num spectral points: "<<vv_numSpectralPoint_[nbb][nspw]
     421           0 :             <<"  num bins: "<<vv_numBin_[nbb][nspw];
     422           0 :         if(vv_numAutoPolProduct_.size())
     423           0 :           if(vv_numAutoPolProduct_[nbb].size())
     424           0 :             cout<<"  num sd pol.: "<<vv_numAutoPolProduct_[nbb][nspw];
     425           0 :         if(vv_numCrossPolProduct_.size())
     426           0 :           if(vv_numCrossPolProduct_[nbb].size())
     427           0 :             cout<<"  num cross pol.: "<<vv_numCrossPolProduct_[nbb][nspw];
     428           0 :         cout<<endl;
     429             :       }
     430             :     }
     431           0 :     uint32_t multidim = isIndexible();
     432           0 :     if( multidim ){
     433           0 :       cout<<"The data structure is  multi-dimensional with the dimensionality "
     434           0 :           <<multidim<<endl;
     435           0 :       cout<<"  axis order: "<<axisSequence_<<endl;
     436           0 :       vector<uint32_t>v_size=axisSizes();
     437           0 :       ostringstream os; 
     438           0 :       for(uint32_t n=0; n<v_size.size()-1; n++)os<<v_size[n]<<",";
     439           0 :       os<<v_size[v_size.size()-1];
     440           0 :       cout<<"  axis sizes: "<<os.str()<<endl;;
     441           0 :     }
     442           0 :   }
     443             : 
     444             :   // ============================================================================================
     445             :   // DataDump -> DataStructure
     446             :   // ============================================================================================
     447             : 
     448           0 :   DataDump::DataDump()
     449             :   {
     450             :     //cout<<"Default constructor DataDump"<<endl;
     451           0 :   }
     452             : 
     453           0 :   DataDump::DataDump( uint32_t      numPolProduct,
     454             :                       uint32_t      numBin,
     455             :                       Enum<NetSideband> e_sideband,
     456             :                       uint32_t      numBaseband,
     457             :                       uint32_t      numAnt,
     458             :                       CorrelationMode   correlationMode,
     459             :                       uint64_t         time,
     460             :                       uint64_t         timeCentroid,
     461             :                       uint64_t         interval, 
     462             :                       uint64_t         exposure, 
     463           0 :                       const float*      floatData):
     464             :     DataStructure( numPolProduct,
     465             :                    numBin,
     466             :                    e_sideband,
     467             :                    numBaseband,
     468             :                    numAnt,
     469             :                    correlationMode),
     470           0 :     cuintFlagsPtr_(NULL),
     471           0 :     clonlonActualTimesPtr_(NULL),
     472           0 :     clonlonActualDurationsPtr_(NULL),
     473           0 :     cfloatWeightsPtr_(NULL),
     474           0 :     cfloatZeroLagsPtr_(NULL),
     475           0 :     cfloatAutoDataPtr_(floatData),
     476           0 :     cshortCrossDataPtr_(NULL),
     477           0 :     cintCrossDataPtr_(NULL),
     478           0 :     cfloatCrossDataPtr_(NULL)
     479             :   {
     480           0 :     integrationNum_    = 0;
     481           0 :     subintegrationNum_ = 0;
     482           0 :     time_         = time;
     483           0 :     timeCentroid_ = timeCentroid;
     484           0 :     interval_     = interval;
     485           0 :     exposure_     = exposure;
     486             : 
     487           0 :     uintFlagsPtr_             = NULL;
     488           0 :     lonlonActualTimesPtr_     = NULL;
     489           0 :     lonlonActualDurationsPtr_ = NULL;
     490           0 :     floatWeightsPtr_          = NULL;
     491           0 :     floatZeroLagsPtr_         = NULL;
     492           0 :     floatAutoDataPtr_         = NULL;
     493           0 :     shortCrossDataPtr_        = NULL;
     494           0 :     intCrossDataPtr_          = NULL;
     495           0 :     floatCrossDataPtr_        = NULL;
     496             : 
     497           0 :   }
     498             : 
     499             : 
     500           0 :   DataDump::DataDump( uint32_t      numPolProduct,
     501             :                       uint32_t      numSpectralPoint,
     502             :                       uint32_t      numBin,
     503             :                       Enum<NetSideband> e_sideband,
     504             :                       uint32_t      numBaseband,
     505             :                       uint32_t      numAnt,
     506             :                       CorrelationMode   correlationMode,
     507             :                       uint64_t         time,
     508             :                       uint64_t         timeCentroid, 
     509             :                       uint64_t         interval,
     510             :                       uint64_t         exposure,
     511             :                       const float*             floatData, 
     512           0 :                       const uint32_t* dataFlags):
     513             :     DataStructure( numPolProduct,
     514             :                    numSpectralPoint,
     515             :                    numBin,
     516             :                    e_sideband,
     517             :                    numBaseband,
     518             :                    numAnt,
     519             :                    correlationMode),
     520           0 :     cuintFlagsPtr_(dataFlags),
     521           0 :     clonlonActualTimesPtr_(NULL),
     522           0 :     clonlonActualDurationsPtr_(NULL),
     523           0 :     cfloatWeightsPtr_(NULL),
     524           0 :     cfloatZeroLagsPtr_(NULL),
     525           0 :     cfloatAutoDataPtr_(floatData),
     526           0 :     cshortCrossDataPtr_(NULL),
     527           0 :     cintCrossDataPtr_(NULL),
     528           0 :     cfloatCrossDataPtr_(NULL)
     529             :   {   
     530           0 :     integrationNum_    = 0;
     531           0 :     subintegrationNum_ = 0;
     532           0 :     time_              = time;
     533           0 :     timeCentroid_      = timeCentroid;  cout<<"timeCentroid="<<timeCentroid<<endl;
     534           0 :     interval_          = interval;       
     535           0 :     exposure_          = exposure;
     536             : 
     537           0 :     uintFlagsPtr_             = NULL;
     538           0 :     lonlonActualTimesPtr_     = NULL;
     539           0 :     lonlonActualDurationsPtr_ = NULL;
     540           0 :     floatWeightsPtr_          = NULL;
     541           0 :     floatZeroLagsPtr_         = NULL;
     542           0 :     floatAutoDataPtr_         = NULL;
     543           0 :     shortCrossDataPtr_        = NULL;
     544           0 :     intCrossDataPtr_          = NULL;
     545           0 :     floatCrossDataPtr_        = NULL;
     546           0 :   }
     547             : 
     548           0 :   DataDump::DataDump( vector<vector<uint32_t> >       vv_numAutoPolProduct, // /bb/spw
     549             :                       vector<vector<uint32_t> >       vv_numSpectralPoint,  // /bb/spw
     550             :                       vector<vector<uint32_t> >       vv_numBin,            // /bb/spw
     551             :                       vector<vector<Enum<NetSideband> > > vv_e_sideband,        // /bb/spw
     552             :                       uint32_t                        numApc,
     553             :                       vector<uint32_t>                v_numSpectralWindow,  // /bb
     554             :                       uint32_t                        numBaseband,
     555             :                       uint32_t                        numAnt,
     556             :                       CorrelationMode                     correlationMode,
     557             :                       uint64_t                           time,
     558             :                       uint64_t                           timeCentroid,  
     559             :                       uint64_t                           interval,
     560             :                       uint64_t                           exposure,  
     561             :                       const float*                        floatData, 
     562           0 :                       const uint32_t*                 dataFlags):
     563             :     DataStructure( vv_numAutoPolProduct,
     564             :                    vv_numSpectralPoint,
     565             :                    vv_numBin,
     566             :                    vv_e_sideband,
     567             :                    numApc,
     568             :                    v_numSpectralWindow,
     569             :                    numBaseband,
     570             :                    numAnt,
     571             :                    correlationMode),
     572           0 :     integrationNum_(0),
     573           0 :     subintegrationNum_(0),
     574           0 :     time_(time),
     575           0 :     timeCentroid_(timeCentroid),
     576           0 :     interval_(interval),
     577           0 :     exposure_(exposure),
     578           0 :     cuintFlagsPtr_(dataFlags),
     579           0 :     clonlonActualTimesPtr_(NULL),
     580           0 :     clonlonActualDurationsPtr_(NULL),
     581           0 :     cfloatWeightsPtr_(NULL),
     582           0 :     cfloatZeroLagsPtr_(NULL),
     583           0 :     cfloatAutoDataPtr_(floatData),
     584           0 :     cshortCrossDataPtr_(NULL),
     585           0 :     cintCrossDataPtr_(NULL),
     586           0 :     cfloatCrossDataPtr_(NULL)
     587             :   {
     588           0 :     uintFlagsPtr_             = NULL;
     589           0 :     lonlonActualTimesPtr_     = NULL;
     590           0 :     lonlonActualDurationsPtr_ = NULL;
     591           0 :     floatWeightsPtr_          = NULL;
     592           0 :     floatZeroLagsPtr_         = NULL;
     593           0 :     floatAutoDataPtr_         = NULL;
     594           0 :     shortCrossDataPtr_        = NULL;
     595           0 :     intCrossDataPtr_          = NULL;
     596           0 :     floatCrossDataPtr_        = NULL;
     597           0 :   }
     598             : 
     599           0 :   DataDump::DataDump( vector<vector<uint32_t> >       vv_numAutoPolProduct, // /bb/spw
     600             :                       vector<vector<uint32_t> >       vv_numSpectralPoint,  // /bb/spw
     601             :                       vector<vector<uint32_t> >       vv_numBin,            // /bb/spw
     602             :                       vector<vector<Enum<NetSideband> > > vv_e_sideband,        // /bb/spw
     603             :                       uint32_t                        numApc,
     604             :                       vector<uint32_t>                v_numSpectralWindow,  // /bb
     605             :                       uint32_t                        numBaseband,
     606             :                       uint32_t                        numAnt,
     607             :                       CorrelationMode                     correlationMode,
     608             :                       uint64_t                           time,
     609             :                       uint64_t                           timeCentroid,  
     610             :                       uint64_t                           interval,
     611             :                       uint64_t                           exposure,  
     612           0 :                       const float*                        floatData):
     613             :     DataStructure( vv_numAutoPolProduct,    
     614             :                    vv_numSpectralPoint,
     615             :                    vv_numBin,
     616             :                    vv_e_sideband,
     617             :                    numApc,
     618             :                    v_numSpectralWindow,
     619             :                    numBaseband,
     620             :                    numAnt,
     621             :                    correlationMode),
     622           0 :     integrationNum_(0),
     623           0 :     subintegrationNum_(0),
     624           0 :     time_(time),
     625           0 :     timeCentroid_(timeCentroid),
     626           0 :     interval_(interval),
     627           0 :     exposure_(exposure),
     628           0 :     cuintFlagsPtr_(NULL),
     629           0 :     clonlonActualTimesPtr_(NULL),
     630           0 :     clonlonActualDurationsPtr_(NULL),
     631           0 :     cfloatWeightsPtr_(NULL),
     632           0 :     cfloatZeroLagsPtr_(NULL),
     633           0 :     cfloatAutoDataPtr_(floatData),
     634           0 :     cshortCrossDataPtr_(NULL),
     635           0 :     cintCrossDataPtr_(NULL),
     636           0 :     cfloatCrossDataPtr_(NULL)
     637             :   {
     638           0 :     uintFlagsPtr_             = NULL;
     639           0 :     lonlonActualTimesPtr_     = NULL;
     640           0 :     lonlonActualDurationsPtr_ = NULL;
     641           0 :     floatWeightsPtr_          = NULL;
     642           0 :     floatZeroLagsPtr_         = NULL;
     643           0 :     floatAutoDataPtr_         = NULL;
     644           0 :     shortCrossDataPtr_        = NULL;
     645           0 :     intCrossDataPtr_          = NULL;
     646           0 :     floatCrossDataPtr_        = NULL;
     647           0 :   }
     648             : 
     649       22865 :   DataDump::DataDump( vector<vector<uint32_t> >       vv_numCrossPolProduct,// /bb/spw
     650             :                       vector<vector<uint32_t> >       vv_numAutoPolProduct, // /bb/spw
     651             :                       vector<vector<uint32_t> >       vv_numSpectralPoint,  // /bb/spw
     652             :                       vector<vector<uint32_t> >       vv_numBin,            // /bb/spw
     653             :                       vector<vector<Enum<NetSideband> > > vv_e_sideband,        // /bb/spw
     654             :                       uint32_t                        numApc,
     655             :                       vector<uint32_t>                v_numSpectralWindow,  // /bb
     656             :                       uint32_t                        numBaseband,
     657             :                       uint32_t                        numAnt,
     658             :                       CorrelationMode                     correlationMode,
     659             :                       uint64_t                           time,
     660             :                       uint64_t                           timeCentroid,  
     661             :                       uint64_t                           interval, 
     662       22865 :                       uint64_t                           exposure):
     663             :     DataStructure( vv_numCrossPolProduct,
     664             :                    vv_numAutoPolProduct,
     665             :                    vv_numSpectralPoint,
     666             :                    vv_numBin,
     667             :                    vv_e_sideband,
     668             :                    numApc,
     669             :                    v_numSpectralWindow,
     670             :                    numBaseband,
     671             :                    numAnt,
     672             :                    correlationMode),
     673       22865 :     integrationNum_(0),
     674       22865 :     subintegrationNum_(0),
     675       22865 :     time_(time),
     676       22865 :     timeCentroid_(timeCentroid),
     677       22865 :     interval_(interval),
     678       22865 :     exposure_(exposure),
     679       22865 :     es_flagsAxes_(), 
     680       22865 :     es_actualTimesAxes_(),   
     681       22865 :     es_actualDurationsAxes_(),   
     682       22865 :     es_weightsAxes_(), 
     683       22865 :     es_zeroLagsAxes_(), 
     684       22865 :     es_autoDataAxes_(), 
     685       22865 :     es_crossDataAxes_(),
     686       22865 :     numFlags_(0),     
     687       22865 :     numActualTimes_(0), 
     688       22865 :     numActualDurations_(0), 
     689       22865 :     numWeights_(0),     
     690       22865 :     numZeroLags_(0),     
     691       22865 :     numAutoData_(0),     
     692       22865 :     numCrossData_(0),
     693       22865 :     cuintFlagsPtr_(NULL),
     694       22865 :     clonlonActualTimesPtr_(NULL),
     695       22865 :     clonlonActualDurationsPtr_(NULL),
     696       22865 :     cfloatWeightsPtr_(NULL),
     697       22865 :     cfloatZeroLagsPtr_(NULL),
     698       22865 :     cfloatAutoDataPtr_(NULL),
     699       22865 :     cshortCrossDataPtr_(NULL),
     700       22865 :     cintCrossDataPtr_(NULL),
     701       45730 :     cfloatCrossDataPtr_(NULL)
     702             :   {
     703             : 
     704             :     // By default the scale factor is set to 1 for all spw. It must be updated subsequently if required
     705             :     // using the method setScaleFactor().
     706       22865 :     if(vv_numCrossPolProduct.size()){
     707       50324 :       for(uint32_t nbb=0; nbb<numBaseband; nbb++){
     708       33370 :         vector<float> v_f;
     709       82670 :         for(uint32_t nspw=0; nspw<vv_numCrossPolProduct[nbb].size(); nspw++)v_f.push_back(1.0);
     710       33370 :         vv_scaleFactor_.push_back(v_f);
     711       33370 :       }
     712             :     }
     713             :                                                                                 
     714       22865 :     uintFlagsPtr_             = NULL;
     715       22865 :     lonlonActualTimesPtr_     = NULL;
     716       22865 :     lonlonActualDurationsPtr_ = NULL;
     717       22865 :     floatWeightsPtr_          = NULL;
     718       22865 :     floatZeroLagsPtr_         = NULL;
     719       22865 :     floatAutoDataPtr_         = NULL;
     720       22865 :     shortCrossDataPtr_        = NULL;
     721       22865 :     intCrossDataPtr_          = NULL;
     722       22865 :     floatCrossDataPtr_        = NULL;
     723             : 
     724       22865 :   }
     725             : 
     726             : 
     727           0 :   DataDump::DataDump( vector<vector<uint32_t> >       vv_numCrossPolProduct,        // /bb/spw
     728             :                       vector<vector<uint32_t> >       vv_numAutoPolProduct, // /bb/spw
     729             :                       vector<vector<uint32_t> >       vv_numSpectralPoint,  // /bb/spw
     730             :                       vector<vector<uint32_t> >       vv_numBin,    // /bb/spw
     731             :                       vector<vector<Enum<NetSideband> > > vv_e_sideband,      // /bb/spw
     732             :                       uint32_t          numApc,
     733             :                       vector<uint32_t>  v_numSpectralWindow,      // /bb
     734             :                       uint32_t          numBaseband,
     735             :                       uint32_t          numAnt,
     736             :                       CorrelationMode   correlationMode,
     737             :                       uint64_t          time,
     738             :                       uint64_t          timeCentroid,  
     739             :                       uint64_t          interval,
     740             :                       uint64_t          exposure,
     741             :                       uint32_t          /*numVal*/, // comment to avoid the unused parameter warning
     742             :                       const int*        /*crossData*/, // comment to avoid the unused parameter warning
     743             :                       uint32_t          numAutoData,
     744             :                       const float*      autoData,
     745             :                       uint32_t          numFlags,
     746           0 :                       const uint32_t*                 flags):
     747             :     DataStructure( vv_numCrossPolProduct,
     748             :                    vv_numAutoPolProduct,
     749             :                    vv_numSpectralPoint,
     750             :                    vv_numBin,
     751             :                    vv_e_sideband,
     752             :                    numApc,
     753             :                    v_numSpectralWindow,
     754             :                    numBaseband,
     755             :                    numAnt,
     756             :                    correlationMode),
     757           0 :     integrationNum_(0),
     758           0 :     subintegrationNum_(0),
     759           0 :     time_(time),
     760           0 :     timeCentroid_(timeCentroid),
     761           0 :     interval_(interval),
     762           0 :     exposure_(exposure),
     763           0 :     cuintFlagsPtr_(NULL),
     764           0 :     clonlonActualTimesPtr_(NULL),
     765           0 :     clonlonActualDurationsPtr_(NULL),
     766           0 :     cfloatWeightsPtr_(NULL),
     767           0 :     cfloatZeroLagsPtr_(NULL),
     768           0 :     cfloatAutoDataPtr_(NULL),
     769           0 :     cshortCrossDataPtr_(NULL),
     770           0 :     cintCrossDataPtr_(NULL),
     771           0 :     cfloatCrossDataPtr_(NULL)
     772             :   {
     773           0 :     uintFlagsPtr_     = new uint32_t[numFlags]; for(uint32_t n=0; n<numFlags; n++)uintFlagsPtr_[n] = flags[n];
     774           0 :     lonlonActualTimesPtr_     = NULL;
     775           0 :     lonlonActualDurationsPtr_ = NULL;
     776           0 :     floatWeightsPtr_          = NULL;
     777             : 
     778           0 :     floatZeroLagsPtr_         = NULL;
     779             : 
     780           0 :     floatAutoDataPtr_ = new float[numAutoData]; for(uint32_t n=0; n<numAutoData; n++)floatAutoDataPtr_[n] = autoData[n];
     781             :     
     782           0 :     shortCrossDataPtr_        = NULL;
     783           0 :     intCrossDataPtr_          = NULL;
     784           0 :     floatCrossDataPtr_        = NULL;
     785             : 
     786           0 :   }
     787             : 
     788             : 
     789       22865 :   DataDump::~DataDump()
     790             :   {
     791       22865 :     bool coutest=false;
     792       22865 :     if(coutest){
     793           0 :       cout<<"Destructor DataDump"<<endl;
     794           0 :       if(uintFlagsPtr_             ) cout<<"delete uintFlagsPtr_"<<endl;
     795           0 :       if(lonlonActualTimesPtr_     ) cout<<"delete lonlonActualTimesPtr_"<<endl;
     796           0 :       if(lonlonActualDurationsPtr_ ) cout<<"delete lonlonActualDurationsPtr_"<<endl;
     797           0 :       if(floatWeightsPtr_          ) cout<<"delete floatWeightsPtr_"<<endl;
     798           0 :       if(floatZeroLagsPtr_         ) cout<<"delete floatZeroLagsPtr_"<<endl;
     799           0 :       if(floatAutoDataPtr_         ) cout<<"delete floatAutoDataPtr_"<<endl;
     800           0 :       if(shortCrossDataPtr_        ) cout<<"delete shortCrossDataPtr_"<<endl;
     801           0 :       if(intCrossDataPtr_          ) cout<<"delete intCrossDataPtr_"<<endl;
     802           0 :       if(floatCrossDataPtr_        ) cout<<"delete floatCrossDataPtr_"<<endl;
     803             :     }
     804       22865 :     if(uintFlagsPtr_             ) delete uintFlagsPtr_;
     805       22865 :     if(lonlonActualTimesPtr_     ) delete lonlonActualTimesPtr_;
     806       22865 :     if(lonlonActualDurationsPtr_ ) delete lonlonActualDurationsPtr_;
     807       22865 :     if(floatWeightsPtr_          ) delete floatWeightsPtr_;
     808       22865 :     if(floatZeroLagsPtr_         ) delete floatZeroLagsPtr_;
     809       22865 :     if(floatAutoDataPtr_         ) delete floatAutoDataPtr_;
     810       22865 :     if(shortCrossDataPtr_        ) delete shortCrossDataPtr_;
     811       22865 :     if(intCrossDataPtr_          ) delete intCrossDataPtr_;
     812       22865 :     if(floatCrossDataPtr_        ) delete floatCrossDataPtr_;
     813       22865 :   }
     814             : 
     815           0 :   DataDump::DataDump(const DataDump& a) : DataStructure(a)
     816             :   {
     817           0 :     cout<<"Copy constructor DataDump (deep copy)"<<endl;
     818           0 :     cout<<"ici a.uintFlagsPtr_="<<a.uintFlagsPtr_<<endl;
     819           0 :     vv_numCrossPolProduct_= a.vv_numCrossPolProduct_;
     820           0 :     vv_numAutoPolProduct_ = a.vv_numAutoPolProduct_;
     821           0 :     vv_numSpectralPoint_  = a.vv_numSpectralPoint_;
     822           0 :     vv_numBin_            = a.vv_numBin_;
     823           0 :     vv_e_sideband_        = a.vv_e_sideband_;
     824           0 :     numApc_               = a.numApc_;
     825           0 :     v_numSpectralWindow_  = a.v_numSpectralWindow_;
     826           0 :     numBaseband_          = a.numBaseband_;
     827           0 :     numAnt_               = a.numAnt_;
     828           0 :     correlationMode_      = a.correlationMode_;
     829           0 :     axisSequence_         = a.axisSequence_;
     830           0 :     v_minSize_            = a.v_minSize_;
     831           0 :     v_maxSize_            = a.v_maxSize_;
     832             : 
     833           0 :     integrationNum_       = a.integrationNum_;
     834           0 :     subintegrationNum_    = a.subintegrationNum_;
     835           0 :     time_                 = a.time_;
     836           0 :     timeCentroid_         = a.timeCentroid_;
     837           0 :     interval_             = a.interval_;
     838           0 :     exposure_             = a.exposure_;
     839             : 
     840           0 :     vv_scaleFactor_       = a.vv_scaleFactor_;
     841             : 
     842           0 :     es_flagsAxes_           = a.es_flagsAxes_; 
     843           0 :     es_actualTimesAxes_     = a.es_actualTimesAxes_;   
     844           0 :     es_actualDurationsAxes_ = a.es_actualDurationsAxes_;   
     845           0 :     es_weightsAxes_         = a.es_weightsAxes_; 
     846             : 
     847           0 :     es_zeroLagsAxes_        = a.es_zeroLagsAxes_; 
     848             : 
     849           0 :     es_autoDataAxes_        = a.es_autoDataAxes_; 
     850           0 :     es_crossDataAxes_       = a.es_crossDataAxes_;
     851             : 
     852             : 
     853           0 :     numFlags_               = a.numFlags_;
     854           0 :     numActualTimes_         = a.numActualTimes_;
     855           0 :     numActualDurations_     = a.numActualDurations_;
     856           0 :     numWeights_             = a.numWeights_;
     857             :     
     858           0 :     numZeroLags_            = a.numZeroLags_;
     859             :      
     860           0 :     numAutoData_            = a.numAutoData_; 
     861           0 :     numCrossData_           = a.numCrossData_;
     862           0 :     cout<<"A"<<endl;
     863           0 :     cout<<"a.cuintFlagsPtr_"<<a.cuintFlagsPtr_<<endl;
     864           0 :     cout<<"a.flags()="<<a.flags()<<endl;
     865           0 :     cuintFlagsPtr_              = a.cuintFlagsPtr_;
     866           0 :     cout<<"B"<<endl;
     867           0 :     clonlonActualTimesPtr_      = a.clonlonActualTimesPtr_;
     868           0 :     clonlonActualDurationsPtr_  = a.clonlonActualDurationsPtr_;
     869           0 :     cfloatWeightsPtr_           = a.cfloatWeightsPtr_;
     870             : 
     871           0 :     cfloatZeroLagsPtr_          = a.cfloatZeroLagsPtr_;
     872             : 
     873           0 :     cfloatAutoDataPtr_          = a.cfloatAutoDataPtr_;
     874           0 :     cshortCrossDataPtr_         = a.cshortCrossDataPtr_;
     875           0 :     cintCrossDataPtr_           = a.cintCrossDataPtr_;
     876           0 :     cout<<"C"<<endl;
     877           0 :     cout<<"a.uintFlagsPtr_"<<a.uintFlagsPtr_<<endl;
     878           0 :     if(a.uintFlagsPtr_){
     879           0 :       cout<<"a.numFlags_="<<a.numFlags_<<endl;
     880           0 :       uintFlagsPtr_ = new uint32_t[a.numFlags_]; 
     881           0 :       for(uint32_t n=0; n<a.numFlags_; n++) uintFlagsPtr_[n] = a.uintFlagsPtr_[n]; }
     882           0 :     cout<<"D"<<endl;
     883           0 :     if(a.lonlonActualTimesPtr_){
     884           0 :       cout<<"a.numActualTimes_="<<a.numActualTimes_<<endl;
     885           0 :       lonlonActualTimesPtr_ = new int64_t[numActualTimes_]; 
     886           0 :       for(uint32_t n=0; n<numActualTimes_; n++)lonlonActualTimesPtr_[n] = a.lonlonActualTimesPtr_[n]; }
     887           0 :     if(a.lonlonActualDurationsPtr_){
     888           0 :       lonlonActualDurationsPtr_ = new int64_t[numActualDurations_]; 
     889           0 :       for(uint32_t n=0; n<numActualDurations_; n++)lonlonActualDurationsPtr_[n] = a.lonlonActualDurationsPtr_[n]; }
     890           0 :     if(a.floatWeightsPtr_){
     891           0 :       floatWeightsPtr_ = new float[numWeights_]; 
     892           0 :       for(uint32_t n=0; n<numWeights_; n++)floatWeightsPtr_[n] = a.floatWeightsPtr_[n]; }
     893             : 
     894           0 :     if(a.floatZeroLagsPtr_){
     895           0 :       floatZeroLagsPtr_ = new float[numZeroLags_]; 
     896           0 :       for(uint32_t n=0; n<numZeroLags_; n++)floatZeroLagsPtr_[n] = a.floatZeroLagsPtr_[n]; }
     897           0 :     if(a.shortCrossDataPtr_){
     898           0 :       cout<<"a.numCrossData_="<<a.numCrossData_<<endl;
     899           0 :       cout<<"numCrossData_="<<numCrossData_<<endl;
     900           0 :       shortCrossDataPtr_ = new short int[numCrossData_]; 
     901           0 :       for(uint32_t n=0; n<numCrossData_; n++)shortCrossDataPtr_[n] = a.shortCrossDataPtr_[n]; }
     902           0 :     if(a.intCrossDataPtr_){
     903           0 :       intCrossDataPtr_ = new int[numCrossData_]; 
     904           0 :       for(uint32_t n=0; n<numCrossData_; n++)intCrossDataPtr_[n] = a.intCrossDataPtr_[n]; }
     905           0 :     if(a.floatCrossDataPtr_){
     906           0 :       floatCrossDataPtr_ = new float[numCrossData_]; 
     907           0 :       for(uint32_t n=0; n<numCrossData_; n++)floatCrossDataPtr_[n] = a.floatCrossDataPtr_[n]; }
     908           0 :     cout<<"E"<<endl;
     909           0 :     cout<<"floatAutoDataPtr_ ="<<floatAutoDataPtr_<<endl;
     910           0 :     cout<<"a.floatAutoDataPtr_ ="<<a.floatAutoDataPtr_<<endl;
     911           0 :     if(a.floatAutoDataPtr_){
     912           0 :       cout<<"a.numAutoData_="<<a.numAutoData_<<endl;
     913           0 :       cout<<"numAutoData_="<<numAutoData_<<endl;
     914           0 :       floatAutoDataPtr_ = new float[numAutoData_]; 
     915           0 :       for(uint32_t n=0; n<numAutoData_; n++)floatAutoDataPtr_[n] = a.floatAutoDataPtr_[n]; }
     916             : 
     917           0 :      cout<<"F"<<endl;
     918             :     
     919           0 :   }
     920             : 
     921           0 :   DataDump& DataDump::operator = (const DataDump & a)
     922             :   {
     923           0 :     if(this == &a)return *this;
     924           0 :     vv_numCrossPolProduct_= a.vv_numCrossPolProduct_;
     925           0 :     vv_numAutoPolProduct_ = a.vv_numAutoPolProduct_;
     926           0 :     vv_numSpectralPoint_  = a.vv_numSpectralPoint_;
     927           0 :     vv_numBin_            = a.vv_numBin_;
     928           0 :     vv_e_sideband_        = a.vv_e_sideband_;
     929           0 :     numApc_               = a.numApc_;
     930           0 :     v_numSpectralWindow_  = a.v_numSpectralWindow_;
     931           0 :     numBaseband_          = a.numBaseband_;
     932           0 :     numAnt_               = a.numAnt_;
     933           0 :     correlationMode_      = a.correlationMode_;
     934           0 :     axisSequence_         = a.axisSequence_;
     935           0 :     v_minSize_            = a.v_minSize_;
     936           0 :     v_maxSize_            = a.v_maxSize_;
     937             : 
     938           0 :     integrationNum_       = a.integrationNum_;
     939           0 :     subintegrationNum_    = a.subintegrationNum_;
     940           0 :     time_                 = a.time_;
     941           0 :     timeCentroid_         = a.timeCentroid_;
     942           0 :     interval_             = a.interval_;
     943           0 :     exposure_             = a.exposure_;
     944             : 
     945           0 :     return *this;
     946             :   }
     947             : 
     948             :   // shape unchanged
     949           0 :   DataDump DataDump::operator - (const DataDump &rhs)
     950             :   {
     951           0 :     uint32_t numD=numAutoData();
     952           0 :     if(rhs.numAutoData()!=numD){
     953           0 :       ostringstream os;
     954           0 :       os << "Cannot subtract a data dump which has " << rhs.numAutoData()
     955           0 :          <<" data from an other which has "<<numD
     956           0 :          <<" data";
     957           0 :       Error( FATAL, os.str());
     958           0 :     }
     959           0 :     uint64_t st1 = (time_-interval_)/(uint64_t)2;
     960           0 :     uint64_t et1 = (time_+interval_)/(uint64_t)2; 
     961           0 :     uint64_t st2 = (rhs.time()-rhs.interval())/(uint64_t)2;
     962           0 :     uint64_t et2 = (rhs.time()+rhs.interval())/(uint64_t)2; 
     963           0 :     if( st1>et2 || et1<st2)
     964           0 :       Error( WARNING, (char *) "data difference of dumps overlaping in time");
     965             :     uint64_t st,et;
     966           0 :     if(st1<st2)
     967           0 :       st = st1;
     968             :     else
     969           0 :       st = st2;
     970           0 :     if(et1<et2)
     971           0 :       et = et2;
     972             :     else
     973           0 :       et = et1;
     974             : 
     975             :     uint64_t timeCentroid;
     976           0 :     if(interval_==rhs.interval())
     977           0 :       timeCentroid = (time_+rhs.time())/(uint64_t)2;
     978             :     else{
     979           0 :       double w=interval_/rhs.interval();
     980           0 :       timeCentroid = (uint64_t) ( (w*time_ + rhs.time())/(w+1.) );
     981             :     }
     982             : 
     983           0 :     uint32_t       numF = numD;                                  // TODO (more complex than that!)
     984           0 :     float*             diffFloatData = new float[numD];
     985           0 :     uint32_t*      sumUintFlags  = new uint32_t[numF];
     986             : 
     987           0 :     if(floatAutoDataPtr_){
     988           0 :       if(rhs.floatAutoDataPtr_){
     989           0 :         for(uint32_t nd=0; nd<numD; nd++)
     990           0 :           diffFloatData[nd] = floatAutoDataPtr_[nd]-rhs.floatAutoDataPtr_[nd];
     991           0 :         for(uint32_t nf=0; nf<numF; nf++){
     992           0 :           if(uintFlagsPtr_[nf]!=rhs.uintFlagsPtr_[nf])
     993           0 :             sumUintFlags[nf]=uintFlagsPtr_[nf]+rhs.uintFlagsPtr_[nf];  // TODO (more complex than that!)
     994             :           else
     995           0 :             sumUintFlags[nf]=uintFlagsPtr_[nf];
     996             :         }
     997             :       }else{
     998           0 :         for(uint32_t nd=0; nd<numD; nd++)
     999           0 :           diffFloatData[nd] = floatAutoDataPtr_[nd]-rhs.cfloatAutoDataPtr_[nd];
    1000           0 :         for(uint32_t nf=0; nf<numF; nf++){
    1001           0 :           if(uintFlagsPtr_[nf]!=rhs.cuintFlagsPtr_[nf])
    1002           0 :             sumUintFlags[nf]=uintFlagsPtr_[nf]+rhs.cuintFlagsPtr_[nf];  // TODO (more complex than that!)
    1003             :           else
    1004           0 :             sumUintFlags[nf]=uintFlagsPtr_[nf];
    1005             :         }
    1006             :       }
    1007             :     }else{
    1008           0 :       if(rhs.floatAutoDataPtr_){
    1009           0 :         for(uint32_t nd=0; nd<numD; nd++)
    1010           0 :           diffFloatData[nd] = cfloatAutoDataPtr_[nd]-rhs.floatAutoDataPtr_[nd];
    1011           0 :         for(uint32_t nf=0; nf<numF; nf++){
    1012           0 :           if(cuintFlagsPtr_[nf]!=rhs.uintFlagsPtr_[nf])
    1013           0 :             sumUintFlags[nf]=cuintFlagsPtr_[nf]+rhs.uintFlagsPtr_[nf];  // TODO (more complex than that!)
    1014             :           else
    1015           0 :             sumUintFlags[nf]=cuintFlagsPtr_[nf];
    1016             :         }
    1017             :       }else{
    1018           0 :         for(uint32_t nd=0; nd<numD; nd++)
    1019           0 :           diffFloatData[nd] = cfloatAutoDataPtr_[nd]-rhs.cfloatAutoDataPtr_[nd];
    1020           0 :         for(uint32_t nf=0; nf<numF; nf++){
    1021           0 :           if(cuintFlagsPtr_[nf]!=rhs.cuintFlagsPtr_[nf])
    1022           0 :             sumUintFlags[nf]=cuintFlagsPtr_[nf]+rhs.cuintFlagsPtr_[nf];  // TODO (more complex than that!)
    1023             :           else
    1024           0 :             sumUintFlags[nf]=cuintFlagsPtr_[nf];
    1025             :         }
    1026             :       }
    1027             :     }    
    1028           0 :     uint32_t numV=0;  // TODO
    1029           0 :     int*         diffCorrData=NULL;
    1030           0 :     return DataDump( vv_numCrossPolProduct_,
    1031           0 :                      vv_numAutoPolProduct_,
    1032           0 :                      vv_numSpectralPoint_,
    1033           0 :                      vv_numBin_,
    1034           0 :                      vv_e_sideband_,
    1035             :                      numApc_,
    1036           0 :                      v_numSpectralWindow_,
    1037             :                      numBaseband_,
    1038             :                      numAnt_,
    1039             :                      correlationMode_,
    1040           0 :                      (time_+rhs.time())/(uint64_t) 2,
    1041             :                      timeCentroid,
    1042             :                      et-st,
    1043           0 :                      exposure_+rhs.exposure(),
    1044             :                      numV, diffCorrData,
    1045             :                      numD, diffFloatData,
    1046             :                      numF, sumUintFlags
    1047           0 :                      );
    1048             :   }
    1049             : 
    1050           0 :   DataDump DataDump::operator + (const DataDump &rhs)
    1051             :   {
    1052           0 :     uint32_t numD=numAutoData();
    1053           0 :     if(rhs.numAutoData()!=numD){
    1054           0 :       ostringstream os;
    1055           0 :       os << "Cannot add a data dump which has " << numD
    1056           0 :          <<" data with an other which has "<<rhs.numAutoData()
    1057           0 :          <<" data";
    1058           0 :       Error( FATAL, os.str());
    1059           0 :     }
    1060           0 :     uint64_t st1 = (time_-interval_)/(uint64_t)2;
    1061           0 :     uint64_t et1 = (time_+interval_)/(uint64_t)2; 
    1062           0 :     uint64_t st2 = (rhs.time()-rhs.interval())/(uint64_t)2;
    1063           0 :     uint64_t et2 = (rhs.time()+rhs.interval())/(uint64_t)2; 
    1064           0 :     if( st1>et2 || et1<st2)
    1065           0 :       Error( WARNING, (char *) "sum of data dumps which overlap in time");
    1066             :     uint64_t st,et;
    1067           0 :     if(st1<st2)
    1068           0 :       st = st1;
    1069             :     else
    1070           0 :       st = st2;
    1071           0 :     if(et1<et2)
    1072           0 :       et = et2;
    1073             :     else
    1074           0 :       et = et1;
    1075             : 
    1076             :     uint64_t timeCentroid;
    1077           0 :     if(interval_==rhs.interval())
    1078           0 :       timeCentroid = (time_+rhs.time())/(uint64_t)2;
    1079             :     else{
    1080           0 :       double w=interval_/rhs.interval();
    1081           0 :       timeCentroid = (uint64_t) ( (w*time_ + rhs.time())/(w+1.) );
    1082             :     }
    1083           0 :     uint32_t numF = numD;                                           // TODO (more complex than that!)
    1084           0 :     float*             sumFloatData = new float[numD];
    1085           0 :     uint32_t*      sumUintFlags = new uint32_t[numF];
    1086             : 
    1087           0 :     if(floatAutoDataPtr_){
    1088           0 :       if(rhs.floatAutoDataPtr_){
    1089           0 :         for(uint32_t nd=0; nd<numD; nd++)
    1090           0 :           sumFloatData[nd] = 0.5*(floatAutoDataPtr_[nd]+rhs.floatAutoDataPtr_[nd]);
    1091           0 :         for(uint32_t nf=0; nf<numF; nf++){
    1092           0 :           if(uintFlagsPtr_[nf]!=rhs.uintFlagsPtr_[nf])
    1093           0 :             sumUintFlags[nf]=uintFlagsPtr_[nf]+rhs.uintFlagsPtr_[nf];  // TODO (more complex than that!)
    1094             :           else
    1095           0 :             sumUintFlags[nf]=uintFlagsPtr_[nf];
    1096             :         }
    1097             :       }else{
    1098           0 :         for(uint32_t nd=0; nd<numD; nd++)
    1099           0 :           sumFloatData[nd] = 0.5*(floatAutoDataPtr_[nd]+rhs.cfloatAutoDataPtr_[nd]);
    1100           0 :         for(uint32_t nf=0; nf<numF; nf++){
    1101           0 :           if(uintFlagsPtr_[nf]!=rhs.cuintFlagsPtr_[nf])
    1102           0 :             sumUintFlags[nf]=uintFlagsPtr_[nf]+rhs.cuintFlagsPtr_[nf];  // TODO (more complex than that!)
    1103             :           else
    1104           0 :             sumUintFlags[nf]=uintFlagsPtr_[nf];
    1105             :         }
    1106             :       }
    1107             :     }else{
    1108           0 :       if(rhs.floatAutoDataPtr_){
    1109           0 :         for(uint32_t nd=0; nd<numD; nd++)
    1110           0 :           sumFloatData[nd] = 0.5*(cfloatAutoDataPtr_[nd]+rhs.floatAutoDataPtr_[nd]);
    1111           0 :         for(uint32_t nf=0; nf<numF; nf++){
    1112           0 :           if(cuintFlagsPtr_[nf]!=rhs.uintFlagsPtr_[nf])
    1113           0 :             sumUintFlags[nf]=cuintFlagsPtr_[nf]+rhs.uintFlagsPtr_[nf];  // TODO (more complex than that!)
    1114             :           else
    1115           0 :             sumUintFlags[nf]=cuintFlagsPtr_[nf];
    1116             :         }
    1117             :       }else{
    1118           0 :         for(uint32_t nd=0; nd<numD; nd++)
    1119           0 :           sumFloatData[nd] = 0.5*(cfloatAutoDataPtr_[nd]+rhs.cfloatAutoDataPtr_[nd]);
    1120           0 :         for(uint32_t nf=0; nf<numF; nf++){
    1121           0 :           if(cuintFlagsPtr_[nf]!=rhs.cuintFlagsPtr_[nf])
    1122           0 :             sumUintFlags[nf]=cuintFlagsPtr_[nf]+rhs.cuintFlagsPtr_[nf];  // TODO (more complex than that!)
    1123             :           else
    1124           0 :             sumUintFlags[nf]=cuintFlagsPtr_[nf];
    1125             :         }
    1126             :       }
    1127             :     }
    1128           0 :     uint32_t numVal=0;  // TODO
    1129           0 :     int*         sumVisData=NULL;
    1130           0 :     return DataDump (vv_numCrossPolProduct_,
    1131           0 :                      vv_numAutoPolProduct_,
    1132           0 :                      vv_numSpectralPoint_,
    1133           0 :                      vv_numBin_,
    1134           0 :                      vv_e_sideband_,
    1135             :                      numApc_,
    1136           0 :                      v_numSpectralWindow_,
    1137             :                      numBaseband_,
    1138             :                      numAnt_,
    1139             :                      correlationMode_,
    1140           0 :                      (time_+rhs.time())/(uint64_t) 2,
    1141             :                      timeCentroid,
    1142             :                      et-st,
    1143           0 :                      exposure_+rhs.exposure(),
    1144             :                      numVal, sumVisData,
    1145             :                      numD, sumFloatData,
    1146             :                      numF, sumUintFlags
    1147           0 :                      );
    1148             :   }
    1149             : 
    1150             : 
    1151             :   // operations modifying the structure
    1152             : //   DataDump      DataDump::spectralAverage()
    1153             : //   {
    1154             : 
    1155             : //   }
    1156             : 
    1157             :   // Attachers and importers
    1158             : 
    1159        4801 :   void DataDump::attachFlags( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, // comment to avoid the unused parameter warning 
    1160             :                               uint32_t numData, const uint32_t* flagsPtr){
    1161        4801 :     cuintFlagsPtr_ = flagsPtr; 
    1162        4801 :     es_flagsAxes_  = es_an; 
    1163        4801 :     numFlags_      = numData; 
    1164        4801 :   }
    1165           0 :   void DataDump::importFlags( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, // comment to avoid the unused parameter warning 
    1166             :                               uint32_t numData, const uint32_t* flagsPtr){
    1167           0 :     cuintFlagsPtr_ = NULL;
    1168           0 :     if(uintFlagsPtr_){
    1169           0 :       if(numFlags_!=numData){
    1170           0 :         delete uintFlagsPtr_;
    1171           0 :         uintFlagsPtr_ = new uint32_t[numData];
    1172             :       }
    1173             :     }else{
    1174           0 :       uintFlagsPtr_ = new uint32_t[numData];
    1175             :     }
    1176           0 :     for(uint32_t n=0; n<numData; n++)uintFlagsPtr_[n] = flagsPtr[n]; 
    1177           0 :     es_flagsAxes_ = es_an;
    1178           0 :     numFlags_     = numData; 
    1179           0 :   }
    1180             : 
    1181         252 :   void DataDump::attachActualTimes( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, // comment to avoid the unused parameter warning 
    1182             :                                     uint32_t numData, const int64_t * actualTimesPtr){
    1183         252 :     clonlonActualTimesPtr_ = actualTimesPtr; 
    1184         252 :     es_actualTimesAxes_    = es_an;
    1185         252 :     numActualTimes_        = numData;
    1186         252 :   }
    1187           0 :   void DataDump::importActualTimes( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, // comment to avoid the unused parameter warning 
    1188             :                                     uint32_t numData, const int64_t * actualTimesPtr){
    1189           0 :     clonlonActualTimesPtr_ = NULL;
    1190           0 :     if(lonlonActualTimesPtr_){
    1191           0 :       if(numActualTimes_!=numData){
    1192           0 :         delete lonlonActualTimesPtr_;
    1193           0 :         lonlonActualTimesPtr_ = new int64_t[numData];
    1194             :       }
    1195             :     }else{
    1196           0 :       lonlonActualTimesPtr_ = new int64_t[numData];
    1197             :     }
    1198           0 :     for(uint32_t n=0; n<numData; n++)lonlonActualTimesPtr_[n] = actualTimesPtr[n]; 
    1199           0 :     es_actualTimesAxes_ = es_an;
    1200           0 :     numActualTimes_     = numData; 
    1201           0 :   }
    1202             : 
    1203             : 
    1204         252 :   void DataDump::attachActualDurations( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, // comment to avoid the unused parameter warning 
    1205             :                                         uint32_t numData, const int64_t * actualDurationsPtr){
    1206         252 :     clonlonActualDurationsPtr_ = actualDurationsPtr; 
    1207         252 :     es_actualDurationsAxes_     = es_an;
    1208         252 :     numActualDurations_         = numData;
    1209         252 :   }
    1210           0 :   void DataDump::importActualDurations( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, // comment to avoid the unused parameter warning 
    1211             :                                         uint32_t numData, const int64_t * actualDurationsPtr){
    1212           0 :     clonlonActualDurationsPtr_ = NULL;
    1213           0 :     if(lonlonActualDurationsPtr_){
    1214           0 :       if(numActualDurations_!=numData){
    1215           0 :         delete lonlonActualDurationsPtr_;
    1216           0 :         lonlonActualDurationsPtr_ = new int64_t[numData];
    1217             :       }
    1218             :     }else{
    1219           0 :       lonlonActualDurationsPtr_ = new int64_t[numData];
    1220             :     }
    1221           0 :     for(uint32_t n=0; n<numData; n++)lonlonActualDurationsPtr_[n] = actualDurationsPtr[n]; 
    1222           0 :     es_actualDurationsAxes_ = es_an;
    1223           0 :     numActualDurations_     = numData; 
    1224           0 :   }
    1225             : 
    1226       13890 :   void DataDump::attachZeroLags( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, // comment to avoid the unused parameter warning 
    1227             :                                  uint32_t numData, const float* zeroLagsPtr){
    1228       13890 :     cfloatZeroLagsPtr_ = zeroLagsPtr; 
    1229       13890 :     es_zeroLagsAxes_   = es_an;
    1230       13890 :     numZeroLags_       = numData;
    1231       13890 :   }
    1232           0 :   void DataDump::importZeroLags( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, // comment to avoid the unused parameter warning
    1233             :                                  uint32_t numData, const float* zeroLagsPtr){
    1234           0 :     cfloatZeroLagsPtr_ = NULL;
    1235           0 :     if(floatZeroLagsPtr_){
    1236           0 :       if(numZeroLags_!=numData){
    1237           0 :         delete floatZeroLagsPtr_;
    1238           0 :         floatZeroLagsPtr_ = new float[numData];
    1239             :       }
    1240             :     }else{
    1241           0 :       floatZeroLagsPtr_ = new float[numData];
    1242             :     }
    1243           0 :     for(uint32_t n=0; n<numData; n++)floatZeroLagsPtr_[n] = zeroLagsPtr[n]; 
    1244           0 :     es_zeroLagsAxes_ = es_an;
    1245           0 :     numZeroLags_     = numData;
    1246           0 :   }
    1247             : 
    1248       22753 :   void DataDump::attachAutoData( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, 
    1249             :                                  uint32_t numData, const float* autoDataPtr){
    1250       22753 :     cfloatAutoDataPtr_ = autoDataPtr; 
    1251       22753 :     es_autoDataAxes_   = es_an;
    1252       22753 :     numAutoData_       = numData;
    1253             : 
    1254       22753 :     if(uintFlagsPtr_)cout<<"there are imported flags"<<endl;
    1255             :     //cout<<"uintFlagsPtr_="<<    uintFlagsPtr_<<endl;
    1256             : 
    1257       22753 :   }
    1258           0 :   void DataDump::importAutoData( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, 
    1259             :                                  uint32_t numData, const float* autoDataPtr){
    1260           0 :     cfloatAutoDataPtr_ = NULL;
    1261           0 :     if(floatAutoDataPtr_){
    1262           0 :       if(numAutoData_!=numData){
    1263           0 :         delete floatAutoDataPtr_;
    1264           0 :         floatAutoDataPtr_ = new float[numData];
    1265             :       }
    1266             :     }else{
    1267           0 :       floatAutoDataPtr_ = new float[numData];
    1268             :     }
    1269           0 :     for(uint32_t n=0; n<numData; n++)floatAutoDataPtr_[n] = autoDataPtr[n]; 
    1270           0 :     es_autoDataAxes_ = es_an;
    1271           0 :     numAutoData_     = numData;
    1272           0 :   }
    1273             : 
    1274       14502 :   void DataDump::attachCrossData( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, 
    1275             :                                   uint32_t numData, const short int* crossDataPtr){
    1276       14502 :     cintCrossDataPtr_   = NULL; 
    1277       14502 :     cfloatCrossDataPtr_ = NULL;
    1278       14502 :     cshortCrossDataPtr_ = crossDataPtr; 
    1279       14502 :     es_crossDataAxes_   = es_an;
    1280       14502 :     numCrossData_       = numData;
    1281       14502 :   }
    1282           0 :   void DataDump::importCrossData( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, 
    1283             :                                   uint32_t numData, const short int* crossDataPtr){
    1284           0 :     cintCrossDataPtr_   = NULL; 
    1285           0 :     cfloatCrossDataPtr_ = NULL;
    1286           0 :     cshortCrossDataPtr_ = NULL;
    1287           0 :     if(shortCrossDataPtr_){
    1288           0 :       if(numCrossData_!=numData){
    1289           0 :         delete shortCrossDataPtr_;
    1290           0 :         shortCrossDataPtr_ = new short int[numData];
    1291             :       }
    1292             :     }else{
    1293           0 :       shortCrossDataPtr_ = new short int[numData];
    1294             :     }
    1295           0 :     for(uint32_t n=0; n<numData; n++)shortCrossDataPtr_[n] = crossDataPtr[n]; 
    1296           0 :     es_crossDataAxes_ = es_an;
    1297           0 :     numCrossData_     = numData;
    1298           0 :   }
    1299             : 
    1300        1200 :   void DataDump::attachCrossData( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, 
    1301             :                                   uint32_t numData, const  int* crossDataPtr){
    1302        1200 :     cshortCrossDataPtr_ = NULL; 
    1303        1200 :     cintCrossDataPtr_   = crossDataPtr; 
    1304        1200 :     cfloatCrossDataPtr_ = NULL;
    1305        1200 :     es_crossDataAxes_   = es_an;
    1306        1200 :     numCrossData_       = numData;
    1307        1200 :   }
    1308           0 :   void DataDump::importCrossData( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, 
    1309             :                                   uint32_t numData, const int* crossDataPtr){
    1310           0 :     cshortCrossDataPtr_ = NULL; 
    1311           0 :     cintCrossDataPtr_   = NULL;
    1312           0 :     cfloatCrossDataPtr_ = NULL;
    1313           0 :     if(intCrossDataPtr_){
    1314           0 :       if(numCrossData_!=numData){
    1315           0 :         delete intCrossDataPtr_;
    1316           0 :         intCrossDataPtr_ = new int[numData];
    1317             :       }
    1318             :     }else{
    1319           0 :       intCrossDataPtr_ = new int[numData];
    1320             :     }
    1321           0 :     for(uint32_t n=0; n<numData; n++)intCrossDataPtr_[n] = crossDataPtr[n]; 
    1322           0 :     es_crossDataAxes_ = es_an;
    1323           0 :     numCrossData_     = numData;
    1324           0 :   }
    1325             : 
    1326             : 
    1327        1252 :   void DataDump::attachCrossData( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, 
    1328             :                                   uint32_t numData, const float* crossDataPtr){
    1329        1252 :     cshortCrossDataPtr_ = NULL; 
    1330        1252 :     cintCrossDataPtr_   = NULL;
    1331        1252 :     cfloatCrossDataPtr_ = crossDataPtr; 
    1332        1252 :     es_crossDataAxes_   = es_an;
    1333        1252 :     numCrossData_       = numData;
    1334        1252 :   }
    1335           0 :   void DataDump::importCrossData( uint32_t /*declaredSize*/, EnumSet<AxisName> es_an, 
    1336             :                                   uint32_t numData, const float* crossDataPtr){
    1337           0 :     cshortCrossDataPtr_ = NULL; 
    1338           0 :     cintCrossDataPtr_   = NULL;
    1339           0 :     cfloatCrossDataPtr_ = NULL;
    1340           0 :     if(floatCrossDataPtr_){
    1341           0 :       if(numCrossData_!=numData){
    1342           0 :         delete floatCrossDataPtr_;
    1343           0 :         floatCrossDataPtr_ = new float[numData];
    1344             :       }
    1345             :     }else{
    1346           0 :       floatCrossDataPtr_ = new float[numData];
    1347             :     }
    1348           0 :     for(uint32_t n=0; n<numData; n++)floatCrossDataPtr_[n] = crossDataPtr[n]; 
    1349           0 :     es_crossDataAxes_ = es_an;
    1350           0 :     numCrossData_     = numData;
    1351           0 :   }
    1352             : 
    1353       16954 :   void DataDump::setScaleFactor(vector<vector<float> > vv_scaleFactor){
    1354       16954 :     if(vv_scaleFactor.size()!=vv_numCrossPolProduct_.size())
    1355           0 :       Error(FATAL,
    1356             :             (char *) "vv_scaleFactor, of size %d, does not have  a size equal to %d (i.e. numBaseband)",
    1357             :             vv_numCrossPolProduct_.size(),numBaseband_);
    1358       50324 :     for(uint32_t nbb=0; nbb<vv_numCrossPolProduct_.size(); nbb++)
    1359       33370 :       if(vv_scaleFactor[nbb].size()!=vv_numCrossPolProduct_[nbb].size())
    1360           0 :         Error(FATAL,
    1361             :               (char *) "vv_scaleFactor[%d], of size %d, does not have  a size equal to the nb on spw for that baseband",
    1362           0 :             nbb,vv_numCrossPolProduct_[nbb].size());
    1363       16954 :     vv_scaleFactor_ = vv_scaleFactor;
    1364             :     // linearization for fast access:
    1365       50324 :     for(uint32_t nbb=0; nbb<vv_scaleFactor.size(); nbb++){
    1366       82670 :       for(uint32_t nspw=0; nspw<vv_scaleFactor[nbb].size(); nspw++){
    1367       49300 :         v_scaleFactor_.push_back(vv_scaleFactor[nbb][nspw]);
    1368             :       }
    1369             :     }
    1370       16954 :     return;
    1371             :   }
    1372             : 
    1373             :   // Setters to identify the project structure context:
    1374       13977 :   uint32_t DataDump::setIntegration(uint32_t integNum){
    1375       13977 :     if(integrationNum_){
    1376           0 :       if(integNum==integrationNum_)return integrationNum_;
    1377           0 :       Error(WARNING,
    1378             :             (char *) "This dump has already been identified with the integration number %d;\n it is not allowed to tag it again",
    1379             :             integrationNum_);
    1380           0 :       return 0;
    1381             :     }
    1382       13977 :     integrationNum_=integNum;
    1383       13977 :     return integrationNum_;
    1384             :   }
    1385             : 
    1386        9886 :   uint32_t DataDump::setSubintegration(uint32_t integNum, uint32_t subintegNum){
    1387        9886 :     if(setIntegration(integNum)){
    1388        9886 :       if(subintegNum==subintegrationNum_)return integrationNum_;
    1389           0 :       if(subintegrationNum_)
    1390           0 :         Error(WARNING,
    1391             :               (char *) "This dump has already been identified with the subintegration number %d;\n it is not allowed to tag it again",
    1392             :               subintegrationNum_);
    1393           0 :       subintegrationNum_=subintegNum;
    1394           0 :       return subintegNum;
    1395             :     }
    1396           0 :     return 0;
    1397             :   }
    1398             : 
    1399       22865 :   uint32_t DataDump::setContextUsingProjectPath(string projectPathUri){
    1400       22865 :     string::size_type i=0, p=0 ;
    1401             :     //    uint32_t i=0, p=0;
    1402       22865 :     vector<uint32_t> v_node;
    1403      141987 :     while(p!=string::npos){
    1404      119122 :       p = projectPathUri.find("/",i);
    1405      119122 :       if(p!=string::npos){
    1406       96257 :         v_node.push_back((uint32_t)atoi(projectPathUri.substr(i,p-i).c_str()));
    1407       96257 :         i = p+1;
    1408             :       }else{
    1409       22865 :         v_node.push_back((uint32_t)atoi(projectPathUri.substr(i,projectPathUri.length()).c_str()));
    1410             :       }
    1411             :     }
    1412       22865 :     if(v_node.size()==5)
    1413             :       //return setSubintegration(v_node[4],v_node[5]);
    1414        9886 :       return setSubintegration(v_node[3],v_node[4]);
    1415       12979 :     else if(v_node.size()==4) 
    1416             :       // return setIntegration(v_node[4]);
    1417        4091 :       return setIntegration(v_node[3]);
    1418        8888 :     return 0;
    1419       22865 :   }
    1420             : 
    1421             : 
    1422             :   // Accessors
    1423       37154 :   uint64_t    DataDump::time() const
    1424             :   {
    1425       37154 :     return time_;
    1426             :   }
    1427             : 
    1428       37154 :   uint64_t    DataDump::timeCentroid() const
    1429             :   {
    1430       37154 :     return timeCentroid_;
    1431             :   }
    1432             : 
    1433       37154 :   uint64_t    DataDump::interval() const
    1434             :   {
    1435       37154 :     return interval_;
    1436             :   }
    1437             : 
    1438       37154 :   uint64_t    DataDump::exposure() const
    1439             :   {
    1440       37154 :     return exposure_;
    1441             :   }
    1442             : 
    1443             : 
    1444    20666708 :   uint32_t DataDump::integrationNum()
    1445             :   {
    1446    20666708 :     return integrationNum_;
    1447             :   }
    1448             : 
    1449    11997820 :   uint32_t DataDump::subintegrationNum()
    1450             :   {
    1451    11997820 :     return subintegrationNum_;
    1452             :   }
    1453             : 
    1454           0 :   float DataDump::scaleFactor(uint32_t nbb, uint32_t nspw){
    1455           0 :     if(nbb<vv_scaleFactor_.size()){
    1456           0 :       if(nspw<vv_scaleFactor_[nbb].size()){
    1457           0 :         return vv_scaleFactor_[nbb][nspw];
    1458             :       }else{
    1459           0 :         Error(FATAL,(char *) "spectral window index %d too large for %d spectral windows for baseband index %d",
    1460           0 :               nspw,vv_scaleFactor_[nbb].size(),nbb);
    1461             :       }
    1462             :     }else{
    1463           0 :       Error(FATAL,(char *) "baseband index %d too large for %d basebands",
    1464             :             nbb,vv_scaleFactor_.size());
    1465             :     }
    1466           0 :     return 0;
    1467             :   }
    1468             : 
    1469    11550156 :   float DataDump::scaleFactor(uint32_t ndd){
    1470    11550156 :     bool coutest=false;
    1471    11550156 :     if (coutest) cout << "size of v_scaleFactor_ = " << v_scaleFactor_.size() << ", ndd = " << ndd << endl;
    1472    11550156 :     return v_scaleFactor_.at(ndd);
    1473             :   }
    1474             : 
    1475             : 
    1476       20863 :   const float*              DataDump::autoData() const{
    1477       20863 :     if(floatAutoDataPtr_)               // imported data made available read-only
    1478           0 :       return floatAutoDataPtr_;
    1479             :     else
    1480       20863 :       return cfloatAutoDataPtr_;        // attached data made available read-only
    1481             :   }
    1482             : 
    1483       30280 :   const short*             DataDump::crossDataShort() const{
    1484       30280 :     if(shortCrossDataPtr_)
    1485           0 :       return shortCrossDataPtr_;
    1486             :     else
    1487       30280 :       return cshortCrossDataPtr_;
    1488             :   }
    1489             : 
    1490        3352 :   const int*              DataDump::crossDataLong() const{
    1491        3352 :     if(intCrossDataPtr_)
    1492           0 :       return intCrossDataPtr_;
    1493             :     else
    1494        3352 :       return cintCrossDataPtr_;
    1495             :   }
    1496             : 
    1497        2504 :   const float*              DataDump::crossDataFloat() const{
    1498        2504 :     if(floatCrossDataPtr_)
    1499           0 :       return floatCrossDataPtr_;
    1500             :     else
    1501        2504 :       return cfloatCrossDataPtr_;
    1502             :   }
    1503             : 
    1504             : 
    1505       18774 :   const uint32_t* DataDump::flags() const
    1506             :   {
    1507       18774 :     bool coutest=false;
    1508       18774 :     if(coutest){
    1509           0 :       if(uintFlagsPtr_)
    1510           0 :         cout<<"return flags owned by datadump"<<endl;
    1511           0 :       if(cuintFlagsPtr_)
    1512           0 :         cout<<"return flags which have been attached to datadump"<<endl;
    1513             :     }
    1514       18774 :     if(uintFlagsPtr_)
    1515           0 :       return uintFlagsPtr_;
    1516             :     else
    1517       18774 :       return cuintFlagsPtr_;
    1518             :     return NULL;
    1519             :   }
    1520             : 
    1521             : 
    1522           0 :   const int64_t*     DataDump::actualTimes() const
    1523             :   {
    1524           0 :     if(lonlonActualTimesPtr_)
    1525           0 :       return lonlonActualTimesPtr_;
    1526             :     else
    1527           0 :       return clonlonActualTimesPtr_;
    1528             :     return NULL;
    1529             :   }
    1530             : 
    1531           0 :   const int64_t*         DataDump::actualDurations() const
    1532             :   {
    1533           0 :     bool coutest=false;
    1534           0 :     if(coutest){
    1535           0 :       if(lonlonActualDurationsPtr_)
    1536           0 :         cout<<"return actualDurations owned by datadump"<<endl;
    1537           0 :       if(clonlonActualDurationsPtr_)
    1538           0 :         cout<<"return actualDurations which have been attached to datadump"<<endl;
    1539             :     }
    1540           0 :     if(lonlonActualDurationsPtr_)
    1541           0 :       return lonlonActualDurationsPtr_;
    1542             :     else
    1543           0 :       return clonlonActualDurationsPtr_;
    1544             :     return NULL;
    1545             :   }
    1546             : 
    1547           0 :   const float*             DataDump::zeroLags() const
    1548             :   {
    1549           0 :     if(floatZeroLagsPtr_)
    1550           0 :       return floatZeroLagsPtr_;
    1551             :     else
    1552           0 :       return cfloatZeroLagsPtr_;
    1553             :     return NULL;
    1554             :   }
    1555             : 
    1556           0 :   uint32_t DataDump::floatData(vector<vector<vector<float> > >&)
    1557             :   {
    1558             :   
    1559             : //     for(uint32_t nbb=0; nbb<numBaseband_; nbb++){
    1560             : //       v_sizes[nbb].push_back(numSpectralWindow[nbb]);
    1561             : //     }
    1562             : //     if(numPolProduct>1)     v_sizes.push_back(numPolProduct);
    1563             : //     if(numSpectralPoint>1)  v_sizes.push_back(numSpectralPoint);
    1564             : //     if(numBin>1)            v_sizes.push_back(numBin);
    1565             : //     if(numApc>1)            v_sizes.push_back(numApc);
    1566             : //     if(numSpectralWindow>1) v_sizes.push_back(numSpectralWindow);
    1567             : //     if(numBaseband>1)       v_sizes.push_back(numBaseband);
    1568             : //     if(numAnt>1)            v_sizes.push_back(numAnt);  
    1569           0 :     uint32_t dim=0;
    1570           0 :     return dim;
    1571             :   }
    1572           0 :   uint32_t DataDump::floatData(vector<vector<vector<float*> > >& /*vvv*/) // comment to avoid the unused parameter warning
    1573             :   {
    1574           0 :     uint32_t dim=0;
    1575           0 :     return dim;
    1576             :   }
    1577             : 
    1578           0 :   uint32_t DataDump::floatData(vector<vector<vector<vector<float> > > >& /*vvvv*/) // comment to avoid the unused parameter warning
    1579             :   {
    1580           0 :     uint32_t dim=0;
    1581           0 :     return dim;
    1582             :   }
    1583             : 
    1584             : 
    1585           0 :   uint32_t DataDump::floatData(vector<vector<vector<vector<vector<float> > > > >& /*vvvvv*/)
    1586             :   {
    1587             : //     uint32_t nd;
    1588             : //     vvvvvvv.resize(numAnt_);
    1589             : //     for(uint32_t na=0; na<numAnt_; na++){
    1590             : //       vvvvvvv[na].resize(numBaseband_);
    1591             : 
    1592             : //       for(uint32_t nbb=0; nbb<numBaseband_; nbb){
    1593             : //      vvvvvvv[na][nbb].resize(v_numSpectralWindow_[nbb]);
    1594             : 
    1595             : //      for(uint32_t nspw=0; nspw<v_numSpectralWindow_[nbb]; nspw++){
    1596             : //        vvvvvvv[na][nbb][nspw].resize(vv_numBin_[nbb][nspw]);
    1597             : 
    1598             : //        for(uint32_t nb=0; nb<vv_numBin_[nbb][nspw]; nb++){
    1599             : //          vvvvvvv[na][nbb][nspw][nb].resize(vv_numBin_[nbb][nspw]);
    1600             : 
    1601             : //          for(uint32_t napc=0; napc<numApc_; napc++){
    1602             : //            vvvvvvv[na][nbb][nb][nspw][nb].resize(numApc_);
    1603             : 
    1604             : 
    1605             : //            for(uint32_t nsp=0; nsp<vv_numSpectralPoint_[nbb][nspw] nsp++){
    1606             : //              vvvvvvv[na][nbb][nb][nspw][nb][nsp].resize(vv_numPolProduct_[nbb][nspw]);
    1607             : 
    1608             : //              for(uint32_t np=0; np<vv_numPolProduct_[nbb][nspw]; np++)
    1609             : //                vvvvvvv[na][nbb][nb][nspw][nb][nsp].push-back(*floatDataPtr_[nd++]);
    1610             : 
    1611             : //            }
    1612             : //          }
    1613             : //        }
    1614             : //      }
    1615             : //       }
    1616             : //     }
    1617             :     
    1618           0 :     uint32_t dim=0;
    1619           0 :     return dim;
    1620             : 
    1621             :   }
    1622             : 
    1623             : 
    1624             : // ============================================================================================
    1625             : // Integration -> DataDump -> DataStructure
    1626             : // ============================================================================================
    1627             : 
    1628             : //   Integration::Integration()
    1629             : //   {
    1630             : //   }
    1631             : 
    1632           0 :   Integration::Integration( vector<vector<uint32_t> >       vv_numPolProduct,     // /bb/spw
    1633             :                             vector<vector<uint32_t> >       vv_numSpectralPoint,  // /bb/spw
    1634             :                             vector<vector<uint32_t> >       vv_numBin,            // /bb/spw
    1635             :                             vector<vector<Enum<NetSideband> > > vv_e_sideband,        // /bb/spw
    1636             :                             uint32_t                        numApc,
    1637             :                             vector<uint32_t>                v_numSpectralWindow,  // /bb
    1638             :                             uint32_t                        numBaseband,
    1639             :                             uint32_t                        numAnt,
    1640             :                             CorrelationMode                     correlationMode,
    1641             :                             uint64_t                           time, 
    1642             :                             uint64_t                           timeCentroid, 
    1643             :                             uint64_t                           interval, 
    1644             :                             uint64_t                           exposure, 
    1645             :                             float*                              floatData,
    1646           0 :                             uint32_t                        integrationNum):
    1647             :     DataDump( vv_numPolProduct,    
    1648             :               vv_numSpectralPoint,
    1649             :               vv_numBin,
    1650             :               vv_e_sideband,
    1651             :               numApc,
    1652             :               v_numSpectralWindow,
    1653             :               numBaseband,
    1654             :               numAnt,
    1655             :               correlationMode,
    1656             :               time,
    1657             :               timeCentroid,
    1658             :               interval, 
    1659             :               exposure,
    1660           0 :               floatData)
    1661             :   {
    1662           0 :     integrationNum_    = integrationNum;
    1663           0 :     subintegrationNum_ = 0;
    1664           0 :   }
    1665             : 
    1666           0 :   Integration::Integration( vector<vector<uint32_t> >       vv_numPolProduct,       // /bb/spw
    1667             :                             vector<vector<uint32_t> >       vv_numSpectralPoint,    // /bb/spw
    1668             :                             vector<vector<uint32_t> >       vv_numBin,      // /bb/spw
    1669             :                             vector<vector<Enum<NetSideband> > > vv_e_sideband,        // /bb/spw
    1670             :                             uint32_t            numApc,
    1671             :                             vector<uint32_t>    v_numSpectralWindow,      // /bb
    1672             :                             uint32_t            numBaseband,
    1673             :                             uint32_t            numAnt,
    1674             :                             CorrelationMode     correlationMode,
    1675             :                             uint64_t            time,
    1676             :                             uint64_t            timeCentroid,  
    1677             :                             uint64_t            interval,
    1678             :                             uint64_t            exposure,  
    1679             :                             float*              floatData, 
    1680             :                             uint32_t*           dataFlags,
    1681           0 :                             uint32_t                        integrationNum):
    1682             :     DataDump( vv_numPolProduct,
    1683             :               vv_numSpectralPoint,
    1684             :               vv_numBin,
    1685             :               vv_e_sideband,
    1686             :               numApc,
    1687             :               v_numSpectralWindow,
    1688             :               numBaseband,
    1689             :               numAnt,
    1690             :               correlationMode,
    1691             :               time,
    1692             :               timeCentroid,
    1693             :               interval, 
    1694             :               exposure,
    1695             :               floatData,
    1696           0 :               dataFlags)
    1697             :   {
    1698           0 :     integrationNum_    = integrationNum;
    1699           0 :     subintegrationNum_ = 0;
    1700           0 :   }
    1701             : 
    1702           0 :   Integration::~Integration()
    1703             :   {
    1704           0 :   }
    1705             : 
    1706           0 :   Integration::Integration( const Integration & a) : DataDump(a)
    1707             :   {
    1708           0 :     cout<<"Copy constructor Integration"<<endl;
    1709           0 :     vv_numCrossPolProduct_= a.vv_numCrossPolProduct_;
    1710           0 :     vv_numAutoPolProduct_ = a.vv_numAutoPolProduct_;
    1711           0 :     vv_numSpectralPoint_  = a.vv_numSpectralPoint_;
    1712           0 :     vv_numBin_            = a.vv_numBin_;
    1713           0 :     vv_e_sideband_        = a.vv_e_sideband_;
    1714           0 :     numApc_               = a.numApc_;
    1715           0 :     v_numSpectralWindow_  = a.v_numSpectralWindow_;
    1716           0 :     numBaseband_          = a.numBaseband_;
    1717           0 :     numAnt_               = a.numAnt_;
    1718           0 :     correlationMode_      = a.correlationMode_;
    1719           0 :     axisSequence_         = a.axisSequence_;
    1720           0 :     v_minSize_            = a.v_minSize_;
    1721           0 :     v_maxSize_            = a.v_maxSize_;
    1722             : 
    1723           0 :     integrationNum_       = a.integrationNum_;
    1724           0 :     subintegrationNum_    = a.subintegrationNum_;
    1725           0 :     time_                 = a.time_;
    1726           0 :     timeCentroid_         = a.timeCentroid_;
    1727           0 :     interval_             = a.interval_;
    1728           0 :     exposure_             = a.exposure_;
    1729             : 
    1730             : 
    1731             : //     int nd=a.numData();
    1732             : //     if(a.floatDataPtr_){
    1733             : //       floatDataPtr_ = new        float[nd]; for(int n=0; n<nd; n++)floatDataPtr_[n] = a.floatDataPtr_[n];
    1734             : //     }else{
    1735             : //       floatDataPtr_=a.floatDataPtr_;
    1736             : //     }
    1737             : //     if(a.dataFlagsPtr_){
    1738             : //       dataFlagsPtr_ = new uint32_t[nd]; for(int n=0; n<nd; n++)dataFlagsPtr_[n] = a.dataFlagsPtr_[n];
    1739             : //     }else{
    1740             : //       dataFlagsPtr_=a.dataFlagsPtr_;
    1741             : //     }
    1742             : 
    1743           0 :     integrationNum_       = a.integrationNum_;
    1744           0 :   }
    1745             : 
    1746             : 
    1747             : 
    1748             : }

Generated by: LCOV version 1.16