]> Creatis software - clitk.git/blob - filters/clitkGuerreroVentilationGenericFilter.h
- new GF system
[clitk.git] / filters / clitkGuerreroVentilationGenericFilter.h
1 /*-------------------------------------------------------------------------
2
3   Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
4   l'Image). All rights reserved. See Doc/License.txt or
5   http://www.creatis.insa-lyon.fr/Public/Gdcm/License.html for details.
6                                                                                 
7      This software is distributed WITHOUT ANY WARRANTY; without even
8      the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
9      PURPOSE.  See the above copyright notices for more information.
10                                                                              
11 -------------------------------------------------------------------------*/
12
13 #ifndef clitkGuerreroVentilationGenericFilter_H
14 #define clitkGuerreroVentilationGenericFilter_H
15
16 /**
17  -------------------------------------------------------------------
18  * @file   clitkGuerreroVentilationGenericFilter.h
19  * @author David Sarrut <David.Sarrut@creatis.insa-lyon.fr>
20  * @date   23 Feb 2008
21  -------------------------------------------------------------------*/
22
23 // clitk include
24 #include "clitkCommon.h"
25 #include "clitkImageCommon.h"
26 #include "clitkImageToImageGenericFilter.h"
27
28 // itk include
29 #include "itkImage.h"
30 #include "itkImageIOBase.h"
31 #include "itkImageRegionIterator.h"
32 #include "itkImageRegionConstIterator.h"
33
34 namespace clitk {
35   
36   //--------------------------------------------------------------------
37   class GuerreroVentilationGenericFilter : 
38   public ImageToImageGenericFilter<GuerreroVentilationGenericFilter> {
39   public:
40         
41     // Constructor 
42     GuerreroVentilationGenericFilter();
43     virtual ~GuerreroVentilationGenericFilter() {}
44
45     // Types
46     typedef GuerreroVentilationGenericFilter  Self;
47     typedef ImageToImageGenericFilterBase     Superclass;
48     typedef itk::SmartPointer<Self>       Pointer;
49     typedef itk::SmartPointer<const Self> ConstPointer;
50
51     // New
52     itkNewMacro(Self);
53     
54     // Set methods
55     void SetBloodCorrectionFactor(double f) {blood_mass_factor=f;}
56     void SetUseCorrectFormula(bool u) {use_correct_formula=u;}
57
58     //--------------------------------------------------------------------
59     // Main function called each time the filter is updated
60     template<class InputImageType>  
61     void UpdateWithInputImageType();
62
63   protected:  
64     template<unsigned int Dim> void InitializeImageType();
65     //Parameters
66     double blood_mass_factor;
67     bool use_correct_formula;
68
69   }; // end class GuerreroVentilationGenericFilter
70 //--------------------------------------------------------------------
71
72 } // end namespace
73 //--------------------------------------------------------------------
74
75 #endif //#define clitkGuerreroVentilationGenericFilter_H
76