00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017 #ifndef __itkSmoothingRecursiveGaussianImageFilter_h
00018 #define __itkSmoothingRecursiveGaussianImageFilter_h
00019
00020 #include "itkRecursiveGaussianImageFilter.h"
00021 #include "itkCastImageFilter.h"
00022 #include "itkImage.h"
00023 #include "itkPixelTraits.h"
00024 #include "itkCommand.h"
00025
00026
00027 namespace itk
00028 {
00029
00042 template <typename TInputImage,
00043 typename TOutputImage= TInputImage >
00044 class ITK_EXPORT SmoothingRecursiveGaussianImageFilter:
00045 public ImageToImageFilter<TInputImage,TOutputImage>
00046 {
00047 public:
00049 typedef SmoothingRecursiveGaussianImageFilter Self;
00050 typedef ImageToImageFilter<TInputImage,TOutputImage> Superclass;
00051 typedef SmartPointer<Self> Pointer;
00052 typedef SmartPointer<const Self> ConstPointer;
00053
00054
00056 typedef TInputImage InputImageType;
00057 typedef TOutputImage OutputImageType;
00058 typedef typename TInputImage::PixelType PixelType;
00059 typedef typename NumericTraits<PixelType>::RealType RealType;
00060 typedef typename NumericTraits<PixelType>::ScalarRealType ScalarRealType;
00061
00062
00064 itkTypeMacro(SmoothingRecursiveGaussianImageFilter,
00065 ImageToImageFilter);
00066
00068 itkStaticConstMacro(ImageDimension, unsigned int,
00069 TInputImage::ImageDimension);
00070
00075 typedef typename NumericTraits< PixelType >::FloatType InternalRealType;
00076 typedef Image<InternalRealType,
00077 itkGetStaticConstMacro(ImageDimension) > RealImageType;
00078
00080 typedef RecursiveGaussianImageFilter<
00081 InputImageType,
00082 RealImageType
00083 > FirstGaussianFilterType;
00084
00086 typedef RecursiveGaussianImageFilter<
00087 RealImageType,
00088 RealImageType
00089 > InternalGaussianFilterType;
00090
00092 typedef CastImageFilter<
00093 RealImageType,
00094 OutputImageType
00095 > CastingFilterType;
00096
00097
00099 typedef typename InternalGaussianFilterType::Pointer InternalGaussianFilterPointer;
00100
00102 typedef typename FirstGaussianFilterType::Pointer FirstGaussianFilterPointer;
00103
00105 typedef typename CastingFilterType::Pointer CastingFilterPointer;
00106
00108 typedef typename OutputImageType::Pointer OutputImagePointer;
00109
00111 itkNewMacro(Self);
00112
00114 void SetSigma( ScalarRealType sigma );
00115 itkGetMacro(Sigma, ScalarRealType);
00117
00119 void SetNormalizeAcrossScale( bool normalizeInScaleSpace );
00120 itkGetMacro( NormalizeAcrossScale, bool );
00122
00123 void SetNumberOfThreads( int nb );
00124
00125 #ifdef ITK_USE_CONCEPT_CHECKING
00126
00127 itkConceptMacro(InputHasNumericTraitsCheck,
00128 (Concept::HasNumericTraits<PixelType>));
00129
00131 #endif
00132
00133 protected:
00134 SmoothingRecursiveGaussianImageFilter();
00135 virtual ~SmoothingRecursiveGaussianImageFilter() {};
00136 void PrintSelf(std::ostream& os, Indent indent) const;
00137
00139 void GenerateData( void );
00140
00146 virtual void GenerateInputRequestedRegion() throw(InvalidRequestedRegionError);
00147
00148
00149 void EnlargeOutputRequestedRegion(DataObject *output);
00150
00151 private:
00152 SmoothingRecursiveGaussianImageFilter(const Self&);
00153 void operator=(const Self&);
00154
00155 InternalGaussianFilterPointer m_SmoothingFilters[ImageDimension-1];
00156 FirstGaussianFilterPointer m_FirstSmoothingFilter;
00157 CastingFilterPointer m_CastingFilter;
00158
00160 bool m_NormalizeAcrossScale;
00161
00163 ScalarRealType m_Sigma;
00164 };
00165
00166 }
00167
00168 #ifndef ITK_MANUAL_INSTANTIATION
00169 #include "itkSmoothingRecursiveGaussianImageFilter.txx"
00170 #endif
00171
00172 #endif
00173