1 #ifndef __clitkInvertVFFilter_h
2 #define __clitkInvertVFFilter_h
5 #include "clitkImageCommon.h"
7 #include "itkImageToImageFilter.h"
9 #include "itkImageRegionIterator.h"
10 #include "itkImageRegionIteratorWithIndex.h"
11 #include "itkNumericTraits.h"
16 template <class InputImageType, class OutputImageType>
17 class ITK_EXPORT InvertVFFilter : public itk::ImageToImageFilter<InputImageType, OutputImageType>
21 typedef InvertVFFilter Self;
22 typedef itk::ImageToImageFilter<InputImageType, OutputImageType> Superclass;
23 typedef itk::SmartPointer<Self> Pointer;
24 typedef itk::SmartPointer<const Self> ConstPointer;
26 /** Method for creation through the object factory. */
29 /** Run-time type information (and related methods) */
30 itkTypeMacro( InvertVFFilter, ImageToImageFilter );
32 /** Determine the image dimension. */
33 itkStaticConstMacro(ImageDimension, unsigned int,
34 InputImageType::ImageDimension );
37 typedef double CoordRepType;
38 typedef itk::Image<double, ImageDimension> WeightsImageType;
39 typedef itk::Image<itk::SimpleFastMutexLock, ImageDimension> MutexImageType;
42 typedef itk::Point<CoordRepType,itkGetStaticConstMacro(ImageDimension)> PointType;
44 /** Inherit some types from the superclass. */
45 typedef typename OutputImageType::IndexType IndexType;
46 typedef typename OutputImageType::SizeType SizeType;
47 typedef typename OutputImageType::PixelType PixelType;
48 typedef typename OutputImageType::SpacingType SpacingType;
51 itkSetMacro( Verbose, bool);
52 itkSetMacro( EdgePaddingValue, PixelType );
53 void SetNumberOfThreads(unsigned int r )
55 m_NumberOfThreadsIsGiven=true;
58 itkSetMacro(ThreadSafe, bool);
67 bool m_NumberOfThreadsIsGiven;
68 unsigned int m_NumberOfThreads;
69 PixelType m_EdgePaddingValue;
74 } // end namespace clitk
75 #ifndef ITK_MANUAL_INSTANTIATION
76 #include "clitkInvertVFFilter.txx"
79 #endif // #define __clitkInvertVFFilter_h