File: tMSDerivedValues.cc

package info (click to toggle)
casacore 3.8.0-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 51,908 kB
  • sloc: cpp: 471,569; fortran: 16,372; ansic: 7,416; yacc: 4,714; lex: 2,346; sh: 1,865; python: 629; perl: 531; sed: 499; csh: 201; makefile: 32
file content (123 lines) | stat: -rw-r--r-- 4,294 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
//# tMSDerivedValues: Tests the MSDerivedValues class
//# Copyright (C) 1997,1998,1999,2000,2001
//# Associated Universities, Inc. Washington DC, USA.
//#
//# This program is free software; you can redistribute it and/or modify it
//# under the terms of the GNU General Public License as published by the Free
//# Software Foundation; either version 2 of the License, or (at your option)
//# any later version.
//#
//# This program is distributed in the hope that it will be useful, but WITHOUT
//# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
//# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
//# more details.
//#
//# You should have received a copy of the GNU General Public License along
//# with this program; if not, write to the Free Software Foundation, Inc.,
//# 675 Massachusetts Ave, Cambridge, MA 02139, USA.
//#
//# Correspondence concerning AIPS++ should be addressed as follows:
//#        Internet email: casa-feedback@nrao.edu.
//#        Postal address: AIPS++ Project Office
//#                        National Radio Astronomy Observatory
//#                        520 Edgemont Road
//#                        Charlottesville, VA 22903-2475 USA

#include <casacore/ms/MSOper/MSDerivedValues.h>
#include <casacore/casa/iostream.h>
#include <casacore/casa/iomanip.h>
#include <casacore/casa/Exceptions/Error.h>
#include <casacore/casa/Quanta/MVAngle.h>
#include <casacore/casa/Quanta/MVTime.h>
#include <casacore/casa/IO/ArrayIO.h>

#include <casacore/casa/namespace.h>
int main()
{
  try {
    Quantity longitude; Quantity::read(longitude,"149.33.00.5");
    cout << "longitude: "<<MVAngle(longitude)<<endl;
    Quantity latitude;  Quantity::read(latitude,"-30.18.46.385");
    cout << "latitude : "<<MVAngle(latitude)<<endl;
    Vector<MPosition> pos(1);
    pos(0)=MPosition(Quantity(236.9,"m"),longitude,latitude,
		     MPosition::Ref(MPosition::WGS84));

    MSDerivedValues msd;
    msd.setAntennaPositions(pos);

    Quantity time; MVTime::read(time,"today");
    MEpoch today(time);

    cout <<" Current time: "<<MVTime(today.getValue())<<endl;

    msd.setEpoch(today);

    MEpoch last = msd.last();
    
    cout <<" Current last: "<< MVTime(last.getValue())<<endl;

    Quantity ra; Quantity::read(ra,"12:00:00.0");
    Quantity dec; Quantity::read(dec,"-30.00.00.0");
    MDirection mySource(ra,dec);
   
    cout <<" FieldCenter: "<< mySource.getAngle("deg") <<endl;

    msd.setFieldCenter(mySource);

    cout <<" Hour angle : "<< MVAngle(msd.hourAngle()) <<endl;

    cout <<" Az & El    : "<< msd.azel().getAngle("deg")<<endl;

    Vector<String> mount(1); mount(0)="alt-az";

    msd.setAntennaMount(mount);

    cout << " Par. angle: "<< MVAngle(msd.parAngle()) << endl;

    // test the obsVel conversion
    
    cout << " observatory velocity in LSR  frame: "<< msd.obsVel().get("km/s").
      getValue() << "km/s"<<endl;

    msd.setVelocityFrame(MRadialVelocity::BARY);
    cout << " observatory velocity in BARY frame: "<< msd.obsVel().get("km/s").
      getValue() << "km/s"<<endl;

    
    msd.setVelocityFrame(MRadialVelocity::GEO);
    cout << " observatory velocity in GEO frame: "<< msd.obsVel().get("km/s").
      getValue() << "km/s"<<endl;

    Quantity restFreq(1.42041,"GHz");
    Quantity radioVel(2196.25,"km/s");
    msd.setVelocityReference(MDoppler::RADIO);
    msd.setFrequencyReference(MFrequency::TOPO);
    cout << "radio velocity " << radioVel << " is frequency " << 
      msd.toFrequency(radioVel, restFreq) << endl;
    //====
    /*
    MSDerivedValues msd1;
    MeasurementSet ms("/home/rohir/kgolap/Regression/ALMATST1/NGC5921/ngc5921.ms");
    msd1.setMeasurementSet(ms);
    msd1.setVelocityReference(MDoppler::RADIO);
    msd1.setFrequencyReference(MFrequency::LSRK);
    //locate restFrequency for field 0 and spwid 0
    Bool hasRestFreq=msd1.setRestFrequency(0,0);
    if(!hasRestFreq){
      cout << "Ou la la .....has no restfrequency in this ms" << endl;
    }
    else{
     cout << "radio velocity " << radioVel << " is frequency " << 
       msd1.toFrequency(radioVel) << endl; 
    }
    */

    } catch (std::exception& x) {
	cout << "Caught exception " << endl;
	cout << x.what() << endl;
	return 1;
    } 
    cout << "Done." << endl;
    return 0;
}