//# FiltrationTVI.cc: Template class for data filtering TVI //# Copyright (C) 1996,1997,1998,1999,2000,2001,2002,2003 //# Associated Universities, Inc. Washington DC, USA. //# //# This library is free software; you can redistribute it and/or modify it //# under the terms of the GNU Library General Public License as published by //# the Free Software Foundation; either version 2 of the License, or (at your //# option) any later version. //# //# This library 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 Library General Public //# License for more details. //# //# You should have received a copy of the GNU Library General Public License //# along with this library; if not, write to the Free Software Foundation, //# Inc., 675 Massachusetts Ave, Cambridge, MA 02139, USA. //# //# Correspondence concerning AIPS++ should be addressed as follows: //# Internet email: aips2-request@nrao.edu. //# Postal address: AIPS++ Project Office //# National Radio Astronomy Observatory //# 520 Edgemont Road //# Charlottesville, VA 22903-2475 USA //# #include #include #include #include #include #include using namespace casacore; namespace casa { //# NAMESPACE CASA - BEGIN namespace vi { //# NAMESPACE vi - BEGIN // explicit instantiation of template class template class FiltrationTVI; // Factory FiltrationTVIFactory::FiltrationTVIFactory(casacore::Record const &configuration, ViImplementation2 *inputVII) : inputVII_p(inputVII), configuration_p(configuration) { } FiltrationTVIFactory::~FiltrationTVIFactory() { } ViImplementation2 * FiltrationTVIFactory::createVi() const { ViImplementation2 *vii = nullptr; if (!configuration_p.isDefined("type")) { throw AipsError(String("You have to specify Filtering type")); } Int const type_indicator = configuration_p.asInt("type"); switch(type_indicator) { case FilteringType::SDDoubleCircleFilter: { // new filter impl vii = new FiltrationTVI(inputVII_p, configuration_p); break; } default: { // unsupported type, throw exception throw AipsError(String("Invalid FilteringType for FiltrationTVI: ")+String::toString(type_indicator)); break; } } return vii; } // LayerFactory FiltrationTVILayerFactory::FiltrationTVILayerFactory(Record const &configuration) : ViiLayerFactory(), configuration_p(configuration) { } ViImplementation2 * FiltrationTVILayerFactory::createInstance( ViImplementation2* vii0) const { // Make the FiltrationTVI, using supplied ViImplementation2, and return it FiltrationTVIFactory factory(configuration_p, vii0); ViImplementation2 *vii = nullptr; try { vii = factory.createVi(); } catch (...) { if (vii0) { delete vii0; } throw; } return vii; } } //# NAMESPACE vi - END } //# NAMESPACE CASA - END