LCOV - code coverage report
Current view: top level - synthesis/TransformMachines/test - MakeMS.h (source / functions) Hit Total Coverage
Test: ctest_coverage.info Lines: 34 34 100.0 %
Date: 2023-11-02 14:27:30 Functions: 1 1 100.0 %

          Line data    Source code
       1             : //# MakeMS: Tests 
       2             : //# Copyright (C) 2016
       3             : //# Associated Universities, Inc. Washington DC, USA.
       4             : //#
       5             : //# This program is free software; you can redistribute it and/or modify it
       6             : //# under the terms of the GNU General Public License as published by the Free
       7             : //# Software Foundation; either version 2 of the License, or (at your option)
       8             : //# any later version.
       9             : //#
      10             : //# This program is distributed in the hope that it will be useful, but WITHOUT
      11             : //# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
      12             : //# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
      13             : //# more details.
      14             : //#
      15             : //# You should have received a copy of the GNU General Public License along
      16             : //# with this program; if not, write to the Free Software Foundation, Inc.,
      17             : //# 675 Massachusetts Ave, Cambridge, MA 02139, USA.
      18             : //#
      19             : //# Correspondence concerning AIPS++ should be addressed as follows:
      20             : //#        Internet email: aips2-request@nrao.edu.
      21             : //#        Postal address: AIPS++ Project Office
      22             : //#                        National Radio Astronomy Observatory
      23             : //#                        520 Edgemont Road
      24             : //#                        Charlottesville, VA 22903-2475 USA
      25             : //#
      26             : //# $Id$
      27             : 
      28             : #include <casacore/casa/aips.h>
      29             : #include <casacore/casa/BasicSL/String.h>
      30             : #include <synthesis/MeasurementEquations/Simulator.h>
      31             : #include <casacore/measures/Measures/MDirection.h>
      32             : #include <casacore/measures/Measures/MeasTable.h>
      33             : 
      34             : namespace casa {
      35             : 
      36             : namespace test {
      37             : 
      38             : class MakeMS {
      39             : 
      40             : public:
      41             : 
      42           1 :     static inline void makems( casacore::String msname, casacore::MDirection thedir, casacore::Double freq=1.5e9,
      43             :                         casacore::Double chanwidth=1e6, casacore::Int nchan=100, casacore::Int nInteg=200 ) {
      44             : 
      45             :         std::vector<Double> stnx={ 41.1100006,  134.110001,   268.309998,  439.410004,  
      46             :                                    644.210022,  880.309998,  1147.10999,  1442.41003,  1765.41003,
      47             :                                    -36.7900009, -121.690002,  -244.789993, -401.190002, -588.48999, 
      48             :                                    -804.690002, -1048.48999, -1318.48999, -1613.98999,
      49             :                                    -4.38999987,-11.29,       -22.7900009, -37.6899986, -55.3899994, 
      50           2 :                                    -75.8899994, -99.0899963, -124.690002, -152.690002 };
      51             :         std::vector<Double> stny={ 3.51999998, -39.8300018,  -102.480003, -182.149994, -277.589996,
      52             :                                    -387.839996, -512.119995, -649.76001,  -800.450012,
      53             :                                    -2.58999991, -59.9099998,  -142.889999, -248.410004, -374.690002,
      54             :                                    -520.599976, -685,        -867.099976, -1066.42004,
      55             :                                    77.1500015,  156.910004,   287.980011,  457.429993,  660.409973,
      56           2 :                                    894.700012,  1158.82996,  1451.43005,  1771.48999 };
      57             :         std::vector<Double> stnz={ 0.25,       -0.439999998, -1.46000004, -3.77999997, -5.9000001, 
      58             :                                    -7.28999996, -8.48999977, -10.5,       -9.56000042,
      59             :                                    0.25,       -0.699999988, -1.79999995, -3.28999996, -4.78999996,
      60             :                                    -6.48999977, -9.17000008, -12.5299997, -15.3699999,
      61             :                                    1.25999999,   2.42000008,   4.23000002,  6.65999985,  9.5,
      62           2 :                                    12.7700005,  16.6800003,  21.2299995,  26.3299999 };
      63           2 :         Vector<Double> xpos(stnx);
      64           2 :         Vector<Double> ypos(stny);
      65           2 :         Vector<Double> zpos(stnz);
      66           1 :         xpos *=5.0; ypos *=5.0;
      67           1 :         xpos-=mean(xpos); ypos-=mean(ypos); zpos-=mean(zpos);
      68           2 :         Vector<Double> diam(27, 25.0);
      69           2 :         Vector<String> antnames(27, "EVLA");
      70           2 :         Vector<String> padnames(27, "KotZot");
      71          28 :         for ( Int k=0; k <27; ++k ) {
      72          27 :             antnames[k] =antnames[k]+ String::toString(k);
      73          27 :             padnames[k]=padnames[k]+String::toString(k);
      74             :         }
      75           2 :         MPosition obsPos;
      76           1 :         casacore::MeasTable::Observatory(obsPos, "EVLA");
      77           2 :         Simulator sm(msname);
      78           2 :         sm.setconfig( "EVLA", xpos, ypos, zpos, diam, Vector<Double>(27,0.0), 
      79           2 :                       Vector<String>(27, "ALT-AZ"), antnames, padnames, "local", obsPos );
      80             :   
      81           2 :         sm.setspwindow( "Bandobast", Quantity(freq, "Hz"), Quantity(chanwidth, "Hz"),
      82           2 :                         Quantity(chanwidth, "Hz"), MFrequency::LSRK,  nchan, "RR RL LR LL" );
      83           3 :         MEpoch refdate( Quantity(57388.0, "d"), MEpoch::UTC );
      84           2 :         MeasFrame mframe(thedir, refdate, obsPos);
      85           3 :         MDirection thedir_hadec=MDirection::Convert(thedir, MDirection::Ref(MDirection::HADEC, mframe))();
      86           3 :         MEpoch lst=MEpoch::Convert(refdate, MEpoch::Ref(MEpoch::LAST, mframe))();
      87           2 :         MEpoch refepo(lst.get("d")-thedir_hadec.getValue().getLong("d"), MEpoch::UTC);
      88           1 :         sm.setfeed("perfect R L", Vector<Double>(), Vector<Double>(), Vector<String>(1, ""));
      89           1 :         sm.setlimits(0.01, Quantity(10.0, "deg"));
      90           1 :         sm.setauto(0.0);
      91           1 :         sm.setfield("2C666", thedir, "T", Quantity(0.0, "m"));
      92           1 :         sm.settimes(Quantity(1.0,"s"), true, refepo);
      93           1 :         sm.observe("2C666", "Bandobast", Quantity(-Double(nInteg)/2.0, "s"), Quantity(Double(nInteg)/2.0,"s"));
      94           1 :     }
      95             :    
      96             : 
      97             : };
      98             : 
      99             : } // namespace test
     100             : } // namespace casa

Generated by: LCOV version 1.16