#include <itkVersorTransformOptimizer.h>
Implement a gradient descent optimizer.
VersorTransformOptimizer is a variant of the gradient descent optimizer implemented in RegularStepGradientDescentOptimizer.
Versors are not in a vector space, for that reason, the classical gradient descent algorithm has to be modified in order to be applicable to Versors (unit quaternions) that form the group SO(3).
The Versor space has only three degrees of freedom, even though Versors are represented using four values.
This optimizer assumes that the CostFunction to be optimized has an itk::Versor as parameters.
Definition at line 52 of file itkVersorTransformOptimizer.h.
Public Member Functions | |
virtual::itk::LightObject::Pointer | CreateAnother () const |
const char * | GetNameOfClass () const override |
void | StepAlongGradient (double factor, const DerivativeType &transformedGradient) override |
![]() | |
std::string | GetStopConditionDescription () const override |
void | ResumeOptimization () |
void | StartOptimization () override |
void | StopOptimization () |
virtual void | SetMaximize (bool _arg) |
virtual const bool & | GetMaximize () const |
virtual void | MaximizeOn () |
virtual void | MaximizeOff () |
bool | GetMinimize () const |
void | SetMinimize (bool v) |
void | MinimizeOn () |
void | MinimizeOff () |
virtual void | SetMaximumStepLength (double _arg) |
virtual void | SetMinimumStepLength (double _arg) |
virtual void | SetRelaxationFactor (double _arg) |
virtual void | SetNumberOfIterations (SizeValueType _arg) |
virtual void | SetGradientMagnitudeTolerance (double _arg) |
virtual const double & | GetCurrentStepLength () const |
virtual const double & | GetMaximumStepLength () const |
virtual const double & | GetMinimumStepLength () const |
virtual const double & | GetRelaxationFactor () const |
virtual const SizeValueType & | GetNumberOfIterations () const |
virtual const double & | GetGradientMagnitudeTolerance () const |
virtual unsigned int | GetCurrentIteration () const |
virtual const StopConditionEnum & | GetStopCondition () const |
virtual const MeasureType & | GetValue () const |
virtual const DerivativeType & | GetGradient () const |
![]() | |
virtual const CostFunctionType * | GetCostFunction () const |
virtual CostFunctionType * | GetModifiableCostFunction () |
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 | |
VersorTransformOptimizer ()=default | |
~VersorTransformOptimizer () override=default | |
![]() | |
virtual void | AdvanceOneStep () |
void | PrintSelf (std::ostream &os, Indent indent) const override |
RegularStepGradientDescentBaseOptimizer () | |
~RegularStepGradientDescentBaseOptimizer () 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 | |
![]() | |
SizeValueType | m_CurrentIteration {} |
double | m_CurrentStepLength {} |
DerivativeType | m_Gradient {} |
double | m_GradientMagnitudeTolerance {} |
bool | m_Maximize {} |
double | m_MaximumStepLength {} |
double | m_MinimumStepLength {} |
SizeValueType | m_NumberOfIterations {} |
DerivativeType | m_PreviousGradient {} |
double | m_RelaxationFactor {} |
bool | m_Stop { false } |
StopConditionEnum | m_StopCondition {} |
std::ostringstream | m_StopConditionDescription {} |
MeasureType | m_Value {} |
![]() | |
CostFunctionPointer | m_CostFunction {} |
![]() | |
ParametersType | m_CurrentPosition {} |
bool | m_ScalesInitialized { false } |
![]() | |
std::atomic< int > | m_ReferenceCount {} |
using itk::VersorTransformOptimizer::ConstPointer = SmartPointer<const Self> |
Definition at line 61 of file itkVersorTransformOptimizer.h.
Definition at line 60 of file itkVersorTransformOptimizer.h.
Standard class type aliases.
Definition at line 58 of file itkVersorTransformOptimizer.h.
Definition at line 59 of file itkVersorTransformOptimizer.h.
Definition at line 71 of file itkVersorTransformOptimizer.h.
using itk::VersorTransformOptimizer::VersorType = Versor<double> |
Versor Type
Definition at line 70 of file itkVersorTransformOptimizer.h.
|
protecteddefault |
Referenced by GetNameOfClass().
|
overrideprotecteddefault |
|
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::RegularStepGradientDescentBaseOptimizer.
|
overridevirtual |
Reimplemented from itk::RegularStepGradientDescentBaseOptimizer.
References VersorTransformOptimizer().
|
static |
Method for creation through the object factory.
|
overridevirtual |
Advance one step following the gradient direction.
Reimplemented from itk::RegularStepGradientDescentBaseOptimizer.