ITK 6.0.0
Insight Toolkit
 
Loading...
Searching...
No Matches
itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage > Class Template Reference

#include <itkStructuralSimilarityImageFilter.h>

Detailed Description

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
class itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >

Computes the Structural Similarity Index Measure (SSIM) between two images.

This filter computes the Structural Similarity Index Measure [wang2004image] between two input images of identical geometry. The output image stores the per-pixel SSIM map. The scalar mean SSIM over the valid (non-boundary) region is available via GetMeanSSIM() after Update().

Algorithm
For two images \(x\) and \(y\), local statistics are computed by convolving with a discrete Gaussian kernel of standard deviation \(\sigma\) (default 1.5):

\[ \mu_x = G_\sigma * x, \quad \mu_y = G_\sigma * y, \]

\[ \sigma_x^2 = G_\sigma * x^2 - \mu_x^2,\quad \sigma_y^2 = G_\sigma * y^2 - \mu_y^2,\quad \sigma_{xy} = G_\sigma * (xy) - \mu_x \mu_y . \]

The three SSIM components are

\[ l(x,y) = \frac{2\mu_x\mu_y + C_1}{\mu_x^2 + \mu_y^2 + C_1}, \qquad c(x,y) = \frac{2\sigma_x\sigma_y + C_2}{\sigma_x^2 + \sigma_y^2 + C_2}, \qquad s(x,y) = \frac{\sigma_{xy} + C_3}{\sigma_x\sigma_y + C_3} \]

with \(C_1 = (K_1 L)^2\), \(C_2 = (K_2 L)^2\), \(C_3 = C_2/2\), and \(L\) the dynamic range of the pixel values.

The combined SSIM is

\[ \mathrm{SSIM}(x,y) = [l(x,y)]^{\alpha}\,[c(x,y)]^{\beta}\,[s(x,y)]^{\gamma}. \]

With the default exponents \(\alpha = \beta = \gamma = 1\) and the convention \(C_3 = C_2/2\), this collapses to the simplified form

\[ \mathrm{SSIM}(x,y) = \frac{(2\mu_x\mu_y + C_1)\,(2\sigma_{xy} + C_2)} {(\mu_x^2 + \mu_y^2 + C_1)\,(\sigma_x^2 + \sigma_y^2 + C_2)} \]

which matches the reference implementation distributed by Wang et al. and the default behavior of skimage.metrics.structural_similarity .

Properties
  • For identical images, the per-pixel SSIM is exactly 1 and the mean SSIM is exactly 1 (subject to floating-point precision).
  • The SSIM index is symmetric: \(\mathrm{SSIM}(x,y) = \mathrm{SSIM}(y,x)\).
  • The SSIM index is bounded above by 1. In typical cases it is non-negative; values can be slightly negative for anti-correlated regions.
Parameters
  • GaussianSigma: standard deviation of the Gaussian window (default 1.5, matching Wang et al.).
  • MaximumKernelWidth: hard limit on the discrete Gaussian kernel width (default 11, matching the canonical 11x11 window).
  • K1, K2: stability constants (defaults 0.01 and 0.03).
  • DynamicRange: \(L\) in the formulas above; defaults to the dynamic range of the input pixel type via NumericTraits (e.g. 255 for unsigned char, 1.0 for float / double). For arbitrary floating-point images, set this explicitly to the actual data range.
  • LuminanceExponent ( \(\alpha\)), ContrastExponent ( \(\beta\)), StructureExponent ( \(\gamma\)): defaults all 1.0.
  • ScaleWeights: array of per-scale weights for multi-scale SSIM (MS-SSIM, [wang2003multiscale]). When the array contains a single element (the default), the filter computes ordinary single-scale SSIM. Multi-scale evaluation with more than one scale is not yet implemented and will raise an exception in BeforeGenerate.

The filter is N-dimensional, multi-threaded, and templated over the input and output image types. The output pixel type defaults to float.

See also
SimilarityIndexImageFilter
DiscreteGaussianImageFilter

Definition at line 112 of file itkStructuralSimilarityImageFilter.h.

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

Public Types

using ConstPointer = SmartPointer<const Self>
 
using IndexType = typename InputImageType::IndexType
 
using InputImageRegionType = typename InputImageType::RegionType
 
using InputImageType = TInputImage
 
using InputPixelType = typename InputImageType::PixelType
 
using OutputImageRegionType = typename OutputImageType::RegionType
 
using OutputImageType = TOutputImage
 
using OutputPixelType = typename OutputImageType::PixelType
 
using Pointer = SmartPointer<Self>
 
using RealType = typename NumericTraits<InputPixelType>::RealType
 
using ScaleWeightsType = Array<RealType>
 
using Self = StructuralSimilarityImageFilter
 
using SizeType = typename InputImageType::SizeType
 
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
 
using 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 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
 

Public Member Functions

virtual::itk::LightObject::Pointer CreateAnother () const
 
virtual double GetMeanSSIM () const
 
virtual const char * GetNameOfClass () const
 
void SetInput1 (const InputImageType *image)
 
const InputImageTypeGetInput1 () const
 
void SetInput2 (const InputImageType *image)
 
const InputImageTypeGetInput2 () const
 
virtual void SetGaussianSigma (double _arg)
 
virtual double GetGaussianSigma () const
 
virtual void SetMaximumKernelWidth (unsigned int _arg)
 
virtual unsigned int GetMaximumKernelWidth () const
 
virtual void SetK1 (double _arg)
 
virtual double GetK1 () const
 
virtual void SetK2 (double _arg)
 
virtual double GetK2 () const
 
virtual void SetDynamicRange (double _arg)
 
virtual double GetDynamicRange () const
 
virtual void SetLuminanceExponent (double _arg)
 
virtual double GetLuminanceExponent () const
 
virtual void SetContrastExponent (double _arg)
 
virtual double GetContrastExponent () const
 
virtual void SetStructureExponent (double _arg)
 
virtual double GetStructureExponent () const
 
void SetScaleWeights (const ScaleWeightsType &weights)
 
virtual const ScaleWeightsTypeGetScaleWeights () const
 
- Public Member Functions inherited from itk::ImageToImageFilter< TInputImage, TOutputImage >
const InputImageTypeGetInput () const
 
const InputImageTypeGetInput (unsigned int idx) const
 
void PopBackInput () override
 
void PopFrontInput () override
 
virtual void PushBackInput (const InputImageType *input)
 
virtual void PushFrontInput (const InputImageType *input)
 
virtual void SetInput (const InputImageType *input)
 
virtual void SetInput (unsigned int, const TInputImage *image)
 
virtual void SetCoordinateTolerance (double _arg)
 
virtual double GetCoordinateTolerance () const
 
virtual void SetDirectionTolerance (double _arg)
 
virtual double GetDirectionTolerance () const
 
- Public Member Functions inherited from itk::ImageSource< TOutputImage >
OutputImageTypeGetOutput (unsigned int idx)
 
virtual void GraftNthOutput (unsigned int idx, DataObject *graft)
 
virtual void GraftOutput (const DataObjectIdentifierType &key, DataObject *graft)
 
virtual void GraftOutput (DataObject *graft)
 
OutputImageTypeGetOutput ()
 
const OutputImageTypeGetOutput () const
 
ProcessObject::DataObjectPointer MakeOutput (ProcessObject::DataObjectPointerArraySizeType idx) override
 
ProcessObject::DataObjectPointer MakeOutput (const ProcessObject::DataObjectIdentifierType &) override
 
- Public Member Functions inherited from itk::ProcessObject
virtual void AbortGenerateDataOff ()
 
virtual void AbortGenerateDataOn ()
 
virtual const bool & GetAbortGenerateData () const
 
DataObjectPointerArray GetIndexedInputs ()
 
DataObjectPointerArray GetIndexedOutputs ()
 
NameArray GetInputNames () const
 
DataObjectPointerArray GetInputs ()
 
MultiThreaderBaseGetMultiThreader () const
 
DataObjectPointerArraySizeType GetNumberOfIndexedInputs () const
 
DataObjectPointerArraySizeType GetNumberOfIndexedOutputs () const
 
DataObjectPointerArraySizeType GetNumberOfInputs () const
 
DataObjectPointerArraySizeType GetNumberOfOutputs () const
 
virtual DataObjectPointerArraySizeType GetNumberOfValidRequiredInputs () const
 
NameArray GetOutputNames () const
 
DataObjectPointerArray GetOutputs ()
 
virtual float GetProgress () const
 
NameArray GetRequiredInputNames () const
 
bool HasInput (const DataObjectIdentifierType &key) const
 
bool HasOutput (const DataObjectIdentifierType &key) const
 
void IncrementProgress (float increment)
 
virtual void PrepareOutputs ()
 
virtual void PropagateRequestedRegion (DataObject *output)
 
virtual void ResetPipeline ()
 
virtual void SetAbortGenerateData (bool _arg)
 
void SetMultiThreader (MultiThreaderBase *threader)
 
virtual void Update ()
 
virtual void UpdateLargestPossibleRegion ()
 
virtual void UpdateOutputData (DataObject *output)
 
virtual void UpdateOutputInformation ()
 
void UpdateProgress (float progress)
 
virtual void SetReleaseDataFlag (bool val)
 
virtual bool GetReleaseDataFlag () const
 
void ReleaseDataFlagOn ()
 
void ReleaseDataFlagOff ()
 
virtual void SetReleaseDataBeforeUpdateFlag (bool _arg)
 
virtual const bool & GetReleaseDataBeforeUpdateFlag () const
 
virtual void ReleaseDataBeforeUpdateFlagOn ()
 
virtual void ReleaseDataBeforeUpdateFlagOff ()
 
virtual void SetNumberOfWorkUnits (ThreadIdType _arg)
 
virtual const ThreadIdTypeGetNumberOfWorkUnits () const
 
- Public Member Functions inherited from itk::Object
unsigned long AddObserver (const EventObject &event, Command *cmd) const
 
unsigned long AddObserver (const EventObject &event, std::function< void(const EventObject &)> function) const
 
virtual void DebugOff () const
 
virtual void DebugOn () const
 
CommandGetCommand (unsigned long tag)
 
bool GetDebug () const
 
MetaDataDictionaryGetMetaDataDictionary ()
 
const MetaDataDictionaryGetMetaDataDictionary () const
 
virtual ModifiedTimeType GetMTime () const
 
virtual const TimeStampGetTimeStamp () const
 
bool HasObserver (const EventObject &event) const
 
void InvokeEvent (const EventObject &)
 
void InvokeEvent (const EventObject &) const
 
virtual void Modified () const
 
void Register () const override
 
void RemoveAllObservers ()
 
void RemoveObserver (unsigned long tag) const
 
void SetDebug (bool debugFlag) const
 
void SetReferenceCount (int) override
 
void UnRegister () const noexcept override
 
void SetMetaDataDictionary (const MetaDataDictionary &rhs)
 
void SetMetaDataDictionary (MetaDataDictionary &&rrhs)
 
virtual void SetObjectName (std::string _arg)
 
virtual const std::string & GetObjectName () const
 
- Public Member Functions inherited from itk::LightObject
Pointer Clone () const
 
virtual void Delete ()
 
virtual int GetReferenceCount () const
 
void Print (std::ostream &os, Indent indent=0) const
 

Static Public Member Functions

static Pointer New ()
 
- Static Public Member Functions inherited from itk::ImageToImageFilter< TInputImage, TOutputImage >
static double GetGlobalDefaultCoordinateTolerance ()
 
static double GetGlobalDefaultDirectionTolerance ()
 
static void SetGlobalDefaultCoordinateTolerance (double)
 
static void SetGlobalDefaultDirectionTolerance (double)
 
- Static Public Member Functions inherited from itk::Object
static bool GetGlobalWarningDisplay ()
 
static void GlobalWarningDisplayOff ()
 
static void GlobalWarningDisplayOn ()
 
static Pointer New ()
 
static void SetGlobalWarningDisplay (bool val)
 
- Static Public Member Functions inherited from itk::LightObject
static void BreakOnError ()
 
static Pointer New ()
 

Static Public Attributes

static constexpr unsigned int ImageDimension = InputImageType::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
 

Protected Member Functions

void EnlargeOutputRequestedRegion (DataObject *data) override
 
void GenerateData () override
 
void PrintSelf (std::ostream &os, Indent indent) const override
 
 StructuralSimilarityImageFilter ()
 
void VerifyPreconditions () const override
 
 ~StructuralSimilarityImageFilter () override=default
 
- 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)
 
void GenerateInputRequestedRegion () override
 
 ImageToImageFilter ()
 
void VerifyInputInformation () const override
 
 ~ImageToImageFilter () override=default
 
- Protected Member Functions inherited from itk::ImageSource< TOutputImage >
virtual void AfterThreadedGenerateData ()
 
virtual void AllocateOutputs ()
 
virtual void BeforeThreadedGenerateData ()
 
void ClassicMultiThread (ThreadFunctionType callbackFunction)
 
virtual const ImageRegionSplitterBaseGetImageRegionSplitter () const
 
 ImageSource ()
 
virtual unsigned int SplitRequestedRegion (unsigned int i, unsigned int pieces, OutputImageRegionType &splitRegion)
 
 ~ImageSource () override=default
 
virtual void ThreadedGenerateData (const OutputImageRegionType &region, ThreadIdType threadId)
 
virtual void DynamicThreadedGenerateData (const OutputImageRegionType &outputRegionForThread)
 
virtual bool GetDynamicMultiThreading () const
 
virtual void SetDynamicMultiThreading (bool _arg)
 
virtual void DynamicMultiThreadingOn ()
 
virtual void DynamicMultiThreadingOff ()
 
- Protected Member Functions inherited from itk::ProcessObject
virtual void AddInput (DataObject *input)
 
void AddOptionalInputName (const DataObjectIdentifierType &)
 
void AddOptionalInputName (const DataObjectIdentifierType &, DataObjectPointerArraySizeType idx)
 
virtual void AddOutput (DataObject *output)
 
bool AddRequiredInputName (const DataObjectIdentifierType &)
 
bool AddRequiredInputName (const DataObjectIdentifierType &, DataObjectPointerArraySizeType idx)
 
virtual void CacheInputReleaseDataFlags ()
 
virtual void GenerateOutputInformation ()
 
virtual void GenerateOutputRequestedRegion (DataObject *output)
 
DataObjectGetInput (const DataObjectIdentifierType &key)
 
const DataObjectGetInput (const DataObjectIdentifierType &key) const
 
virtual const DataObjectPointerArraySizeTypeGetNumberOfRequiredInputs () const
 
virtual const DataObjectPointerArraySizeTypeGetNumberOfRequiredOutputs () const
 
bool IsIndexedInputName (const DataObjectIdentifierType &) const
 
bool IsIndexedOutputName (const DataObjectIdentifierType &) const
 
bool IsRequiredInputName (const DataObjectIdentifierType &) const
 
DataObjectPointerArraySizeType MakeIndexFromInputName (const DataObjectIdentifierType &name) const
 
DataObjectPointerArraySizeType MakeIndexFromOutputName (const DataObjectIdentifierType &name) const
 
DataObjectIdentifierType MakeNameFromInputIndex (DataObjectPointerArraySizeType idx) const
 
DataObjectIdentifierType MakeNameFromOutputIndex (DataObjectPointerArraySizeType idx) const
 
 ProcessObject ()
 
virtual void PropagateResetPipeline ()
 
virtual void PushBackInput (const DataObject *input)
 
virtual void PushFrontInput (const DataObject *input)
 
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 idx, DataObject *input)
 
virtual void SetNthOutput (DataObjectPointerArraySizeType idx, DataObject *output)
 
void SetNumberOfIndexedInputs (DataObjectPointerArraySizeType num)
 
void SetNumberOfIndexedOutputs (DataObjectPointerArraySizeType num)
 
virtual void SetNumberOfRequiredInputs (DataObjectPointerArraySizeType)
 
virtual void SetNumberOfRequiredOutputs (DataObjectPointerArraySizeType _arg)
 
virtual void SetOutput (const DataObjectIdentifierType &name, DataObject *output)
 
virtual void SetPrimaryInput (DataObject *object)
 
virtual void SetPrimaryOutput (DataObject *object)
 
void SetRequiredInputNames (const NameArray &)
 
 ~ProcessObject () override
 
DataObjectGetInput (DataObjectPointerArraySizeType idx)
 
const DataObjectGetInput (DataObjectPointerArraySizeType idx) const
 
DataObjectGetPrimaryInput ()
 
const DataObjectGetPrimaryInput () const
 
virtual void SetPrimaryInputName (const DataObjectIdentifierType &key)
 
virtual const char * GetPrimaryInputName () const
 
DataObjectGetOutput (const DataObjectIdentifierType &key)
 
const DataObjectGetOutput (const DataObjectIdentifierType &key) const
 
virtual void SetPrimaryOutputName (const DataObjectIdentifierType &key)
 
virtual const char * GetPrimaryOutputName () const
 
DataObjectGetOutput (DataObjectPointerArraySizeType i)
 
const DataObjectGetOutput (DataObjectPointerArraySizeType i) const
 
DataObjectGetPrimaryOutput ()
 
const DataObjectGetPrimaryOutput () const
 
virtual bool GetThreaderUpdateProgress () const
 
virtual void ThreaderUpdateProgressOn ()
 
virtual void ThreaderUpdateProgressOff ()
 
virtual void SetThreaderUpdateProgress (bool arg)
 
- Protected Member Functions inherited from itk::Object
 Object ()
 
bool PrintObservers (std::ostream &os, Indent indent) const
 
virtual void SetTimeStamp (const TimeStamp &timeStamp)
 
 ~Object () override
 
- 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 ()
 

Static Private Member Functions

static constexpr double DefaultDynamicRange ()
 

Private Attributes

double m_ContrastExponent { 1.0 }
 
double m_DynamicRange { DefaultDynamicRange() }
 
double m_GaussianSigma { 1.5 }
 
double m_K1 { 0.01 }
 
double m_K2 { 0.03 }
 
double m_LuminanceExponent { 1.0 }
 
unsigned int m_MaximumKernelWidth { 11 }
 
double m_MeanSSIM { 0.0 }
 
ScaleWeightsType m_ScaleWeights { 1, static_cast<RealType>(1.0) }
 
double m_StructureExponent { 1.0 }
 

Additional Inherited Members

- Protected Types inherited from itk::ImageToImageFilter< TInputImage, TOutputImage >
using InputToOutputRegionCopierType
 
using OutputToInputRegionCopierType
 
- Static Protected Member Functions inherited from itk::ImageSource< TOutputImage >
static const ImageRegionSplitterBaseGetGlobalDefaultSplitter ()
 
static ITK_THREAD_RETURN_FUNCTION_CALL_CONVENTION ThreaderCallback (void *arg)
 
- Static Protected Member Functions inherited from itk::ProcessObject
template<typename TSourceObject>
static void MakeRequiredOutputs (TSourceObject &sourceObject, const DataObjectPointerArraySizeType numberOfRequiredOutputs)
 
static constexpr float progressFixedToFloat (uint32_t fixed)
 
static uint32_t progressFloatToFixed (float f)
 
- Protected Attributes inherited from itk::ImageSource< TOutputImage >
bool m_DynamicMultiThreading { true }
 
- Protected Attributes inherited from itk::ProcessObject
TimeStamp m_OutputInformationMTime {}
 
bool m_Updating {}
 
- Protected Attributes inherited from itk::LightObject
std::atomic< int > m_ReferenceCount {}
 

Member Typedef Documentation

◆ ConstPointer

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::ConstPointer = SmartPointer<const Self>

Definition at line 121 of file itkStructuralSimilarityImageFilter.h.

◆ IndexType

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::IndexType = typename InputImageType::IndexType

Definition at line 137 of file itkStructuralSimilarityImageFilter.h.

◆ InputImageRegionType

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::InputImageRegionType = typename InputImageType::RegionType

Definition at line 134 of file itkStructuralSimilarityImageFilter.h.

◆ InputImageType

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::InputImageType = TInputImage

Image type aliases.

Definition at line 130 of file itkStructuralSimilarityImageFilter.h.

◆ InputPixelType

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::InputPixelType = typename InputImageType::PixelType

Definition at line 132 of file itkStructuralSimilarityImageFilter.h.

◆ OutputImageRegionType

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::OutputImageRegionType = typename OutputImageType::RegionType

Definition at line 135 of file itkStructuralSimilarityImageFilter.h.

◆ OutputImageType

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::OutputImageType = TOutputImage

Definition at line 131 of file itkStructuralSimilarityImageFilter.h.

◆ OutputPixelType

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::OutputPixelType = typename OutputImageType::PixelType

Definition at line 133 of file itkStructuralSimilarityImageFilter.h.

◆ Pointer

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::Pointer = SmartPointer<Self>

Definition at line 120 of file itkStructuralSimilarityImageFilter.h.

◆ RealType

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::RealType = typename NumericTraits<InputPixelType>::RealType

Floating-point type used for all SSIM computations.

Definition at line 142 of file itkStructuralSimilarityImageFilter.h.

◆ ScaleWeightsType

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::ScaleWeightsType = Array<RealType>

Type used for the user-specified array of multi-scale weights.

Definition at line 145 of file itkStructuralSimilarityImageFilter.h.

◆ Self

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::Self = StructuralSimilarityImageFilter

Standard class type aliases.

Definition at line 118 of file itkStructuralSimilarityImageFilter.h.

◆ SizeType

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SizeType = typename InputImageType::SizeType

Definition at line 136 of file itkStructuralSimilarityImageFilter.h.

◆ Superclass

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
using itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::Superclass = ImageToImageFilter<TInputImage, TOutputImage>

Definition at line 119 of file itkStructuralSimilarityImageFilter.h.

Constructor & Destructor Documentation

◆ StructuralSimilarityImageFilter()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::StructuralSimilarityImageFilter ( )
protected

Referenced by GetNameOfClass().

◆ ~StructuralSimilarityImageFilter()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::~StructuralSimilarityImageFilter ( )
overrideprotecteddefault

Member Function Documentation

◆ CreateAnother()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual::itk::LightObject::Pointer itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::CreateAnother ( ) 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.

◆ DefaultDynamicRange()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
static constexpr double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::DefaultDynamicRange ( )
inlinestaticconstexprprivate

Default dynamic range: 1.0 for floating-point pixels (assume normalized data), and NumericTraits::max() - NumericTraits::min() for integer pixels (e.g. 255 for unsigned char).

Definition at line 268 of file itkStructuralSimilarityImageFilter.h.

References itk::NumericTraits< T >::max(), and itk::NumericTraits< T >::min().

◆ EnlargeOutputRequestedRegion()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::EnlargeOutputRequestedRegion ( DataObject * data)
overrideprotectedvirtual

This filter computes the full output.

Reimplemented from itk::ProcessObject.

◆ GenerateData()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GenerateData ( )
overrideprotectedvirtual

Composite-filter-style: drives the internal sub-pipeline (5 Gaussian convolutions plus a parallelized SSIM combination).

Reimplemented from itk::ImageSource< TOutputImage >.

◆ GetContrastExponent()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetContrastExponent ( ) const
virtual

Exponent \(\beta\) on the contrast term. Default 1.0.

◆ GetDynamicRange()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetDynamicRange ( ) const
virtual

Dynamic range \(L\) of the pixel values used to compute \(C_1 = (K_1 L)^2\) and \(C_2 = (K_2 L)^2\). Default depends on the input pixel type: 255 for unsigned char, 65535 for unsigned short, 1.0 for float / double, etc.

◆ GetGaussianSigma()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetGaussianSigma ( ) const
virtual

Standard deviation \(\sigma\) of the Gaussian window used to compute local statistics. Default 1.5 (matching Wang et al. 2004).

◆ GetInput1()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
const InputImageType * itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetInput1 ( ) const
inline

Set/Get the first input image.

Definition at line 155 of file itkStructuralSimilarityImageFilter.h.

References itk::ImageToImageFilter< TInputImage, TOutputImage >::GetInput().

◆ GetInput2()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
const InputImageType * itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetInput2 ( ) const

Set/Get the second input image.

◆ GetK1()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetK1 ( ) const
virtual

\(K_1\) stability constant. Default 0.01.

◆ GetK2()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetK2 ( ) const
virtual

\(K_2\) stability constant. Default 0.03.

◆ GetLuminanceExponent()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetLuminanceExponent ( ) const
virtual

Exponent \(\alpha\) on the luminance term. Default 1.0.

◆ GetMaximumKernelWidth()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual unsigned int itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetMaximumKernelWidth ( ) const
virtual

Maximum width (per dimension) of the discrete Gaussian kernel. Default 11, giving an 11x11 window in 2D when sigma=1.5.

◆ GetMeanSSIM()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetMeanSSIM ( ) const
virtual

Mean SSIM over the valid (non-Gaussian-padded) region. Available after Update().

◆ GetNameOfClass()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual const char * itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetNameOfClass ( ) const
virtual

◆ GetScaleWeights()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual const ScaleWeightsType & itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetScaleWeights ( ) const
virtual

Per-scale weights for multi-scale SSIM (MS-SSIM). An array of size 1 (the default) requests ordinary single-scale SSIM and is the only configuration currently supported. Setting an array of length greater than 1 will currently raise an exception in BeforeGenerate.

◆ GetStructureExponent()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::GetStructureExponent ( ) const
virtual

Exponent \(\gamma\) on the structure term. Default 1.0.

◆ New()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
static Pointer itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::New ( )
static

Method for creation through the object factory.

◆ PrintSelf()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::PrintSelf ( std::ostream & os,
Indent indent ) const
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 >.

◆ SetContrastExponent()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetContrastExponent ( double _arg)
virtual

Exponent \(\beta\) on the contrast term. Default 1.0.

◆ SetDynamicRange()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetDynamicRange ( double _arg)
virtual

Dynamic range \(L\) of the pixel values used to compute \(C_1 = (K_1 L)^2\) and \(C_2 = (K_2 L)^2\). Default depends on the input pixel type: 255 for unsigned char, 65535 for unsigned short, 1.0 for float / double, etc.

◆ SetGaussianSigma()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetGaussianSigma ( double _arg)
virtual

Standard deviation \(\sigma\) of the Gaussian window used to compute local statistics. Default 1.5 (matching Wang et al. 2004).

◆ SetInput1()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetInput1 ( const InputImageType * image)
inline

Set/Get the first input image.

Definition at line 150 of file itkStructuralSimilarityImageFilter.h.

References itk::ImageToImageFilter< TInputImage, TOutputImage >::SetInput().

◆ SetInput2()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetInput2 ( const InputImageType * image)

Set/Get the second input image.

◆ SetK1()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetK1 ( double _arg)
virtual

\(K_1\) stability constant. Default 0.01.

◆ SetK2()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetK2 ( double _arg)
virtual

\(K_2\) stability constant. Default 0.03.

◆ SetLuminanceExponent()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetLuminanceExponent ( double _arg)
virtual

Exponent \(\alpha\) on the luminance term. Default 1.0.

◆ SetMaximumKernelWidth()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetMaximumKernelWidth ( unsigned int _arg)
virtual

Maximum width (per dimension) of the discrete Gaussian kernel. Default 11, giving an 11x11 window in 2D when sigma=1.5.

◆ SetScaleWeights()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetScaleWeights ( const ScaleWeightsType & weights)

Per-scale weights for multi-scale SSIM (MS-SSIM). An array of size 1 (the default) requests ordinary single-scale SSIM and is the only configuration currently supported. Setting an array of length greater than 1 will currently raise an exception in BeforeGenerate.

◆ SetStructureExponent()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
virtual void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::SetStructureExponent ( double _arg)
virtual

Exponent \(\gamma\) on the structure term. Default 1.0.

◆ VerifyPreconditions()

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
void itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::VerifyPreconditions ( ) const
overrideprotectedvirtual

Verify that parameters are valid and both inputs are set with matching regions.

Reimplemented from itk::ProcessObject.

Member Data Documentation

◆ ImageDimension

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
unsigned int itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::ImageDimension = InputImageType::ImageDimension
staticconstexpr

Definition at line 139 of file itkStructuralSimilarityImageFilter.h.

◆ m_ContrastExponent

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::m_ContrastExponent { 1.0 }
private

Definition at line 282 of file itkStructuralSimilarityImageFilter.h.

◆ m_DynamicRange

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::m_DynamicRange { DefaultDynamicRange() }
private

Definition at line 280 of file itkStructuralSimilarityImageFilter.h.

◆ m_GaussianSigma

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::m_GaussianSigma { 1.5 }
private

Definition at line 259 of file itkStructuralSimilarityImageFilter.h.

◆ m_K1

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::m_K1 { 0.01 }
private

Definition at line 261 of file itkStructuralSimilarityImageFilter.h.

◆ m_K2

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::m_K2 { 0.03 }
private

Definition at line 262 of file itkStructuralSimilarityImageFilter.h.

◆ m_LuminanceExponent

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::m_LuminanceExponent { 1.0 }
private

Definition at line 281 of file itkStructuralSimilarityImageFilter.h.

◆ m_MaximumKernelWidth

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
unsigned int itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::m_MaximumKernelWidth { 11 }
private

Definition at line 260 of file itkStructuralSimilarityImageFilter.h.

◆ m_MeanSSIM

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::m_MeanSSIM { 0.0 }
private

Definition at line 287 of file itkStructuralSimilarityImageFilter.h.

◆ m_ScaleWeights

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
ScaleWeightsType itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::m_ScaleWeights { 1, static_cast<RealType>(1.0) }
private

Definition at line 285 of file itkStructuralSimilarityImageFilter.h.

◆ m_StructureExponent

template<typename TInputImage, typename TOutputImage = Image<float, TInputImage::ImageDimension>>
double itk::StructuralSimilarityImageFilter< TInputImage, TOutputImage >::m_StructureExponent { 1.0 }
private

Definition at line 283 of file itkStructuralSimilarityImageFilter.h.


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