#include <itkGradientDescentOptimizer.h>
Implement a gradient descent optimizer.
GradientDescentOptimizer implements a simple gradient descent optimizer. At each iteration the current position is updated according to
\[ p_{n+1} = p_n + \mbox{learningRate} \, \frac{\partial f(p_n) }{\partial p_n} \]
The learning rate is a fixed scalar defined via SetLearningRate(). The optimizer steps through a user defined number of iterations; no convergence checking is done.
Additionally, user can scale each component, \( \partial f / \partial p \), by setting a scaling vector using method SetScale().
Definition at line 72 of file itkGradientDescentOptimizer.h.
Public Member Functions | |
virtual void | AdvanceOneStep () |
virtual::itk::LightObject::Pointer | CreateAnother () const |
virtual SizeValueType | GetCurrentIteration () const |
virtual const DerivativeType & | GetGradient () const |
virtual const double & | GetLearningRate () const |
const char * | GetNameOfClass () const override |
virtual const SizeValueType & | GetNumberOfIterations () const |
virtual const double & | GetValue () const |
void | ResumeOptimization () |
virtual void | SetLearningRate (double _arg) |
virtual void | SetNumberOfIterations (SizeValueType _arg) |
void | StartOptimization () override |
void | StopOptimization () |
virtual const bool & | GetMaximize () const |
virtual void | SetMaximize (bool _arg) |
virtual void | MaximizeOn () |
virtual void | MaximizeOff () |
bool | GetMinimize () const |
void | SetMinimize (bool v) |
void | MinimizeOn () |
void | MinimizeOff () |
virtual const StopConditionGradientDescentOptimizerEnum & | GetStopCondition () const |
std::string | GetStopConditionDescription () const override |
![]() | |
virtual::itk::LightObject::Pointer | CreateAnother () const |
virtual const CostFunctionType * | GetCostFunction () const |
virtual CostFunctionType * | GetModifiableCostFunction () |
const char * | GetNameOfClass () const override |
MeasureType | GetValue (const ParametersType ¶meters) const |
virtual void | SetCostFunction (CostFunctionType *costFunction) |
![]() | |
virtual const ParametersType & | GetCurrentPosition () const |
virtual const ParametersType & | GetInitialPosition () const |
virtual void | SetInitialPosition (const ParametersType ¶m) |
void | SetScales (const ScalesType &scales) |
virtual const ScalesType & | GetScales () const |
virtual const ScalesType & | GetInverseScales () const |
![]() | |
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 |
Command * | GetCommand (unsigned long tag) |
bool | GetDebug () const |
MetaDataDictionary & | GetMetaDataDictionary () |
const MetaDataDictionary & | GetMetaDataDictionary () const |
virtual ModifiedTimeType | GetMTime () const |
virtual const TimeStamp & | GetTimeStamp () 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 |
![]() | |
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 Pointer | New () |
![]() | |
static Pointer | New () |
![]() | |
static Pointer | New () |
![]() | |
static bool | GetGlobalWarningDisplay () |
static void | GlobalWarningDisplayOff () |
static void | GlobalWarningDisplayOn () |
static Pointer | New () |
static void | SetGlobalWarningDisplay (bool val) |
![]() | |
static void | BreakOnError () |
static Pointer | New () |
Protected Member Functions | |
GradientDescentOptimizer () | |
void | PrintSelf (std::ostream &os, Indent indent) const override |
~GradientDescentOptimizer () override=default | |
![]() | |
void | PrintSelf (std::ostream &os, Indent indent) const override |
SingleValuedNonLinearOptimizer () | |
~SingleValuedNonLinearOptimizer () override=default | |
![]() | |
NonLinearOptimizer ()=default | |
~NonLinearOptimizer () override | |
![]() | |
Optimizer () | |
virtual void | SetCurrentPosition (const ParametersType ¶m) |
~Optimizer () override=default | |
![]() | |
Object () | |
bool | PrintObservers (std::ostream &os, Indent indent) const |
virtual void | SetTimeStamp (const TimeStamp &timeStamp) |
~Object () override | |
![]() | |
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 () |
Protected Attributes | |
DerivativeType | m_Gradient {} |
double | m_LearningRate { 1.0 } |
bool | m_Maximize { false } |
![]() | |
CostFunctionPointer | m_CostFunction {} |
![]() | |
ParametersType | m_CurrentPosition {} |
bool | m_ScalesInitialized { false } |
![]() | |
std::atomic< int > | m_ReferenceCount {} |
Private Attributes | |
SizeValueType | m_CurrentIteration { 0 } |
SizeValueType | m_NumberOfIterations { 100 } |
bool | m_Stop { false } |
StopConditionGradientDescentOptimizerEnum | m_StopCondition |
std::ostringstream | m_StopConditionDescription {} |
double | m_Value { 0.0 } |
using itk::GradientDescentOptimizer::ConstPointer = SmartPointer<const Self> |
Definition at line 81 of file itkGradientDescentOptimizer.h.
Definition at line 80 of file itkGradientDescentOptimizer.h.
Standard class type aliases.
Definition at line 78 of file itkGradientDescentOptimizer.h.
Definition at line 89 of file itkGradientDescentOptimizer.h.
Definition at line 79 of file itkGradientDescentOptimizer.h.
|
protected |
Referenced by GetNameOfClass().
|
overrideprotecteddefault |
|
virtual |
Advance one step following the gradient direction.
Reimplemented in itk::QuaternionRigidTransformGradientDescentOptimizer.
|
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::LightObject.
Reimplemented in itk::QuaternionRigidTransformGradientDescentOptimizer.
|
virtual |
Get the current iteration number.
|
virtual |
Get Gradient condition.
|
virtual |
Get the learning rate.
|
virtual |
Methods to configure the cost function.
|
inline |
Methods to configure the cost function.
Definition at line 105 of file itkGradientDescentOptimizer.h.
References m_Maximize.
|
overridevirtual |
Reimplemented from itk::LightObject.
Reimplemented in itk::QuaternionRigidTransformGradientDescentOptimizer.
References GradientDescentOptimizer().
|
virtual |
Get the number of iterations.
|
virtual |
Get Stop condition.
|
overridevirtual |
Get Stop condition.
Reimplemented from itk::Optimizer.
|
virtual |
Get the current value.
|
virtual |
Methods to configure the cost function.
Referenced by MinimizeOn().
|
virtual |
Methods to configure the cost function.
Referenced by MinimizeOff().
|
inline |
Methods to configure the cost function.
Definition at line 120 of file itkGradientDescentOptimizer.h.
References MaximizeOn().
|
inline |
Methods to configure the cost function.
Definition at line 115 of file itkGradientDescentOptimizer.h.
References MaximizeOff().
|
static |
Method for creation through the object factory.
|
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::LightObject.
void itk::GradientDescentOptimizer::ResumeOptimization | ( | ) |
Resume previously stopped optimization with current parameters
|
virtual |
Set the learning rate.
|
virtual |
Methods to configure the cost function.
Referenced by SetMinimize().
|
inline |
Methods to configure the cost function.
Definition at line 110 of file itkGradientDescentOptimizer.h.
References SetMaximize().
|
virtual |
Set the number of iterations.
|
overridevirtual |
Start optimization.
Reimplemented from itk::Optimizer.
void itk::GradientDescentOptimizer::StopOptimization | ( | ) |
Stop optimization.
|
private |
Definition at line 191 of file itkGradientDescentOptimizer.h.
|
protected |
Definition at line 178 of file itkGradientDescentOptimizer.h.
|
protected |
Definition at line 182 of file itkGradientDescentOptimizer.h.
|
protected |
Definition at line 180 of file itkGradientDescentOptimizer.h.
Referenced by GetMinimize().
|
private |
Definition at line 190 of file itkGradientDescentOptimizer.h.
|
private |
Definition at line 185 of file itkGradientDescentOptimizer.h.
|
private |
Definition at line 187 of file itkGradientDescentOptimizer.h.
|
private |
Definition at line 192 of file itkGradientDescentOptimizer.h.
|
private |
Definition at line 186 of file itkGradientDescentOptimizer.h.