source: branches/mergetest/src/python_Scantable.cpp @ 1779

Last change on this file since 1779 was 1779, checked in by Kana Sugimoto, 14 years ago

New Development: Yes

JIRA Issue: No (test merging alma branch)

Ready for Test: Yes

Interface Changes: Yes

What Interface Changed:

Test Programs:

Put in Release Notes: No

Module(s):

Description:


  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.4 KB
Line 
1//#---------------------------------------------------------------------------
2//# python_Scantable.cc: python exposure of c++ Scantable class
3//#---------------------------------------------------------------------------
4//# Copyright (C) 2004
5//# ATNF
6//#
7//# This program is free software; you can redistribute it and/or modify it
8//# under the terms of the GNU General Public License as published by the Free
9//# Software Foundation; either version 2 of the License, or (at your option)
10//# any later version.
11//#
12//# This program is distributed in the hope that it will be useful, but
13//# WITHOUT ANY WARRANTY; without even the implied warranty of
14//# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General
15//# Public License for more details.
16//#
17//# You should have received a copy of the GNU General Public License along
18//# with this program; if not, write to the Free Software Foundation, Inc.,
19//# 675 Massachusetts Ave, Cambridge, MA 02139, USA.
20//#
21//# Correspondence concerning this software should be addressed as follows:
22//#        Internet email: Malte.Marquarding@csiro.au
23//#        Postal address: Malte Marquarding,
24//#                        Australia Telescope National Facility,
25//#                        P.O. Box 76,
26//#                        Epping, NSW, 2121,
27//#                        AUSTRALIA
28//#
29//# $Id: python_Scantable.cpp 1779 2010-07-29 09:13:46Z KanaSugimoto $
30//#---------------------------------------------------------------------------
31#include <vector>
32
33#include <boost/python.hpp>
34#include <boost/python/args.hpp>
35
36#include "ScantableWrapper.h"
37
38using namespace boost::python;
39
40namespace asap {
41  namespace python {
42
43void python_Scantable() {
44  class_<ScantableWrapper>("Scantable")
45    //.def( init <> () )
46    .def( init < int > () )
47    .def( init < const std::string&, int > () )
48    .def( init < const ScantableWrapper& > () )
49    .def("_copy", &ScantableWrapper::copy)
50    .def("_assign", &ScantableWrapper::assign)
51    .def("getif", &ScantableWrapper::getIF)
52    .def("getifnos", &ScantableWrapper::getIFNos)
53    .def("getbeam", &ScantableWrapper::getBeam)
54    .def("getbeamnos", &ScantableWrapper::getBeamNos)
55    .def("getpol", &ScantableWrapper::getPol)
56    .def("getpolnos", &ScantableWrapper::getPolNos)
57    .def("getscan", &ScantableWrapper::getScan)
58    .def("getscannos", &ScantableWrapper::getScanNos)
59    .def("getcycle", &ScantableWrapper::getCycle)
60    .def("getmolnos", &ScantableWrapper::getMolNos)
61    .def("nif", &ScantableWrapper::nif,
62         (boost::python::arg("scanno")=-1) )
63    .def("nbeam", &ScantableWrapper::nbeam,
64         (boost::python::arg("scanno")=-1) )
65    .def("npol", &ScantableWrapper::npol,
66         (boost::python::arg("scanno")=-1) )
67    .def("nchan", &ScantableWrapper::nchan,
68         (boost::python::arg("ifno")=-1) )
69    .def("ncycle", &ScantableWrapper::ncycle,
70         (boost::python::arg("scanno")=-1) )
71    .def("nscan", &ScantableWrapper::nscan)
72    .def("nrow", &ScantableWrapper::nrow)
73    .def("get_fluxunit", &ScantableWrapper::getFluxUnit)
74    .def("set_fluxunit", &ScantableWrapper::setFluxUnit)
75    .def("_setInstrument", &ScantableWrapper::setInstrument)
76    .def("_setfeedtype", &ScantableWrapper::setFeedType)
77    .def("_getspectrum", &ScantableWrapper::getSpectrum,
78         (arg("whichrow")=0, arg("poltype")=std::string("")) )
79    .def("poltype", &ScantableWrapper::getPolType )
80    .def("get_column_names", &ScantableWrapper::columnNames)
81    .def("_getpollabel", &ScantableWrapper::getPolarizationLabel)
82    .def("_setspectrum",&ScantableWrapper::setSpectrum,
83         (boost::python::arg("whichrow")=0) )
84    .def("_getabcissa", &ScantableWrapper::getAbcissa,
85         (boost::python::arg("whichrow")=0) )
86    .def("_getabcissalabel", &ScantableWrapper::getAbcissaLabel,
87         (boost::python::arg("whichrow")=0) )
88    .def("_getmask", &ScantableWrapper::getMask,
89         (boost::python::arg("whichrow")=0) )
90    .def("_getclipmask", &ScantableWrapper::getClipMask,
91         (boost::python::arg("whichrow")=0) )
92    .def("_gettsys", &ScantableWrapper::getTsys)
93    .def("_getsourcename", &ScantableWrapper::getSourceName,
94         (boost::python::arg("whichrow")=0) )
95    .def("_getelevation", &ScantableWrapper::getElevation,
96         (boost::python::arg("whichrow")=0) )
97    .def("_getazimuth", &ScantableWrapper::getAzimuth,
98         (boost::python::arg("whichrow")=0) )
99    .def("_getparangle", &ScantableWrapper::getParAngle,
100         (boost::python::arg("whichrow")=0) )
101    .def("_gettime", &ScantableWrapper::getTime,
102         (boost::python::arg("whichrow")=0) )
103    .def("_getinttime", &ScantableWrapper::getIntTime,
104         (boost::python::arg("whichrow")=0) )
105    .def("_getdirection", &ScantableWrapper::getDirectionString,
106         (boost::python::arg("whichrow")=0) )
107    .def("get_antennaname", &ScantableWrapper::getAntennaName)
108    .def("_flag", &ScantableWrapper::flag)
109    .def("_flag_row", &ScantableWrapper::flagRow)
110    .def("_getflagrow", &ScantableWrapper::getFlagRow,
111         (boost::python::arg("whichrow")=0) )
112    .def("_clip", &ScantableWrapper::clip,
113         (boost::python::arg("clipoutside")=true,
114          boost::python::arg("unflag")=false) )
115    .def("_save",  &ScantableWrapper::makePersistent)
116    .def("_summary",  &ScantableWrapper::summary,
117         (boost::python::arg("verbose")=true) )
118    //.def("_getrestfreqs",  &ScantableWrapper::getRestFrequencies)
119    .def("_getrestfreqs",  &ScantableWrapper::getRestFrequency)
120    .def("_setrestfreqs",  &ScantableWrapper::setRestFrequencies)
121    .def("shift_refpix", &ScantableWrapper::shift)
122    .def("_setcoordinfo", &ScantableWrapper::setCoordInfo)
123    .def("_getcoordinfo", &ScantableWrapper::getCoordInfo)
124    .def("set_dirframe", &ScantableWrapper::setDirection,
125         (boost::python::arg("refstr")="") )
126    .def("_gethistory", &ScantableWrapper::getHistory)
127    .def("_addhistory", &ScantableWrapper::addHistory)
128    .def("_getselection", &ScantableWrapper::getSelection)
129    .def("_setselection", &ScantableWrapper::setSelection)
130    .def("_addfit", &ScantableWrapper::addFit)
131    .def("_getfit", &ScantableWrapper::getFit)
132    .def("_recalcazel", &ScantableWrapper::calculateAZEL)
133    .def("_setsourcetype", &ScantableWrapper::setSourceType)
134    .def("_getdirectionvec", &ScantableWrapper::getDirectionVector)
135    .def("_parallactify", &ScantableWrapper::parallactify)
136    .def("get_coordinate", &ScantableWrapper::getCoordinate)
137    .def("_get_weather", &ScantableWrapper::getWeather)
138    .def("_reshape", &ScantableWrapper::reshapeSpectrum,
139         (boost::python::arg("nmin")=-1,
140          boost::python::arg("nmax")=-1) )
141  ;
142};
143
144  } // python
145} // asap
Note: See TracBrowser for help on using the repository browser.