18#ifndef itkPowellOptimizerv4_h
19#define itkPowellOptimizerv4_h
59template <
typename TInternalComputationValueType>
81 itkSetMacro(MaximumIteration,
unsigned int);
82 itkGetConstReferenceMacro(MaximumIteration,
unsigned int);
86 itkSetMacro(MaximumLineIteration,
unsigned int);
87 itkGetConstMacro(MaximumLineIteration,
unsigned int);
92 itkSetMacro(StepLength,
double);
93 itkGetConstReferenceMacro(StepLength,
double);
98 itkSetMacro(StepTolerance,
double);
99 itkGetConstReferenceMacro(StepTolerance,
double);
105 itkSetMacro(ValueTolerance,
double);
106 itkGetConstReferenceMacro(ValueTolerance,
double);
118 itkGetConstReferenceMacro(CurrentLineIteration,
unsigned int);
133 itkGetConstReferenceMacro(CatchGetValueException,
bool);
134 itkSetMacro(CatchGetValueException,
bool);
135 itkBooleanMacro(CatchGetValueException);
137 itkGetConstReferenceMacro(MetricWorstPossibleValue,
double);
138 itkSetMacro(MetricWorstPossibleValue,
double);
150 itkSetMacro(CurrentCost,
double);
174 Swap(
double * a,
double * b)
const;
179 Shift(
double * a,
double * b,
double * c,
double d)
const;
191 LineBracket(
double * x1,
double * x2,
double * x3,
double * f1,
double * f2,
double * f3);
206 double functionValueOfb,
216 double functionValueOfb,
222 itkGetMacro(SpaceDimension,
unsigned int);
233 itkSetMacro(CurrentIteration,
unsigned int);
235 itkGetMacro(Stop,
bool);
236 itkSetMacro(Stop,
bool);
275#ifndef ITK_MANUAL_INSTANTIATION
276# include "itkPowellOptimizerv4.hxx"
Control indentation during Print() invocation.
OptimizerParameters< TInternalComputationValueType > ScalesType
ObjectToObjectOptimizerBaseTemplate()
OptimizerParameters< TInternalComputationValueType > ParametersType
typename MetricType::MeasureType MeasureType
virtual void Modified() const
ParametersType m_CurrentPosition
virtual void LineBracket(double *x1, double *x2, double *x3, double *f1, double *f2, double *f3, ParametersType &tempCoord)
typename MetricType::MeasureType MeasureType
SmartPointer< const Self > ConstPointer
virtual const MeasureType & GetCurrentCost() const
unsigned int m_CurrentLineIteration
void StartOptimization(bool doOnlyInitialization=false) override
OptimizerParameters< TInternalComputationValueType > ParametersType
std::string GetStopConditionDescription() const override
virtual void BracketedLineOptimize(double ax, double bx, double cx, double fa, double functionValueOfb, double fc, double *extX, double *extVal)
MeasureType m_CurrentCost
bool m_CatchGetValueException
PowellOptimizerv4(const PowellOptimizerv4 &)
unsigned int m_SpaceDimension
ParametersType m_LineOrigin
virtual void BracketedLineOptimize(double ax, double bx, double cx, double fa, double functionValueOfb, double fc, double *extX, double *extVal, ParametersType &tempCoord)
double GetLineValue(double x, ParametersType &tempCoord) const
void SetLine(const ParametersType &origin, const vnl_vector< double > &direction)
double GetLineValue(double x) const
void Swap(double *a, double *b) const
double m_MetricWorstPossibleValue
unsigned int m_MaximumLineIteration
SmartPointer< Self > Pointer
ObjectToObjectOptimizerBaseTemplate< TInternalComputationValueType > Superclass
void Shift(double *a, double *b, double *c, double d) const
vnl_vector< double > m_LineDirection
unsigned int m_MaximumIteration
const MeasureType & GetValue() const override
void SetCurrentLinePoint(double x, double fx)
void SetSpaceDimension(unsigned int dim)
virtual void LineBracket(double *x1, double *x2, double *x3, double *f1, double *f2, double *f3)
~PowellOptimizerv4() override=default
std::ostringstream m_StopConditionDescription
void PrintSelf(std::ostream &os, Indent indent) const override
Implements transparent reference counting.
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....