1 | //#---------------------------------------------------------------------------
|
---|
2 | //# python_STMathWrapper.cc: python exposure of c++ STMath class
|
---|
3 | //#---------------------------------------------------------------------------
|
---|
4 | //# Copyright (C) 2004-2012
|
---|
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_STMath.cpp 2526 2012-05-15 23:33:55Z MalteMarquarding $
|
---|
30 | //#---------------------------------------------------------------------------
|
---|
31 | #include <boost/python.hpp>
|
---|
32 |
|
---|
33 | #include <vector>
|
---|
34 |
|
---|
35 | #include "STMathWrapper.h"
|
---|
36 |
|
---|
37 | using namespace boost::python;
|
---|
38 |
|
---|
39 | namespace asap {
|
---|
40 | namespace python {
|
---|
41 | void python_STMath() {
|
---|
42 | class_<STMathWrapper>("stmath")
|
---|
43 | .def( init < > () )
|
---|
44 | .def( init < bool > () )
|
---|
45 | .def("_insitu", &STMathWrapper::insitu)
|
---|
46 | .def("_setinsitu", &STMathWrapper::setInsitu)
|
---|
47 | .def("_average", &STMathWrapper::average)
|
---|
48 | .def("_averagechannel", &STMathWrapper::averageChannel)
|
---|
49 | .def("_averagepol", &STMathWrapper::averagePolarisations)
|
---|
50 | .def("_averagebeams", &STMathWrapper::averageBeams)
|
---|
51 | .def("_unaryop", &STMathWrapper::unaryOperate)
|
---|
52 | .def("_arrayop", &STMathWrapper::arrayOperate)
|
---|
53 | //.def("_array2dop", &STMathWrapper::array2dOperate)
|
---|
54 | .def("_binaryop", &STMathWrapper::binaryOperate)
|
---|
55 | .def("_auto_quotient", &STMathWrapper::autoQuotient)
|
---|
56 | .def("_quotient", &STMathWrapper::quotient)
|
---|
57 | .def("_dototalpower", &STMathWrapper::dototalpower)
|
---|
58 | .def("_dosigref", &STMathWrapper::dosigref)
|
---|
59 | .def("_donod", &STMathWrapper::donod)
|
---|
60 | .def("_dofs", &STMathWrapper::dofs)
|
---|
61 | .def("_stats", &STMathWrapper::statistic)
|
---|
62 | .def("_statsrow", &STMathWrapper::statisticRow)
|
---|
63 | .def("_minmaxchan", &STMathWrapper::minMaxChan)
|
---|
64 | .def("_freqswitch", &STMathWrapper::freqSwitch)
|
---|
65 | .def("_bin", &STMathWrapper::bin)
|
---|
66 | .def("_resample", &STMathWrapper::resample)
|
---|
67 | .def("_smooth", &STMathWrapper::smooth)
|
---|
68 | .def("_gainel", &STMathWrapper::gainElevation)
|
---|
69 | .def("_convertflux", &STMathWrapper::convertFlux)
|
---|
70 | .def("_convertpol", &STMathWrapper::convertPolarisation)
|
---|
71 | .def("_opacity", &STMathWrapper::opacity)
|
---|
72 | .def("_merge", &STMathWrapper::merge)
|
---|
73 | .def("_rotate_xyphase", &STMathWrapper::rotateXYPhase)
|
---|
74 | .def("_rotate_linpolphase", &STMathWrapper::rotateLinPolPhase)
|
---|
75 | .def("_invert_phase", &STMathWrapper::invertPhase)
|
---|
76 | .def("_swap_linears", &STMathWrapper::swapPolarisations)
|
---|
77 | .def("_freq_align", &STMathWrapper::frequencyAlign)
|
---|
78 | .def("_mx_extract", &STMathWrapper::mxExtract)
|
---|
79 | .def("_lag_flag", &STMathWrapper::lagFlag)
|
---|
80 | .def("_fft", &STMathWrapper::fft)
|
---|
81 | // testing average spectra with different channel/resolution
|
---|
82 | .def("_new_average", &STMathWrapper::new_average)
|
---|
83 | // cwcal
|
---|
84 | .def("cwcal", &STMathWrapper::cwcal)
|
---|
85 | .def("almacal", &STMathWrapper::almacal)
|
---|
86 | ;
|
---|
87 | };
|
---|
88 |
|
---|
89 | } //namespace python
|
---|
90 | } // namespace asap
|
---|
91 |
|
---|