source: trunk/src/python_asap.cpp@ 1671

Last change on this file since 1671 was 1598, checked in by Malte Marquarding, 15 years ago

Ticket #170: added scantable.get_coordinate(row). Note that this in the specified reference frame NOT in the basese frame, e.g. usually LSRK/BARY not TOPO. That means that coord.to_frequency(coord.get_rerencepixel()) != coord.get_reference_value(). You need to run {{{freq_align to rectify this

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 3.5 KB
RevLine 
[2]1//#---------------------------------------------------------------------------
[875]2//# python_asap.cc: python module for single dish package asap
[2]3//#---------------------------------------------------------------------------
4//# Copyright (C) 2004
[125]5//# ATNF
[2]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//#
[30]29//# $Id: python_asap.cpp 1598 2009-07-08 01:22:27Z MalteMarquarding $
[2]30//#---------------------------------------------------------------------------
31#include <string>
32#include <vector>
[125]33
[2]34#include <boost/python.hpp>
[95]35#include <boost/python/exception_translator.hpp>
[2]36
[125]37#include <casa/aips.h>
38#include <casa/Exceptions/Error.h>
[875]39#include "ScantableWrapper.h"
[125]40
[1501]41#ifndef HAVE_LIBPYRAP
42 #include "pyconversions.h"
43#else
44 #include <pyrap/Converters/PycExcp.h>
45 #include <pyrap/Converters/PycBasicData.h>
46#endif
[875]47
48#include "python_asap.h"
[2]49
[1501]50#ifndef HAVE_LIBPYRAP
[95]51namespace asap {
52 namespace python {
[1501]53
[125]54void translate_ex(const casa::AipsError& e)
[95]55{
56 // Use the Python 'C' API to set up an exception object
57 PyErr_SetString(PyExc_RuntimeError, e.what());
58}
59
60 }
61}
[1501]62#endif
63
[2]64using namespace boost::python;
65
[95]66BOOST_PYTHON_MODULE(_asap) {
[875]67 asap::python::python_Scantable();
68 asap::python::python_STFiller();
69 asap::python::python_STSelector();
70 asap::python::python_STMath();
[894]71 asap::python::python_Fitter();
[881]72 asap::python::python_STLineFinder();
[960]73 asap::python::python_STFitEntry();
[988]74 asap::python::python_STWriter();
[1126]75 asap::python::python_LineCatalog();
[1501]76 asap::python::python_Logger();
[1598]77 asap::python::python_STCoordinate();
[988]78
[1501]79#ifndef HAVE_LIBPYRAP
80 // Use built-in pyconversions.h
[125]81 register_exception_translator<casa::AipsError>(&asap::python::translate_ex);
[875]82 from_python_sequence < std::vector< asap::ScantableWrapper >,
83 variable_capacity_policy > ();
[2]84 std_vector_to_tuple < int > ();
[95]85 from_python_sequence < std::vector < int >,
[2]86 variable_capacity_policy > ();
[1112]87 std_vector_to_tuple < uint > ();
88 from_python_sequence < std::vector < uint >,
89 variable_capacity_policy > ();
[2]90 std_vector_to_tuple < float > ();
[95]91 from_python_sequence < std::vector < float >,
[2]92 variable_capacity_policy > ();
[42]93 std_vector_to_tuple < double > ();
[95]94 from_python_sequence < std::vector < double >,
[42]95 variable_capacity_policy > ();
[2]96 std_vector_to_tuple < std::string > ();
[95]97 from_python_sequence < std::vector < std::string >,
[2]98 variable_capacity_policy > ();
99 std_vector_to_tuple < bool> ();
[95]100 from_python_sequence < std::vector < bool >,
[2]101 variable_capacity_policy > ();
[1501]102#else
103 casa::pyrap::register_convert_excp();
104 casa::pyrap::register_convert_basicdata();
105 casa::pyrap::register_convert_std_vector<asap::ScantableWrapper>();
106#endif
[2]107}
Note: See TracBrowser for help on using the repository browser.