18#ifndef itkImageToListSampleAdaptor_h
19#define itkImageToListSampleAdaptor_h
53template <
typename TImage>
55 :
public ListSample<typename MeasurementVectorPixelTraits<typename TImage::PixelType>::MeasurementVectorType>
97 using typename Superclass::AbsoluteFrequencyType;
98 using typename Superclass::TotalAbsoluteFrequencyType;
99 using typename Superclass::MeasurementVectorSizeType;
100 using typename Superclass::InstanceIdentifier;
106 SetImage(
const TImage * image);
114 Size()
const override;
121 GetMeasurementVectorSize()
const override
126 if (m_Image.IsNull())
128 return Superclass::GetMeasurementVectorSize();
131 return m_Image->GetNumberOfComponentsPerPixel();
140 GetTotalFrequency()
const override;
156 : m_Iter(iter.m_Iter)
157 , m_InstanceIdentifier(iter.m_InstanceIdentifier)
175 GetMeasurementVector()
const
178 return this->m_MeasurementVectorCache;
182 GetInstanceIdentifier()
const
184 return m_InstanceIdentifier;
191 ++m_InstanceIdentifier;
198 return (m_Iter == it.
m_Iter);
206 : m_Iter(
std::move(iter))
207 , m_InstanceIdentifier(iid)
243 this->ConstIterator::operator=(iter);
258 ImageIteratorType imageIterator(nonConstImage, nonConstImage->GetLargestPossibleRegion());
260 const Iterator iter(imageIterator, 0);
273 const Iterator iter(imageIterator, largestRegion.GetNumberOfPixels());
298 const ConstIterator iter(imageConstIterator, largestRegion.GetNumberOfPixels());
308 PrintSelf(std::ostream & os,
Indent indent)
const override;
312 mutable MeasurementVectorType m_MeasurementVectorInternal{};
318#ifndef ITK_MANUAL_INSTANTIATION
319# include "itkImageToListSampleAdaptor.hxx"
Base class for all data objects in ITK.
A multi-dimensional iterator templated over image type that walks a region of pixels.
Control indentation during Print() invocation.
Base class for most ITK classes.
Traits for a pixel that define the dimension and component type.
ImageConstIteratorType m_Iter
InstanceIdentifier m_InstanceIdentifier
Iterator(const ImageConstIteratorType &iter, InstanceIdentifier iid)=delete
Iterator(const ConstIterator &it)=delete
Iterator(const Self *adaptor)=delete
This class provides ListSample interface to ITK Image.
typename MeasurementVectorTraitsType::ValueType MeasurementType
typename ImageType::Pointer ImagePointer
typename MeasurementPixelTraitsType::MeasurementVectorType MeasurementVectorType
typename ImageType::IndexType IndexType
MeasurementVectorType ValueType
typename ImageType::ConstPointer ImageConstPointer
typename ImageType::PixelType PixelType
typename ImageType::PixelContainerConstPointer PixelContainerConstPointer
This class is the native implementation of the a Sample with an STL container.
TPixelType MeasurementVectorType
typename TMeasurementVector::ValueType ValueType
static void Assign(TArrayType &m, const TArrayType &v)
unsigned int MeasurementVectorSizeType
typename MeasurementVectorTraits::InstanceIdentifier InstanceIdentifier
NumericTraits< AbsoluteFrequencyType >::AccumulateType TotalAbsoluteFrequencyType
MeasurementVectorTraits::AbsoluteFrequencyType AbsoluteFrequencyType
SmartPointer< const Self > ConstPointer
SmartPointer< Self > Pointer
ImageBaseType::RegionType RegionType
ImageBaseType::IndexType IndexType
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
bool operator==(const Index< VDimension > &one, const Index< VDimension > &two)
Represent a n-dimensional size (bounds) of a n-dimensional image.