#include <itkPowellOptimizer.h>
Inheritance diagram for itk::PowellOptimizer:


This optimizer needs a cost function. Partial derivatives of that function are not required.
For an N-dimensional parameter space, each iteration minimizes(maximizes) the function in N (initially orthogonal) directions. Typically only 2-5 iterations are required. If gradients are available, consider a conjugate gradient line search strategy.
The SetStepLength determines the initial distance to step in a line direction when bounding the minimum (using bracketing triple spaced using a golden search strategy).
The StepTolerance terminates optimization when the parameter values are known to be within this (scaled) distance of the local extreme.
The ValueTolerance terminates optimization when the cost function values at the current parameters and at the local extreme are likely (within a second order approximation) to be within this is tolerance.
Optimizers
Definition at line 54 of file itkPowellOptimizer.h.
Public Types | |
| typedef SmartPointer< const Self > | ConstPointer |
| typedef CostFunctionType::Pointer | CostFunctionPointer |
| typedef SingleValuedCostFunction | CostFunctionType |
| typedef CostFunctionType::DerivativeType | DerivativeType |
| typedef CostFunctionType::MeasureType | MeasureType |
| typedef SingleValuedNonLinearOptimizer::ParametersType | ParametersType |
| typedef SmartPointer< Self > | Pointer |
| typedef Superclass::ScalesType | ScalesType |
| typedef PowellOptimizer | Self |
| typedef SingleValuedNonLinearOptimizer | Superclass |
Public Member Functions | |
| virtual LightObject::Pointer | CreateAnother () const |
| virtual void | DebugOff () const |
| virtual void | DebugOn () const |
| virtual void | Delete () |
| Command * | GetCommand (unsigned long tag) |
| virtual const CostFunctionType * | GetCostFunction () |
| Return Current Value *virtual const MeasureType & | GetCurrentCost () |
| virtual const unsigned int & | GetCurrentIteration () |
| virtual const unsigned int & | GetCurrentLineIteration () |
| virtual const ParametersType & | GetCurrentPosition () |
| bool | GetDebug () const |
| virtual const ParametersType & | GetInitialPosition () |
| virtual const bool & | GetMaximize () |
| virtual const unsigned int & | GetMaximumIteration () |
| virtual unsigned int | GetMaximumLineIteration () const |
| const MetaDataDictionary & | GetMetaDataDictionary (void) const |
| MetaDataDictionary & | GetMetaDataDictionary (void) |
| virtual unsigned long | GetMTime () const |
| virtual const char * | GetNameOfClass () const |
| virtual int | GetReferenceCount () const |
| virtual const ScalesType & | GetScales () |
| virtual const double & | GetStepLength () |
| virtual const double & | GetStepTolerance () |
| MeasureType | GetValue (const ParametersType ¶meters) const |
| MeasureType | GetValue () const |
| virtual const double & | GetValueTolerance () |
| bool | HasObserver (const EventObject &event) const |
| void | InvokeEvent (const EventObject &) const |
| void | InvokeEvent (const EventObject &) |
| virtual void | Modified () const |
| void | Print (std::ostream &os, Indent indent=0) const |
| virtual void | Register () const |
| void | RemoveAllObservers () |
| void | RemoveObserver (unsigned long tag) |
| virtual void | SetCostFunction (CostFunctionType *costFunction) |
| void | SetDebug (bool debugFlag) const |
| virtual void | SetInitialPosition (const ParametersType ¶m) |
| Set if the Optimizer should Maximize the metric *virtual void | SetMaximize (bool _arg) |
| Set Get maximum iteration limit *virtual void | SetMaximumIteration (unsigned int _arg) |
| Set Get the maximum number of line search iterations *virtual void | SetMaximumLineIteration (unsigned int _arg) |
| void | SetMetaDataDictionary (const MetaDataDictionary &rhs) |
| virtual void | SetReferenceCount (int) |
| void | SetScales (const ScalesType &scales) |
| Set Get StepTolerance Once the local extreme is known to be within this *distance of the current parameter optimization terminates *virtual void | SetStepTolerance (double _arg) |
| Set Get ValueTolerance Once this current cost function value is known *to be within this tolerance of the cost function value at the local optimization terminates *virtual void | SetValueTolerance (double _arg) |
| void | StartOptimization () |
| void | StopOptimization () |
| Set Get StepLength for | the (scaled) spacing of the sampling of *parameter space while bracketing the extremum */virtual void SetStepLength(double _arg) |
| virtual void | UnRegister () const |
Static Public Member Functions | |
| static void | BreakOnError () |
| static bool | GetGlobalWarningDisplay () |
| static void | GlobalWarningDisplayOff () |
| static void | GlobalWarningDisplayOn () |
| static Pointer | New () |
| This is a global flag that controls whether any warning *or error messages are displayed *static void | SetGlobalWarningDisplay (bool flag) |
Public Attributes | |
| Allow people to add remove invoke observers(callbacks) to any ITK *object.This is an implementation of the subject/observer design *pattern.An observer is added by specifying an event to respond to *and an itk unsigned lon | AddObserver )(const EventObject &event, Command *) const |
| This is a global flag that controls whether any | debug |
| Set Get ValueTolerance Once this current cost function value is known *to be within this tolerance of the cost function value at the local * | extreme |
| Set Get StepTolerance Once the local extreme is known to be within this *distance of the current parameter | values |
Protected Member Functions | |
| virtual void | BracketedLineOptimize (double ax, double bx, double cx, double fa, double fb, double fc, double *extX, double *extVal) |
| double | GetLineValue (double x) const |
| virtual unsigned int | GetSpaceDimension () |
| virtual bool | GetStop () |
| virtual void | LineBracket (double *ax, double *bx, double *cx, double *fa, double *fb, double *fc) |
| PowellOptimizer (const PowellOptimizer &) | |
| PowellOptimizer () | |
| bool | PrintObservers (std::ostream &os, Indent indent) const |
| void | PrintSelf (std::ostream &os, Indent indent) const |
| virtual void | PrintTrailer (std::ostream &os, Indent indent) const |
| virtual void | SetCurrentCost (double _arg) |
| virtual void | SetCurrentIteration (unsigned int _arg) |
| void | SetCurrentLinePoint (double x, double fx) |
| virtual void | SetCurrentPosition (const ParametersType ¶m) |
| void | SetLine (const ParametersType &origin, const vnl_vector< double > &direction) |
| virtual void | SetSpaceDimension (unsigned int _arg) |
| virtual void | SetStop (bool _arg) |
| void | Shift (double *a, double *b, double *c, double d) const |
| void | Swap (double *a, double *b) const |
| virtual | ~PowellOptimizer () |
Protected Attributes | |
| CostFunctionPointer | m_CostFunction |
| int | m_ReferenceCount |
| SimpleFastMutexLock | m_ReferenceCountLock |
| bool | m_ScalesInitialized |
| Methods invoked by virtual 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.*/virtual void PrintSelf(std voi | PrintHeader )(std::ostream &os, Indent indent) const |
|
|
Reimplemented from itk::SingleValuedNonLinearOptimizer. Reimplemented in itk::FRPROptimizer. Definition at line 62 of file itkPowellOptimizer.h. |
|
|
Reimplemented from itk::SingleValuedNonLinearOptimizer. Reimplemented in itk::FRPROptimizer. Definition at line 75 of file itkPowellOptimizer.h. |
|
|
Type of the Cost Function Reimplemented from itk::SingleValuedNonLinearOptimizer. Reimplemented in itk::FRPROptimizer. Definition at line 71 of file itkPowellOptimizer.h. |
|
|
Derivative type. It defines a type used to return the cost function derivative. Definition at line 64 of file itkSingleValuedNonLinearOptimizer.h. |
|
|
Measure type. It defines a type used to return the cost function value. Reimplemented in itk::LBFGSBOptimizer. Definition at line 60 of file itkSingleValuedNonLinearOptimizer.h. |
|
|
Parameters type. It defines a position in the optimization search space. Reimplemented from itk::SingleValuedNonLinearOptimizer. Reimplemented in itk::FRPROptimizer. Definition at line 65 of file itkPowellOptimizer.h. |
|
|
Reimplemented from itk::SingleValuedNonLinearOptimizer. Reimplemented in itk::FRPROptimizer. Definition at line 61 of file itkPowellOptimizer.h. |
|
|
Scale type. This array defines scale to be applied to parameters before being evaluated in the cost function. This allows to map to a more convenient space. In particular this is used to normalize parameter spaces in which some parameters have a different dynamic range. Reimplemented from itk::Optimizer. Definition at line 52 of file itkNonLinearOptimizer.h. |
|
|
Standard "Self" typedef. Reimplemented from itk::SingleValuedNonLinearOptimizer. Reimplemented in itk::FRPROptimizer. Definition at line 59 of file itkPowellOptimizer.h. |
|
|
Reimplemented from itk::SingleValuedNonLinearOptimizer. Reimplemented in itk::FRPROptimizer. Definition at line 60 of file itkPowellOptimizer.h. |
|
|
|
|
|
|
|
|
|
|
||||||||||||||||||||||||||||||||||||
|
Given a bracketing triple of points and their function values, returns a bounded extreme. These values are in parameter space, along the current line and wrt the current origin set via SetLine. Optimization terminates based on MaximumIteration, StepTolerance, or ValueTolerance. Implemented as Brent line optimers from NRC. |
|
|
This method is called when itkExceptionMacro executes. It allows the debugger to break on error. |
|
|
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. |
|
|
Turn debugging output off. |
|
|
Turn debugging output on. |
|
|
Delete an itk object. This method should always be used to delete an object when the new operator was used to create it. Using the C delete method will not work with reference counting. |
|
|
Get the command associated with the given tag. NOTE: This returns a pointer to a Command, but it is safe to asign this to a Command::Pointer. Since Command inherits from LightObject, at this point in the code, only a pointer or a reference to the Command can be used. |
|
|
Get the cost function. |
|
|
|
|
|
Return Current Iteration |
|
|
Get the current line search iteration |
|
|
Get current position of the optimization. |
|
|
Get the value of the debug flag. |
|
|
|
|
|
Get the position to initialize the optimization. |
|
|
Get the value of the n-dimensional cost function at this scalar step distance along the current line direction from the current line origin. Line origin and distances are set via SetLine |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Run-time type information (and related methods). Reimplemented from itk::SingleValuedNonLinearOptimizer. Reimplemented in itk::FRPROptimizer. |
|
|
Gets the reference count on this object. Definition at line 98 of file itkLightObject.h. |
|
|
Get current parameters scaling. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Get the cost function value at the given parameters. Reimplemented in itk::SPSAOptimizer. |
|
|
Definition at line 113 of file itkPowellOptimizer.h. |
|
|
|
|
|
Definition at line 100 of file itkObject.h. References itk::Object::SetGlobalWarningDisplay(). |
|
|
Definition at line 98 of file itkObject.h. References itk::Object::SetGlobalWarningDisplay(). |
|
|
Return true if an observer is registered for this event. |
|
|
Call Execute on all the Commands observing this event id. The actions triggered by this call doesn't modify this object. |
|
|
Call Execute on all the Commands observing this event id. |
|
||||||||||||||||||||||||||||
|
The LineBracket routine from NRC. Uses current origin and line direction (from SetLine) to find a triple of points (ax, bx, cx) that bracket the extreme "near" the origin. Search first considers the point StepLength distance from ax. IMPORTANT: The value of ax and the value of the function at ax (i.e., fa), must both be provided to this function. |
|
|
|
Method for creation through the object factory. Reimplemented from itk::SingleValuedNonLinearOptimizer. Reimplemented in itk::FRPROptimizer. |
|
||||||||||||
|
Cause the object to print itself out. |
|
||||||||||||
|
|
|
||||||||||||
|
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::SingleValuedNonLinearOptimizer. Reimplemented in itk::FRPROptimizer. |
|
||||||||||||
|
|
|
|
Increase the reference count (mark as used by another object). Reimplemented from itk::LightObject. |
|
|
Remove all observers . |
|
|
Remove the observer with this tag value. |
|
|
Set the cost function. |
|
|
|
|
|
|
|
||||||||||||
|
Set the given scalar step distance (x) and function value (fx) as the "best-so-far" optimizer values. |
|
|
Set the current position. |
|
|
Set the value of the debug flag. A non-zero value turns debugging on. |
|
|
Referenced by itk::Object::GlobalWarningDisplayOff(), and itk::Object::GlobalWarningDisplayOn(). |
|
|
Set the position to initialize the optimization. |
|
||||||||||||
|
Used to specify the line direction through the n-dimensional parameter space the is currently being bracketed and optimized. |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Sets the reference count (use with care) Reimplemented from itk::LightObject. |
|
|
Set current parameters scaling. Reimplemented in itk::LBFGSBOptimizer. |
|
|
|
|
|
|
|
|
|
|
|
|
|
||||||||||||||||||||
|
Used in bracketing the extreme along the current line. Adapted from NRC |
|
|
Start optimization. Reimplemented from itk::Optimizer. Reimplemented in itk::FRPROptimizer. |
|
|
When users call StartOptimization, this value will be set false. By calling StopOptimization, this flag will be set true, and optimization will stop at the next iteration. Definition at line 128 of file itkPowellOptimizer.h. |
|
||||||||||||
|
Used in bracketing the extreme along the current line. Adapted from NRC |
|
|
|
|
|
Decrease the reference count (release by another object). Reimplemented from itk::LightObject. |
|
|
|
|
|
Definition at line 94 of file itkObject.h. |
|
|
Definition at line 101 of file itkPowellOptimizer.h. |
|
|
Definition at line 80 of file itkSingleValuedNonLinearOptimizer.h. |
|
|
Number of uses of this object by other objects. Definition at line 119 of file itkLightObject.h. |
|
|
Mutex lock to protect modification to the reference count Definition at line 122 of file itkLightObject.h. |
|
|
Definition at line 90 of file itkOptimizer.h. |
|
|
|
|
|
Definition at line 95 of file itkPowellOptimizer.h. |
1.4.2 written by Dimitri van Heesch,
© 1997-2000