#include <itkQuaternionRigidTransformGradientDescentOptimizer.h>
Implement a gradient descent optimizer.
QuaternionRigidTransformGradientDescentOptimizer is an extension to the simple gradient descent optimizer implemented in GradientDescentOptimizer. At each iteration the current position is updated according to
p(n+1) = p(n) + learningRate * d f(p(n)) / d p(n)
\[ 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. The first four components of p are assumed to be the four components of the quaternion. After each update, the quaternion is normalized to have a magnitude of one. This ensures the transform is purely rigid.
Definition at line 52 of file itkQuaternionRigidTransformGradientDescentOptimizer.h.
Public Member Functions | |
void | AdvanceOneStep () override |
virtual::itk::LightObject::Pointer | CreateAnother () const |
const char * | GetNameOfClass () const override |
![]() | |
virtual SizeValueType | GetCurrentIteration () const |
virtual const DerivativeType & | GetGradient () const |
virtual const double & | GetLearningRate () const |
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 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 | |
QuaternionRigidTransformGradientDescentOptimizer ()=default | |
~QuaternionRigidTransformGradientDescentOptimizer () override=default | |
![]() | |
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 () |
Additional Inherited Members | |
![]() | |
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 {} |
using itk::QuaternionRigidTransformGradientDescentOptimizer::ConstPointer = SmartPointer<const Self> |
Definition at line 61 of file itkQuaternionRigidTransformGradientDescentOptimizer.h.
using itk::QuaternionRigidTransformGradientDescentOptimizer::ParametersType = Superclass::ParametersType |
Parameters type. It defines a position in the optimization search space.
Definition at line 71 of file itkQuaternionRigidTransformGradientDescentOptimizer.h.
Definition at line 60 of file itkQuaternionRigidTransformGradientDescentOptimizer.h.
using itk::QuaternionRigidTransformGradientDescentOptimizer::Self = QuaternionRigidTransformGradientDescentOptimizer |
Standard class type aliases.
Definition at line 58 of file itkQuaternionRigidTransformGradientDescentOptimizer.h.
Definition at line 59 of file itkQuaternionRigidTransformGradientDescentOptimizer.h.
|
protecteddefault |
Referenced by GetNameOfClass().
|
overrideprotecteddefault |
|
overridevirtual |
Advance one step following the gradient direction.
Reimplemented from itk::GradientDescentOptimizer.
|
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::GradientDescentOptimizer.
|
overridevirtual |
Reimplemented from itk::GradientDescentOptimizer.
References QuaternionRigidTransformGradientDescentOptimizer().
|
static |
Method for creation through the object factory.