18#ifndef itkIsoContourDistanceImageFilter_h
19#define itkIsoContourDistanceImageFilter_h
60template <
typename TInputImage,
typename TOutputImage>
89 using PixelType =
typename OutputImageType::PixelType;
96 using SizeType =
typename OutputImageType::SizeType;
99 using IndexType =
typename OutputImageType::IndexType;
126 itkSetMacro(NarrowBanding,
bool);
127 itkGetConstMacro(NarrowBanding,
bool);
128 itkBooleanMacro(NarrowBanding);
161 itkExceptionMacro(
"This class requires threadId so it must use classic multi-threading model");
193 const std::vector<OffsetValueType> & stride);
209#ifndef ITK_MANUAL_INSTANTIATION
210# include "itkIsoContourDistanceImageFilter.hxx"
Const version of NeighborhoodIterator, defining iteration of a local N-dimensional neighborhood of pi...
Base class for all data objects in ITK.
OutputImageType OutputImageType
InputImageType InputImageType
Control indentation during Print() invocation.
IsoContourDistanceImageFilter()
void ThreadedGenerateData(const OutputImageRegionType &outputRegionForThread, ThreadIdType threadId) override
typename OutputImageType::RegionType OutputImageRegionType
std::vector< RegionType > m_NarrowBandRegion
typename NarrowBandType::Iterator BandIterator
void BeforeThreadedGenerateData() override
~IsoContourDistanceImageFilter() override=default
NarrowBandPointer m_NarrowBand
typename InputImageType::SizeType InputSizeType
SmartPointer< const Self > ConstPointer
typename NarrowBandType::RegionType RegionType
typename OutputImageType::SizeType SizeType
PixelRealType m_LevelSetValue
NarrowBand< BandNodeType > NarrowBandType
static ITK_THREAD_RETURN_FUNCTION_CALL_CONVENTION ThreaderFullCallback(void *arg)
typename OutputImageType::IndexType IndexType
typename InputImageType::SpacingType InputSpacingType
typename NarrowBandType::ConstIterator ConstBandIterator
static constexpr unsigned int ImageDimension
void ThreadedGenerateDataBand(const OutputImageRegionType &outputRegionForThread, ThreadIdType threadId)
void DynamicThreadedGenerateData(const OutputImageRegionType &) override
IsoContourDistanceImageFilter Self
void ThreadedGenerateDataFull(const OutputImageRegionType &outputRegionForThread, ThreadIdType threadId)
ImageToImageFilter< InputImageType, OutputImageType > Superclass
void PrintSelf(std::ostream &os, Indent indent) const override
NeighborhoodIterator< OutputImageType > OutputNeighborhoodIteratorType
InputSpacingType m_Spacing
typename NumericTraits< InputPixelType >::RealType PixelRealType
typename NarrowBandType::Pointer NarrowBandPointer
ConstNeighborhoodIterator< InputImageType > InputNeighbordIteratorType
NarrowBandPointer GetNarrowBand() const
BandNode< IndexType, PixelType > BandNodeType
static constexpr unsigned int OutputImageDimension
void SetNarrowBand(NarrowBandType *ptr)
typename InputImageType::PixelType InputPixelType
void GenerateData() override
SmartPointer< Self > Pointer
typename InputImageType::IndexType InputIndexType
typename OutputImageType::PixelType PixelType
void EnlargeOutputRequestedRegion(DataObject *) override
void GenerateInputRequestedRegion() override
void ComputeValue(const InputNeighbordIteratorType &inNeigIt, OutputNeighborhoodIteratorType &outNeigIt, unsigned int center, const std::vector< OffsetValueType > &stride)
typename NodeContainerType::const_iterator ConstIterator
SmartPointer< Self > Pointer
typename NodeContainerType::iterator Iterator
Defines iteration of a local N-dimensional neighborhood of pixels across an itk::Image.
Implements transparent reference counting.
#define itkConceptMacro(name, concept)
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
unsigned int ThreadIdType
itk::ITK_THREAD_RETURN_TYPE ITK_THREAD_RETURN_FUNCTION_CALL_CONVENTION