18#ifndef itkCompositeValleyFunction_h
19#define itkCompositeValleyFunction_h
22#include "ITKBiasCorrectionExport.h"
79 TargetClass(
double mean,
double sigma)
100 SetSigma(
double sigma)
116class ITKBiasCorrection_EXPORT CompositeValleyFunction :
public CacheableScalarFunction
123 using MeasureType = Superclass::MeasureType;
124 using MeasureArrayType = Superclass::MeasureArrayType;
127 CompositeValleyFunction(
const MeasureArrayType & classMeans,
const MeasureArrayType & classSigmas);
130 ~CompositeValleyFunction()
override;
134 GetUpperBound()
const
141 GetLowerBound()
const
149 operator()(MeasureType x)
151 if (x > m_UpperBound || x < m_LowerBound)
156 if (!this->IsCacheAvailable())
158 return this->Evaluate(x);
161 return GetCachedValue(x);
166 Evaluate(MeasureType x)
override;
170 valley(MeasureType d)
172 return 1 - 1 / (1 + d * d / 3);
177 AddNewClass(
double mean,
double sigma)
179 const TargetClass aClass(mean, sigma);
181 m_Targets.push_back(aClass);
190 std::vector<TargetClass> m_Targets{};
194 double m_UpperBound{};
BinaryGeneratorImageFilter< TInputImage1, TInputImage2, TOutputImage > Superclass
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....