//#--------------------------------------------------------------------------- //# SDMathWrapper.h: Wrapper classes to use CountedPtr //#--------------------------------------------------------------------------- //# Copyright (C) 2004 //# ATNF //# //# 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 this software should be addressed as follows: //# Internet email: Malte.Marquarding@csiro.au //# Postal address: Malte Marquarding, //# Australia Telescope National Facility, //# P.O. Box 76, //# Epping, NSW, 2121, //# AUSTRALIA //# //# $Id: //#--------------------------------------------------------------------------- #ifndef SDMATHWRAPPER_H #define SDMATHWRAPPER_H #include #include #include #include "SDMemTableWrapper.h" #include "SDMath.h" namespace asap { namespace SDMathWrapper { SDMemTableWrapper average(const SDMemTableWrapper& sdt) { return SDMemTableWrapper(SDMath::average(sdt.getCP())); } SDMemTableWrapper quotient(const SDMemTableWrapper& on, const SDMemTableWrapper& off) { return SDMemTableWrapper(SDMath::quotient(on.getCP(), off.getCP())); } SDMemTableWrapper scale(const SDMemTableWrapper& in, casa::Float factor) { return SDMemTableWrapper(SDMath::multiply(in.getCP(),factor)); } void scaleInSitu(SDMemTableWrapper& in, casa::Float factor) { SDMemTable* sdmt = in.getPtr(); SDMath::multiplyInSitu(in.getPtr(),factor); } SDMemTableWrapper add(const SDMemTableWrapper& in, casa::Float offset) { return SDMemTableWrapper(SDMath::add(in.getCP(), offset)); } SDMemTableWrapper hanning(const SDMemTableWrapper& in) { return SDMemTableWrapper(SDMath::hanning(in.getCP())); } SDMemTableWrapper averages(boost::python::tuple tpl, const std::vector& mask); SDMemTableWrapper averagePol(const SDMemTableWrapper& in, const std::vector& mask) { return SDMath::averagePol(in.getCP(), mask); } SDMemTableWrapper bin(const SDMemTableWrapper& in, int width) { return SDMath::bin(in.getCP(), width); } std::vector statistic(const SDMemTableWrapper& in, const std::vector& mask, const std::string& which) { return SDMath::statistic(in.getCP(), mask, which); } }; } // namespace #endif