LCOV - code coverage report
Current view: top level - air_casawvr/casawvr - msutils.cc (source / functions) Hit Total Coverage
Test: casacpp_coverage.info Lines: 74 111 66.7 %
Date: 2024-11-06 17:42:47 Functions: 6 9 66.7 %

          Line data    Source code
       1             : /**
       2             :    Bojan Nikolic <b.nikolic@mrao.cam.ac.uk>, <bojan@bnikolic.co.uk>
       3             :    Initial version January 2010.
       4             :    Maintained by ESO since 2013. 
       5             :    
       6             :    This file is part of LibAIR and is licensed under GNU Public
       7             :    License Version 2
       8             :    
       9             :    \file msutils.cpp
      10             :    Renamed msutils.cc 2023
      11             : 
      12             : */
      13             : 
      14             : #include <stdexcept>
      15             : #include "msutils.h"
      16             : 
      17             : #include <casacore/ms/MeasurementSets/MeasurementSet.h>
      18             : #include <casacore/tables/Tables/Table.h>
      19             : #include <casacore/ms/MeasurementSets/MSFieldColumns.h>
      20             : #include <casacore/ms/MeasurementSets/MSField.h>
      21             : #include <casacore/ms/MeasurementSets/MSColumns.h>
      22             : 
      23             : namespace LibAIR2 {
      24             : 
      25             :   /** Channel frequencies for spectral window spw     
      26             :    */
      27           0 :   void spwChannelFreq(const casacore::MeasurementSet &ms,
      28             :                       size_t spw,
      29             :                       std::vector<double> &fres)
      30             :   {
      31           0 :     casacore::MSSpectralWindow specTable(ms.spectralWindow());
      32             : 
      33             :     // Number of channels 
      34             :     casacore::ScalarColumn<casacore::Int> nc
      35             :       (specTable,
      36           0 :        casacore::MSSpectralWindow::columnName(casacore::MSSpectralWindow::NUM_CHAN));
      37             : 
      38             :     // Frequencies of the channels
      39             :     casacore::ArrayColumn<casacore::Double>
      40             :       chfreq(specTable,
      41           0 :              casacore::MSSpectralWindow::columnName(casacore::MSSpectralWindow::CHAN_FREQ));
      42             : 
      43           0 :     fres.resize(nc(spw));
      44           0 :     casacore::Array<casacore::Double> freq;
      45           0 :     chfreq.get(spw, freq, casacore::True);
      46             :     
      47           0 :     for(size_t i=0; i< static_cast<size_t>(nc(spw)); ++i)
      48             :     {
      49           0 :       fres[i]=freq(casacore::IPosition(1,i));
      50             :     }
      51           0 :   }
      52             : 
      53          44 :   void fieldIDs(const casacore::MeasurementSet &ms,
      54             :                 std::vector<double> &time,
      55             :                 std::vector<int> &fieldID,
      56             :                 std::vector<int> &sourceID,
      57             :                 const std::vector<size_t> &sortedI)
      58             :   {
      59          44 :     const casacore::MSMainColumns cols(ms);
      60          44 :     const casacore::ScalarColumn<casacore::Int> &f= cols.fieldId();
      61          44 :     const casacore::ScalarColumn<casacore::Double> &t= cols.time();
      62             : 
      63          44 :     std::map<size_t, size_t> srcmap=getFieldSrcMap(ms);
      64             : 
      65          44 :     const size_t nrows=f.nrow();    
      66             : 
      67          44 :     if(sortedI.size()!= nrows){
      68           0 :       throw std::runtime_error("Time-sorted row vector must have same size as MS.");
      69             :     }
      70             : 
      71          44 :     time.resize(nrows);
      72          44 :     fieldID.resize(nrows);
      73          44 :     sourceID.resize(nrows);
      74     1024534 :     for(size_t ii=0; ii<nrows; ++ii)
      75             :     {
      76     1024490 :       size_t i = sortedI[ii];
      77             : 
      78     1024490 :       time[ii]=t(i);
      79     1024490 :       fieldID[ii]=f(i);
      80     1024490 :       if (srcmap.count(f(i)) == 0)
      81             :       {
      82           0 :         throw std::runtime_error("Encountered data without associated source");
      83             :       }
      84             :       /**checking if compiler version has map::at*/
      85             : #if __GNUC__ <= 4 and __GNUC_MINOR__ < 1
      86             :       sourceID[ii]=srcmap[(f(i))];
      87             : #else
      88     1024490 :       sourceID[ii]=srcmap.at(f(i));
      89             : #endif
      90             : 
      91             :     }
      92          44 :   }
      93             : 
      94             : 
      95           0 :   std::ostream & operator<<(std::ostream &o, 
      96             :                             const StateIntentMap &t)
      97             :   {
      98           0 :     o<<"     Map between State_ID and Scan Intents "<<std::endl
      99           0 :      <<"----------------------------------------------"<<std::endl;
     100           0 :     for(StateIntentMap::const_iterator i=t.begin(); 
     101           0 :         i!= t.end(); 
     102           0 :         ++i)
     103             :     {
     104           0 :       o<<i->first<<": "<<i->second
     105           0 :        <<std::endl;
     106             :     }
     107           0 :     return o;
     108             :   }
     109             : 
     110             : 
     111          26 :   void scanIntents(const casacore::MeasurementSet &ms,
     112             :                    StateIntentMap &mi)
     113             :   {
     114          26 :     mi.clear();
     115          26 :     casacore::MSState state(ms.state());
     116             :     const casacore::ScalarColumn<casacore::String> modes(state,
     117          26 :                                                    casacore::MSState::columnName(casacore::MSState::OBS_MODE));
     118          58 :     for(size_t i=0; i<state.nrow(); ++i)
     119             :     {
     120          32 :       casacore::String t;
     121          32 :       modes.get(i,t);
     122          32 :       mi.insert(std::pair<size_t, std::string>(i, t));
     123          32 :     }
     124          26 :   }
     125             : 
     126          26 :   std::set<size_t> skyStateIDs(const casacore::MeasurementSet &ms)
     127             :   {
     128          26 :     std::set<size_t> res;
     129          26 :     StateIntentMap mi;
     130          26 :     scanIntents(ms, mi);
     131          26 :     for(StateIntentMap::const_iterator i=mi.begin();
     132          58 :         i!=mi.end();
     133          32 :         ++i)
     134             :     {
     135          32 :       if((i->second.find("ON_SOURCE") != i->second.npos
     136           2 :           || i->second.find("REFERENCE") != i->second.npos
     137           2 :           || i->second.find("SIGNAL") != i->second.npos)
     138          34 :          && (i->second.find("CALIBRATE_ATMOSPHERE") == i->second.npos))
     139             :         {
     140          26 :           res.insert(i->first);
     141             :         }
     142             :     }
     143          52 :     return res;
     144          26 :   }
     145             : 
     146           0 :   field_t getFieldNames(const casacore::MeasurementSet &ms)
     147             :   {
     148           0 :     field_t res;
     149           0 :     const casacore::MSField & fieldT(ms.field());
     150           0 :     const size_t nfields=fieldT.nrow();
     151             : 
     152           0 :     casacore::MSFieldColumns fcols(fieldT);
     153           0 :     const casacore::ScalarColumn<casacore::String> &names (fcols.name());
     154           0 :     for(size_t i=0; i<nfields; ++i)
     155             :     {
     156           0 :       res.insert(field_t::value_type(i, std::string(names(i))));
     157             :     }
     158           0 :     return res;
     159           0 :   }
     160             : 
     161          23 :   field_t getSourceNames(const casacore::MeasurementSet &ms)
     162             :   {
     163          23 :     field_t res;
     164          23 :     const casacore::MSSource & srcTab(ms.source());
     165          23 :     const size_t nsource=srcTab.nrow();
     166             : 
     167          23 :     casacore::MSSourceColumns scols(srcTab);
     168          23 :     const casacore::ScalarColumn<casacore::String> &names (scols.name());
     169          23 :     const casacore::ScalarColumn<casacore::Int> & ids (scols.sourceId());
     170        8163 :     for(size_t i=0; i<nsource; ++i)
     171             :     {
     172        8140 :       res.insert(field_t::value_type(ids(i), std::string(names(i))));
     173             :     }
     174          46 :     return res;
     175             :     
     176          23 :   }
     177             : 
     178           2 :   std::set<size_t> getSrcFields(const casacore::MeasurementSet &ms,
     179             :                                 const std::string &source)
     180             :   {
     181           2 :     std::set<size_t> res;
     182           2 :     const casacore::MSField & fieldT(ms.field());
     183           2 :     const size_t nfields=fieldT.nrow();
     184             : 
     185           2 :     field_t sources=getSourceNames(ms);
     186             : 
     187           2 :     casacore::MSFieldColumns fcols(fieldT);
     188           2 :     const casacore::ScalarColumn<casacore::Int> &fieldsrc (fcols.sourceId());
     189          34 :     for(size_t i=0; i<nfields; ++i)
     190             :     {
     191             :       try {
     192          32 :         if(sources.at(fieldsrc(i))==source)
     193           2 :           res.insert(i);
     194             :       }
     195           0 :       catch (const std::out_of_range &e)
     196             :       {
     197           0 :         std::cout<<"ERROR: Could not find source name for source ID " <<fieldsrc(i)<<std::endl
     198           0 :                  <<"       This could be related to CSV-910"<<std::endl
     199           0 :                  <<"       Continuing with processing but the statistics might be affected by this"<<std::endl
     200           0 :                  <<std::endl;
     201           0 :       }
     202             :     }
     203           4 :     return res;
     204           2 :   }
     205             : 
     206          70 :   std::map<size_t, size_t> getFieldSrcMap(const casacore::MeasurementSet &ms)
     207             :   {
     208          70 :     std::map<size_t, size_t> res;
     209          70 :     const casacore::MSField & fieldT(ms.field());
     210          70 :     const size_t nfields=fieldT.nrow();
     211          70 :     casacore::MSFieldColumns fcols(fieldT);
     212          70 :     const casacore::ScalarColumn<casacore::Int> &fieldsrc (fcols.sourceId());
     213        1034 :     for(size_t i=0; i<nfields; ++i)
     214             :     {
     215         964 :       res.insert(std::pair<size_t, size_t>(i, fieldsrc(i)));
     216             :     }
     217         140 :     return res;
     218          70 :   }
     219             : }
     220             : 
     221             : 

Generated by: LCOV version 1.16