ITK  4.2.0
Insight Segmentation and Registration Toolkit
Public Types | Public Member Functions | Static Public Member Functions | Static Public Attributes | Protected Member Functions | Private Member Functions | Private Attributes
itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage > Class Template Reference

#include <itkFFTWRealToHalfHermitianForwardFFTImageFilter.h>

+ Inheritance diagram for itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >:
+ Collaboration diagram for itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >:

List of all members.

Public Types

typedef SmartPointer< const SelfConstPointer
typedef fftw::Proxy
< InputPixelType
FFTWProxyType
typedef TInputImage InputImageType
typedef InputImageType::PixelType InputPixelType
typedef InputImageType::SizeType InputSizeType
typedef TOutputImage OutputImageType
typedef OutputImageType::PixelType OutputPixelType
typedef OutputImageType::SizeType OutputSizeType
typedef SmartPointer< SelfPointer
typedef
FFTWRealToHalfHermitianForwardFFTImageFilter 
Self
typedef
RealToHalfHermitianForwardFFTImageFilter
< TInputImage, TOutputImage > 
Superclass
- Public Types inherited from itk::RealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >
typedef InputImageType::IndexType InputIndexType
typedef OutputImageType::IndexType OutputIndexType
- Public Types inherited from itk::ImageToImageFilter< TInputImage, TOutputImage >
typedef
InputImageType::ConstPointer 
InputImageConstPointer
typedef InputImageType::PixelType InputImagePixelType
typedef InputImageType::Pointer InputImagePointer
typedef InputImageType::RegionType InputImageRegionType
typedef
Superclass::OutputImagePixelType 
OutputImagePixelType
typedef
Superclass::OutputImageRegionType 
OutputImageRegionType
- Public Types inherited from itk::ImageSource< TOutputImage >
typedef
Superclass::DataObjectIdentifierType 
DataObjectIdentifierType
typedef DataObject::Pointer DataObjectPointer
typedef
Superclass::DataObjectPointerArraySizeType 
DataObjectPointerArraySizeType
typedef OutputImageType::Pointer OutputImagePointer
- Public Types inherited from itk::ProcessObject
typedef std::vector
< DataObjectPointer
DataObjectPointerArray
typedef std::vector
< DataObjectIdentifierType
NameArray
- Public Types inherited from itk::Object
- Public Types inherited from itk::LightObject

Public Member Functions

virtual ::itk::LightObject::Pointer CreateAnother (void) const
virtual const char * GetNameOfClass () const
virtual void SetPlanRigor (const int &value)
virtual const int & GetPlanRigor ()

Static Public Member Functions

static Pointer New ()

Static Public Attributes

static const unsigned int ImageDimension = InputImageType::ImageDimension

Protected Member Functions

 FFTWRealToHalfHermitianForwardFFTImageFilter ()
virtual void GenerateData ()
void PrintSelf (std::ostream &os, Indent indent) const
virtual void UpdateOutputData (DataObject *output)
 ~FFTWRealToHalfHermitianForwardFFTImageFilter ()
- Protected Member Functions inherited from itk::RealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >
virtual void EnlargeOutputRequestedRegion (DataObject *output)
virtual void GenerateInputRequestedRegion ()
virtual void GenerateOutputInformation ()
 RealToHalfHermitianForwardFFTImageFilter ()
virtual ~RealToHalfHermitianForwardFFTImageFilter ()
- Protected Member Functions inherited from itk::ImageToImageFilter< TInputImage, TOutputImage >
virtual void CallCopyInputRegionToOutputRegion (OutputImageRegionType &destRegion, const InputImageRegionType &srcRegion)
virtual void CallCopyOutputRegionToInputRegion (InputImageRegionType &destRegion, const OutputImageRegionType &srcRegion)
 ImageToImageFilter ()
virtual void VerifyInputInformation ()
 ~ImageToImageFilter ()
void PushBackInput (const DataObject *input)
void PushFrontInput (const DataObject *input)
- Protected Member Functions inherited from itk::ImageSource< TOutputImage >
virtual void AfterThreadedGenerateData ()
virtual void AllocateOutputs ()
virtual void BeforeThreadedGenerateData ()
 ImageSource ()
virtual unsigned int SplitRequestedRegion (unsigned int i, unsigned int num, OutputImageRegionType &splitRegion)
virtual void ThreadedGenerateData (const OutputImageRegionType &outputRegionForThread, ThreadIdType threadId)
virtual ~ImageSource ()
- Protected Member Functions inherited from itk::ProcessObject
virtual void AddInput (DataObject *input)
virtual void AddOutput (DataObject *output)
bool AddRequiredInputName (const DataObjectIdentifierType &)
virtual void CacheInputReleaseDataFlags ()
virtual void GenerateOutputRequestedRegion (DataObject *output)
virtual const
DataObjectPointerArraySizeType
GetNumberOfRequiredInputs ()
virtual const
DataObjectPointerArraySizeType
GetNumberOfRequiredOutputs ()
bool IsIndexedName (const DataObjectIdentifierType &) const
bool IsRequiredInputName (const DataObjectIdentifierType &) const
 itkLegacyMacro (virtual void RemoveInput(DataObject *input))
 itkLegacyMacro (virtual void RemoveOutput(DataObject *output))
 itkLegacyMacro (void SetNumberOfInputs(DataObjectPointerArraySizeType num))
 itkLegacyMacro (void SetNumberOfOutputs(DataObjectPointerArraySizeType num))
DataObjectPointerArraySizeType MakeIndexFromName (const DataObjectIdentifierType &) const
DataObjectIdentifierType MakeNameFromIndex (DataObjectPointerArraySizeType) const
 ProcessObject ()
virtual void PropagateResetPipeline ()
virtual void ReleaseInputs ()
virtual void RemoveInput (const DataObjectIdentifierType &key)
virtual void RemoveInput (DataObjectPointerArraySizeType)
virtual void RemoveOutput (const DataObjectIdentifierType &key)
virtual void RemoveOutput (DataObjectPointerArraySizeType idx)
bool RemoveRequiredInputName (const DataObjectIdentifierType &)
virtual void RestoreInputReleaseDataFlags ()
virtual void SetInput (const DataObjectIdentifierType &key, DataObject *input)
virtual void SetNthInput (DataObjectPointerArraySizeType num, DataObject *input)
virtual void SetNthOutput (DataObjectPointerArraySizeType num, DataObject *output)
void SetNumberOfIndexedInputs (DataObjectPointerArraySizeType num)
void SetNumberOfIndexedOutputs (DataObjectPointerArraySizeType num)
virtual void SetNumberOfRequiredInputs (DataObjectPointerArraySizeType)
virtual void SetNumberOfRequiredOutputs (DataObjectPointerArraySizeType _arg)
virtual void SetOutput (const DataObjectIdentifierType &key, DataObject *output)
virtual void SetPrimaryInput (DataObject *input)
virtual void SetPrimaryOutput (DataObject *output)
void SetRequiredInputNames (const NameArray &)
virtual void VerifyPreconditions ()
 ~ProcessObject ()
DataObjectGetInput (const DataObjectIdentifierType &key)
const DataObjectGetInput (const DataObjectIdentifierType &key) const
DataObjectGetInput (DataObjectPointerArraySizeType)
const DataObjectGetInput (DataObjectPointerArraySizeType idx) const
DataObjectGetPrimaryInput ()
const DataObjectGetPrimaryInput () const
DataObjectGetOutput (const DataObjectIdentifierType &key)
const DataObjectGetOutput (const DataObjectIdentifierType &key) const
DataObjectGetOutput (DataObjectPointerArraySizeType idx)
const DataObjectGetOutput (DataObjectPointerArraySizeType idx) const
DataObjectGetPrimaryOutput ()
const DataObjectGetPrimaryOutput () const
- Protected Member Functions inherited from itk::Object
 Object ()
bool PrintObservers (std::ostream &os, Indent indent) const
virtual void SetTimeStamp (const TimeStamp &time)
virtual ~Object ()
- Protected Member Functions inherited from itk::LightObject
virtual LightObject::Pointer InternalClone () const
 LightObject ()
virtual void PrintHeader (std::ostream &os, Indent indent) const
virtual void PrintTrailer (std::ostream &os, Indent indent) const
virtual ~LightObject ()

Private Member Functions

 FFTWRealToHalfHermitianForwardFFTImageFilter (const Self &)
void operator= (const Self &)

Private Attributes

bool m_CanUseDestructiveAlgorithm
int m_PlanRigor

Detailed Description

template<class TInputImage, class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
class itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >

FFTW-based forward Fast Fourier Transform.

This filter computes the forward Fourier transform of an image. The implementation is based on the FFTW library.

This filter is multithreaded and supports input images of any size.

In order to use this class, USE_FFTWF must be set to ON in the CMake configuration to support float images, and USE_FFTWD must set to ON to support double images.

This implementation was taken from the Insight Journal paper: http://hdl.handle.net/10380/3154 or http://insight-journal.com/browse/publication/717

Author:
Gaetan Lehmann. Biologie du Developpement et de la Reproduction, INRA de Jouy-en-Josas, France.
See also:
FFTWGlobalConfiguration
RealToHalfHermitianForwardFFTImageFilter

Definition at line 54 of file itkFFTWRealToHalfHermitianForwardFFTImageFilter.h.


Member Typedef Documentation

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef SmartPointer< const Self > itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::ConstPointer
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef fftw::Proxy< InputPixelType > itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::FFTWProxyType

The proxy type is a wrapper for the FFTW API. Because the proxy is defined only for double and float, trying to use any other pixel type is unsupported, as is trying to use double if only the float FFTW version is configured in, or float if only double is configured.

Definition at line 76 of file itkFFTWRealToHalfHermitianForwardFFTImageFilter.h.

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef TInputImage itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::InputImageType
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef InputImageType::PixelType itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::InputPixelType
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef InputImageType::SizeType itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::InputSizeType
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef TOutputImage itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::OutputImageType
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef OutputImageType::PixelType itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::OutputPixelType
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef OutputImageType::SizeType itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::OutputSizeType
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef SmartPointer< Self > itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::Pointer
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef FFTWRealToHalfHermitianForwardFFTImageFilter itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::Self
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
typedef RealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage > itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::Superclass

Constructor & Destructor Documentation

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::FFTWRealToHalfHermitianForwardFFTImageFilter ( )
protected
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::~FFTWRealToHalfHermitianForwardFFTImageFilter ( )
inlineprotected
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::FFTWRealToHalfHermitianForwardFFTImageFilter ( const Self )
private

Member Function Documentation

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
virtual::itk::LightObject::Pointer itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::CreateAnother ( void  ) const
virtual

Create an object from an instance, potentially deferring to a factory. This method allows you to create an instance of an object that is exactly the same type as the referring object. This is useful in cases where an object has been cast back to a base class.

Reimplemented from itk::Object.

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
virtual void itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::GenerateData ( )
protectedvirtual

A version of GenerateData() specific for image processing filters. This implementation will split the processing across multiple threads. The buffer is allocated by this method. Then the BeforeThreadedGenerateData() method is called (if provided). Then, a series of threads are spawned each calling ThreadedGenerateData(). After all the threads have completed processing, the AfterThreadedGenerateData() method is called (if provided). If an image processing filter cannot be threaded, the filter should provide an implementation of GenerateData(). That implementation is responsible for allocating the output buffer. If a filter an be threaded, it should NOT provide a GenerateData() method but should provide a ThreadedGenerateData() instead.

See also:
ThreadedGenerateData()

Reimplemented from itk::ImageSource< TOutputImage >.

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
virtual const char* itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::GetNameOfClass ( ) const
virtual

Run-time type information (and related methods).

Reimplemented from itk::ImageToImageFilter< TInputImage, TOutputImage >.

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
virtual const int& itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::GetPlanRigor ( )
virtual

Set/Get the behavior of wisdom plan creation. The default is provided by FFTWGlobalConfiguration::GetPlanRigor().

The parameter is one of the FFTW planner rigor flags FFTW_ESTIMATE, FFTW_MEASURE, FFTW_PATIENT, FFTW_EXHAUSTIVE provided by FFTWGlobalConfiguration.

/sa FFTWGlobalConfiguration

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
static Pointer itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::New ( )
static

Method for creation through the object factory.

Reimplemented from itk::RealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >.

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
void itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::operator= ( const Self )
private

PushBackInput(), PushFronInput() in the public section force the input to be the type expected by an ImageToImageFilter. However, these methods end of "hiding" the versions from the superclass (ProcessObject) whose arguments are DataObjects. Here, we re-expose the versions from ProcessObject to avoid warnings about hiding methods from the superclass.

Reimplemented from itk::RealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >.

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
void itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::PrintSelf ( std::ostream &  os,
Indent  indent 
) const
protectedvirtual

Methods invoked by Print() to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes.

Reimplemented from itk::ImageToImageFilter< TInputImage, TOutputImage >.

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
virtual void itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::SetPlanRigor ( const int &  value)
inlinevirtual

Set/Get the behavior of wisdom plan creation. The default is provided by FFTWGlobalConfiguration::GetPlanRigor().

The parameter is one of the FFTW planner rigor flags FFTW_ESTIMATE, FFTW_MEASURE, FFTW_PATIENT, FFTW_EXHAUSTIVE provided by FFTWGlobalConfiguration.

/sa FFTWGlobalConfiguration

Definition at line 96 of file itkFFTWRealToHalfHermitianForwardFFTImageFilter.h.

References itk::FFTWGlobalConfiguration::GetPlanRigorName().

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
virtual void itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::UpdateOutputData ( DataObject output)
protectedvirtual

Actually generate new output

Reimplemented from itk::ProcessObject.


Member Data Documentation

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
const unsigned int itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::ImageDimension = InputImageType::ImageDimension
static

Define the image dimension.

Definition at line 86 of file itkFFTWRealToHalfHermitianForwardFFTImageFilter.h.

template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
bool itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::m_CanUseDestructiveAlgorithm
private
template<class TInputImage , class TOutputImage = Image< std::complex<typename TInputImage::PixelType>, TInputImage::ImageDimension>>
int itk::FFTWRealToHalfHermitianForwardFFTImageFilter< TInputImage, TOutputImage >::m_PlanRigor
private

The documentation for this class was generated from the following file: