//#--------------------------------------------------------------------------- //# SDMathWrapper.cc: 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: //#--------------------------------------------------------------------------- #include "SDMathWrapper.h" #include "SDMath.h" using namespace asap; using namespace casa; SDMemTableWrapper SDMathWrapper::quotient(const SDMemTableWrapper& on, const SDMemTableWrapper& off) { SDMath sdm; return SDMemTableWrapper(sdm.quotient(on.getCP(), off.getCP())); } void SDMathWrapper::scaleInSitu(SDMemTableWrapper& in, float factor, bool doAll) { SDMemTable* pIn = in.getPtr(); const uInt what = 0; // SDMath sdm; SDMemTable* pOut = sdm.simpleOperate (*pIn, Float(factor), Bool(doAll), what); *pIn = *pOut; delete pOut; } SDMemTableWrapper SDMathWrapper::scale(const SDMemTableWrapper& in, float factor, bool doAll) { const CountedPtr& pIn = in.getCP(); const uInt what = 0; SDMath sdm; return CountedPtr(sdm.simpleOperate(*pIn, Float(factor), Bool(doAll), what)); } void SDMathWrapper::addInSitu(SDMemTableWrapper& in, float offset, bool doAll) { SDMemTable* pIn = in.getPtr(); const uInt what = 1; // SDMath sdm; SDMemTable* pOut = sdm.simpleOperate (*pIn, Float(offset), Bool(doAll), what); *pIn = *pOut; delete pOut; } SDMemTableWrapper SDMathWrapper::add(const SDMemTableWrapper& in, float offset, bool doAll) { const CountedPtr& pIn = in.getCP(); const uInt what = 1; SDMath sdm; return CountedPtr(sdm.simpleOperate(*pIn, Float(offset), Bool(doAll), what)); } void SDMathWrapper::smoothInSitu(SDMemTableWrapper& in, const std::string& kernel, float width, bool doAll) { SDMemTable* pIn = in.getPtr(); SDMath sdm; SDMemTable* pOut = sdm.smooth(*pIn, String(kernel), Float(width), Bool(doAll)); *pIn = *pOut; delete pOut; } SDMemTableWrapper SDMathWrapper::smooth (const SDMemTableWrapper& in, const std::string& kernel, float width, bool doAll) { const CountedPtr& pIn = in.getCP(); SDMath sdm; return CountedPtr(sdm.smooth(*pIn, String(kernel), Float(width), Bool(doAll))); } void SDMathWrapper::binInSitu(SDMemTableWrapper& in, int width) { SDMemTable* pIn = in.getPtr(); SDMath sdm; SDMemTable* pOut = sdm.bin (*pIn, Int(width)); *pIn = *pOut; delete pOut; } SDMemTableWrapper SDMathWrapper::bin (const SDMemTableWrapper& in, int width) { const CountedPtr& pIn = in.getCP(); SDMath sdm; return CountedPtr(sdm.bin(*pIn, Int(width))); } void SDMathWrapper::averagePolInSitu(SDMemTableWrapper& in, const std::vector& mask) { SDMemTable* pIn = in.getPtr(); SDMath sdm; SDMemTable* pOut = sdm.averagePol (*pIn, mask); *pIn = *pOut; delete pOut; } SDMemTableWrapper SDMathWrapper::averagePol (const SDMemTableWrapper& in, const std::vector& mask) { const CountedPtr& pIn = in.getCP(); SDMath sdm; return CountedPtr(sdm.averagePol(*pIn, mask)); } std::vector SDMathWrapper::statistic(const SDMemTableWrapper& in, const std::vector& mask, const std::string& which) { SDMath sdm; return sdm.statistic(in.getCP(), mask, which); }