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