X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=common%2FclitkCommonGenericFilter.h;h=13491f7f3722ab41d905b7b5ae8e419466ab85fb;hb=d55f025b18f68066a52b8f33c2dc6481e82c2580;hp=751a7262a63b1a97122658ccb93eba3c441e8de1;hpb=8186ce7844751ffa0bd43e8a6ed53d1cc050b843;p=clitk.git diff --git a/common/clitkCommonGenericFilter.h b/common/clitkCommonGenericFilter.h index 751a726..13491f7 100644 --- a/common/clitkCommonGenericFilter.h +++ b/common/clitkCommonGenericFilter.h @@ -1,36 +1,26 @@ /*========================================================================= + Program: vv http://www.creatis.insa-lyon.fr/rio/vv - Program: clitk - Module: $RCSfile: clitkCommonGenericFilter.h,v $ - Language: C++ - Date: $Date: 2010/01/29 08:48:42 $ - Version: $Revision: 1.1 $ - Author : Joel Schaerer - David Sarrut + Authors belong to: + - University of LYON http://www.universite-lyon.fr/ + - Léon Bérard cancer center http://www.centreleonberard.fr + - CREATIS CNRS laboratory http://www.creatis.insa-lyon.fr - Copyright (C) 2008 - Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr - CREATIS-LRMN http://www.creatis.insa-lyon.fr + This software is distributed WITHOUT ANY WARRANTY; without even + the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR + PURPOSE. See the copyright notices for more information. - 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, version 3 of the License. + It is distributed under dual licence - 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, see . - - =========================================================================*/ + - BSD See included LICENSE.txt file + - CeCILL-B http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html +===========================================================================**/ #ifndef CLITKCOMMONGENERICFILTER_H #define CLITKCOMMONGENERICFILTER_H -// clitk include #include "clitkCommon.h" +#include "clitkFilterBase.h" /*-------------------------------------------------------------------- DISCLAIMER : I obviously know how to make this mess much clearer and @@ -45,18 +35,17 @@ namespace clitk { class GenericFilterFunctorBase { public: GenericFilterFunctorBase(FilterType * f) { mFilter = f; } - virtual void DoIt()= 0; + virtual ~GenericFilterFunctorBase() { delete mFilter; } + virtual void Execute()= 0; FilterType * mFilter; }; //-------------------------------------------------------------------- - template + template class GenericFilterFunctorWithDimAndPixelType: public GenericFilterFunctorBase { public: GenericFilterFunctorWithDimAndPixelType(FilterType * f): GenericFilterFunctorBase(f) {} - virtual void DoIt() { - //GenericFilterFunctorBase::mFilter->template UpdateWithDimAndPixelType(); - typedef itk::Image InputImageType; + virtual void Execute() { GenericFilterFunctorBase::mFilter->template UpdateWithInputImageType(); } }; @@ -66,20 +55,28 @@ namespace clitk { class ImageTypesManager { public: typedef std::map*> MapOfPixelTypeToFunctionType; - std::map mMapOfImageTypeToFunction; + typedef std::map MapOfImageComponentsToFunctionType; + typedef std::map MapOfImageDimensionToFunctionType; + MapOfImageDimensionToFunctionType mMapOfImageTypeToFunction; ImageTypesManager(FilterType * f) { mFilter = f; } - virtual void DoIt(int dim, std::string pixelname) { - // std::cout << "ImageTypesManager DoIt " << dim << " " << pixelname << std::endl; - if (mMapOfImageTypeToFunction[dim][pixelname]) - mMapOfImageTypeToFunction[dim][pixelname]->DoIt(); + virtual void DoIt(int dim, int ncomp, std::string pixelname) { + //std::cout << "ImageTypesManager DoIt " << dim << " " << pixelname << std::endl; + if (mMapOfImageTypeToFunction[dim][ncomp][pixelname]) + mMapOfImageTypeToFunction[dim][ncomp][pixelname]->Execute(); + } + template + void AddNewDimensionAndPixelType() { + typedef itk::Image,Dim> InputImageType; + mMapOfImageTypeToFunction[Dim][NComp][ GetTypeAsString() ] = + new GenericFilterFunctorWithDimAndPixelType(mFilter); } - template - void AddNewDimensionAndPixelType() { - // std::cout << "Adding Dim=" << Dim << " and PT = " << GetTypeAsString() << std::endl; - mFilter->AddImageType(Dim, GetTypeAsString()); - mMapOfImageTypeToFunction[Dim][ GetTypeAsString() ] = - new GenericFilterFunctorWithDimAndPixelType(mFilter); + /// Specialization for NComp == 1 + template + void AddNewDimensionAndPixelType() { + typedef itk::Image InputImageType; + mMapOfImageTypeToFunction[Dim][1][ GetTypeAsString() ] = + new GenericFilterFunctorWithDimAndPixelType(mFilter); } FilterType * mFilter; };