ITK
5.0.0
Insight Segmentation and Registration Toolkit
|
#include <itkProjectionImageFilter.h>
Implements an accumulation of an image along a selected direction.
This class accumulates an image along a dimension and reduces the size of this dimension to 1. The dimension being accumulated is set by ProjectionDimension.
Each pixel is the cumulative sum of the pixels along the collapsed dimension and reduces the size of the accumulated dimension to 1 (only on the accumulated).
The dimensions of the InputImage and the OutputImage are either the same or dimension of OutputImage is dimension of InputImage minus one. In the latter case, the direction cosine of the output image is set to the identity.
This class is parameterized over the type of the input image and the type of the output image.
This class was contributed to the Insight Journal by Emilian Beronich and Gaetan Lehmann. The original paper can be found at https://hdl.handle.net/1926/164
Definition at line 57 of file itkProjectionImageFilter.h.
Public Types | |
using | AccumulatorType = TAccumulator |
using | ConstPointer = SmartPointer< const Self > |
using | InputImagePixelType = typename InputImageType::PixelType |
using | InputImagePointer = typename InputImageType::Pointer |
using | InputImageRegionType = typename InputImageType::RegionType |
using | InputImageType = TInputImage |
using | OutputImagePixelType = typename OutputImageType::PixelType |
using | OutputImagePointer = typename OutputImageType::Pointer |
using | OutputImageRegionType = typename OutputImageType::RegionType |
using | OutputImageType = TOutputImage |
using | Pointer = SmartPointer< Self > |
using | Self = ProjectionImageFilter |
using | Superclass = ImageToImageFilter< TInputImage, TOutputImage > |
Public Types inherited from itk::ImageToImageFilter< TInputImage, TOutputImage > | |
using | ConstPointer = SmartPointer< const Self > |
using | InputImageConstPointer = typename InputImageType::ConstPointer |
using | InputImagePixelType = typename InputImageType::PixelType |
using | InputImagePointer = typename InputImageType::Pointer |
using | InputImageRegionType = typename InputImageType::RegionType |
using | InputImageType = TInputImage |
using | OutputImagePixelType = typename Superclass::OutputImagePixelType |
using | OutputImageRegionType = typename Superclass::OutputImageRegionType |
using | Pointer = SmartPointer< Self > |
using | Self = ImageToImageFilter |
using | Superclass = ImageSource< TOutputImage > |
Public Types inherited from itk::ImageSource< TOutputImage > | |
using | ConstPointer = SmartPointer< const Self > |
using | DataObjectIdentifierType = Superclass::DataObjectIdentifierType |
using | DataObjectPointer = DataObject::Pointer |
using | DataObjectPointerArraySizeType = Superclass::DataObjectPointerArraySizeType |
using | OutputImagePixelType = typename OutputImageType::PixelType |
using | OutputImagePointer = typename OutputImageType::Pointer |
using | OutputImageRegionType = typename OutputImageType::RegionType |
using | OutputImageType = TOutputImage |
using | Pointer = SmartPointer< Self > |
using | Self = ImageSource |
using | Superclass = ProcessObject |
Public Types inherited from itk::ProcessObject | |
using | ConstPointer = SmartPointer< const Self > |
using | DataObjectIdentifierType = DataObject::DataObjectIdentifierType |
using | DataObjectPointer = DataObject::Pointer |
using | DataObjectPointerArray = std::vector< DataObjectPointer > |
using | DataObjectPointerArraySizeType = DataObjectPointerArray::size_type |
using | MultiThreaderType = MultiThreaderBase |
using | NameArray = std::vector< DataObjectIdentifierType > |
using | Pointer = SmartPointer< Self > |
using | Self = ProcessObject |
using | Superclass = Object |
Public Types inherited from itk::Object | |
using | ConstPointer = SmartPointer< const Self > |
using | Pointer = SmartPointer< Self > |
using | Self = Object |
using | Superclass = LightObject |
Public Types inherited from itk::LightObject | |
using | ConstPointer = SmartPointer< const Self > |
using | Pointer = SmartPointer< Self > |
using | Self = LightObject |
Static Public Member Functions | |
static Pointer | New () |
Static Public Member Functions inherited from itk::Object | |
static bool | GetGlobalWarningDisplay () |
static void | GlobalWarningDisplayOff () |
static void | GlobalWarningDisplayOn () |
static Pointer | New () |
static void | SetGlobalWarningDisplay (bool flag) |
Static Public Member Functions inherited from itk::LightObject | |
static void | BreakOnError () |
static Pointer | New () |
Static Public Attributes | |
static constexpr unsigned int | InputImageDimension = TInputImage::ImageDimension |
static constexpr unsigned int | OutputImageDimension = TOutputImage::ImageDimension |
Static Public Attributes inherited from itk::ImageToImageFilter< TInputImage, TOutputImage > | |
static constexpr unsigned int | InputImageDimension = TInputImage::ImageDimension |
static constexpr unsigned int | OutputImageDimension = TOutputImage::ImageDimension |
Static Public Attributes inherited from itk::ImageSource< TOutputImage > | |
static constexpr unsigned int | OutputImageDimension = TOutputImage::ImageDimension |
Private Attributes | |
unsigned int | m_ProjectionDimension |
Additional Inherited Members | |
Protected Types inherited from itk::ImageToImageFilter< TInputImage, TOutputImage > | |
using | InputToOutputRegionCopierType = ImageToImageFilterDetail::ImageRegionCopier< Self::OutputImageDimension, Self::InputImageDimension > |
using | OutputToInputRegionCopierType = ImageToImageFilterDetail::ImageRegionCopier< Self::InputImageDimension, Self::OutputImageDimension > |
Static Protected Member Functions inherited from itk::ImageSource< TOutputImage > | |
static const ImageRegionSplitterBase * | GetGlobalDefaultSplitter () |
static ITK_THREAD_RETURN_FUNCTION_CALL_CONVENTION | ThreaderCallback (void *arg) |
Protected Attributes inherited from itk::ImageSource< TOutputImage > | |
bool | m_DynamicMultiThreading |
Protected Attributes inherited from itk::ProcessObject | |
TimeStamp | m_OutputInformationMTime |
bool | m_Updating |
Protected Attributes inherited from itk::LightObject | |
std::atomic< int > | m_ReferenceCount |
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::AccumulatorType = TAccumulator |
Definition at line 85 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::ConstPointer = SmartPointer< const Self > |
Definition at line 67 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::InputImagePixelType = typename InputImageType::PixelType |
Definition at line 79 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::InputImagePointer = typename InputImageType::Pointer |
Definition at line 77 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::InputImageRegionType = typename InputImageType::RegionType |
Definition at line 78 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::InputImageType = TInputImage |
Some convenient type alias.
Definition at line 76 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::OutputImagePixelType = typename OutputImageType::PixelType |
Definition at line 83 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::OutputImagePointer = typename OutputImageType::Pointer |
Definition at line 81 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::OutputImageRegionType = typename OutputImageType::RegionType |
Definition at line 82 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::OutputImageType = TOutputImage |
Definition at line 80 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::Pointer = SmartPointer< Self > |
Definition at line 66 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::Self = ProjectionImageFilter |
Standard class type aliases.
Definition at line 64 of file itkProjectionImageFilter.h.
using itk::ProjectionImageFilter< TInputImage, TOutputImage, TAccumulator >::Superclass = ImageToImageFilter< TInputImage, TOutputImage > |
Definition at line 65 of file itkProjectionImageFilter.h.
|
protected |
|
overrideprotecteddefault |
|
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.
|
overrideprotectedvirtual |
If an imaging filter can be implemented as a multithreaded algorithm, the filter will provide an implementation of ThreadedGenerateData() or DynamicThreadedGenerateData(). This superclass will automatically split the output image into a number of pieces, spawn multiple threads, and call (Dynamic)ThreadedGenerateData() in each thread. Prior to spawning threads, the BeforeThreadedGenerateData() method is called. After all the threads have completed, the AfterThreadedGenerateData() method is called. If an image processing filter cannot support threading, that filter should provide an implementation of the GenerateData() method instead of providing an implementation of (Dynamic)ThreadedGenerateData(). If a filter provides a GenerateData() method as its implementation, then the filter is responsible for allocating the output data. If a filter provides a (Dynamic)ThreadedGenerateData() method as its implementation, then the output memory will allocated automatically by this superclass. The (Dynamic)ThreadedGenerateData() method should only produce the output specified by "outputThreadRegion" parameter. (Dynamic)ThreadedGenerateData() cannot write to any other portion of the output image (as this is responsibility of a different thread).
DynamicThreadedGenerateData() is the newer variant without threadId, and is the preferred signature, which is called by default. This variant can split the requested region into different number of pieces depending on current multi-processing load, which allows better load balancing. The non-dynamic (also known as classic) ThreadedGenerateData() signature has threadId, and number of pieces to be split into is known in advance. It is activated by calling this->DynamicMultiThreadingOff(); in derived class constructor. It should be used when the multi-threaded algorithm needs to pre-allocate some data structure with size dependent on the number of pieces (also known as chunks, work units, and sometimes also incorrectly as threads). Only PlatformMultiThreader guarantees that each piece will be processed in its own specific thread. Pool and TBB multi-threaders maintain a pool of threads (normally equal to number of processing cores) which they use to process the pieces. This normally results in a single thread being reused to process multiple work units.
Reimplemented from itk::ImageSource< TOutputImage >.
|
overrideprotectedvirtual |
Apply changes to the input image requested region.
Reimplemented from itk::ImageToImageFilter< TInputImage, TOutputImage >.
|
overrideprotectedvirtual |
Apply changes to the output image information.
Reimplemented from itk::ProcessObject.
|
virtual |
Run-time type information (and related methods).
Reimplemented from itk::ImageToImageFilter< TInputImage, TOutputImage >.
Reimplemented in itk::StandardDeviationProjectionImageFilter< TInputImage, TOutputImage, TAccumulate >, itk::BinaryThresholdProjectionImageFilter< TInputImage, TOutputImage >, itk::MeanProjectionImageFilter< TInputImage, TOutputImage, TAccumulate >, itk::BinaryProjectionImageFilter< TInputImage, TOutputImage >, itk::SumProjectionImageFilter< TInputImage, TOutputImage >, itk::MedianProjectionImageFilter< TInputImage, TOutputImage >, itk::MaximumProjectionImageFilter< TInputImage, TOutputImage >, and itk::MinimumProjectionImageFilter< TInputImage, TOutputImage >.
|
virtual |
Input and output images must be the same dimension, or the output's dimension must be one less than that of the input. Set/Get the direction in which to accumulate the data. It must be set before the update of the filter. Defaults to the last dimension.
|
static |
Method for creation through the object factory.
|
protectedvirtual |
|
overrideprotectedvirtual |
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 >.
Referenced by itk::BinaryProjectionImageFilter< TInputImage, TOutputImage >::PrintSelf(), and itk::BinaryThresholdProjectionImageFilter< TInputImage, TOutputImage >::PrintSelf().
|
virtual |
Input and output images must be the same dimension, or the output's dimension must be one less than that of the input. Set/Get the direction in which to accumulate the data. It must be set before the update of the filter. Defaults to the last dimension.
|
static |
ImageDimension enumeration
Definition at line 88 of file itkProjectionImageFilter.h.
|
private |
Definition at line 125 of file itkProjectionImageFilter.h.
|
static |
Definition at line 89 of file itkProjectionImageFilter.h.