#include <itkCumulativeGaussianOptimizer.h>
Inheritance diagram for itk::CumulativeGaussianOptimizer:


This optimizer will only work if the data array is sampled from a Cumulative Gaussian curve. It's more of a curve fitter than an optimizer, with the advantage of being fast and specific. It works by taking the derivative of the Cumulative Gaussian sample then repeatedly extending the tails of the Gaussian and recalculating the Gaussian parameters until the change in iterations is within tolerance or very small. The Gaussian is then integrated to reproduce the Cumulative Gaussian and the asymptotes are estimated by using least squares fit to estimate the constant from integration.
Optimizers
Definition at line 47 of file itkCumulativeGaussianOptimizer.h.
Public Types | |
| typedef SmartPointer< const Self > | ConstPointer |
| typedef CostFunctionType::Pointer | CostFunctionPointer |
| typedef CumulativeGaussianCostFunction | CostFunctionType |
| typedef Array2D< double > | DerivativeType |
| typedef CostFunctionType::MeasureType | MeasureType |
| typedef Superclass::ParametersType | ParametersType |
| typedef SmartPointer< Self > | Pointer |
| typedef Superclass::ScalesType | ScalesType |
| typedef CumulativeGaussianOptimizer | Self |
| typedef MultipleValuedNonLinearOptimizer | 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 double | GetComputedMean () |
| virtual double | GetComputedStandardDeviation () |
| virtual const ParametersType & | GetCurrentPosition () |
| bool | GetDebug () const |
| virtual MeasureType * | GetFinalSampledArray () |
| virtual double | GetFitError () |
| virtual const ParametersType & | GetInitialPosition () |
| virtual double | GetLowerAsymptote () |
| 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 double | GetUpperAsymptote () |
| 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 |
| void | PrintArray (MeasureType *array) |
| virtual void | Register () const |
| void | RemoveAllObservers () |
| void | RemoveObserver (unsigned long tag) |
| virtual void | SetCostFunction (CostFunctionType *costFunction) |
| void | SetDataArray (MeasureType *dataArray) |
| void | SetDebug (bool debugFlag) const |
| Set and get macros *virtual void | SetDifferenceTolerance (double _arg) |
| virtual void | SetInitialPosition (const ParametersType ¶m) |
| void | SetMetaDataDictionary (const MetaDataDictionary &rhs) |
| virtual void | SetReferenceCount (int) |
| void | SetScales (const ScalesType &scales) |
| virtual void | SetVerbose (bool _arg) |
| void | StartOptimization () |
| 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 |
Protected Member Functions | |
| CumulativeGaussianOptimizer () | |
| 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 | SetCurrentPosition (const ParametersType ¶m) |
| virtual | ~CumulativeGaussianOptimizer () |
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::MultipleValuedNonLinearOptimizer. Definition at line 57 of file itkCumulativeGaussianOptimizer.h. |
|
|
Definition at line 45 of file itkMultipleValuedNonLinearOptimizer.h. |
|
|
Cost function typedef. NOTE: This optimizer is specific to fitting a Cumulative Gaussian. Reimplemented from itk::MultipleValuedNonLinearOptimizer. Definition at line 60 of file itkCumulativeGaussianOptimizer.h. |
|
|
Derivative type. It defines a type used to return the cost function derivative. Here a bidimensional Array is used for Multivalued functions Definition at line 66 of file itkMultipleValuedNonLinearOptimizer.h. |
|
|
Data array typedef. Reimplemented from itk::MultipleValuedNonLinearOptimizer. Definition at line 63 of file itkCumulativeGaussianOptimizer.h. |
|
|
Parameters type. It defines a position in the optimization search space. Reimplemented from itk::NonLinearOptimizer. Reimplemented in itk::MultipleValuedNonLinearVnlOptimizer. Definition at line 52 of file itkMultipleValuedNonLinearOptimizer.h. |
|
|
Reimplemented from itk::MultipleValuedNonLinearOptimizer. Definition at line 56 of file itkCumulativeGaussianOptimizer.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 typedefs. Reimplemented from itk::MultipleValuedNonLinearOptimizer. Definition at line 54 of file itkCumulativeGaussianOptimizer.h. |
|
|
Reimplemented from itk::MultipleValuedNonLinearOptimizer. Definition at line 55 of file itkCumulativeGaussianOptimizer.h. |
|
|
|
|
|
|
|
|
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 current position of the optimization. |
|
|
Get the value of the debug flag. |
|
|
|
|
|
|
|
|
|
|
|
Get the position to initialize the optimization. |
|
|
|
|
|
|
|
|
|
|
|
|
Run-time type information (and related methods). Reimplemented from itk::MultipleValuedNonLinearOptimizer. |
|
|
Gets the reference count on this object. Definition at line 98 of file itkLightObject.h. |
|
|
Get current parameters scaling. |
|
|
|
|
|
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. |
|
|
|
Method for creation through the object factory. Reimplemented from itk::MultipleValuedNonLinearOptimizer. |
|
||||||||||||
|
Cause the object to print itself out. |
|
|
Print an array. |
|
||||||||||||
|
|
|
||||||||||||
|
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::MultipleValuedNonLinearOptimizer. |
|
||||||||||||
|
|
|
|
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 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. |
|
|
|
|
|
Sets the reference count (use with care) Reimplemented from itk::LightObject. |
|
|
Set current parameters scaling. Reimplemented in itk::LBFGSBOptimizer. |
|
|
|
|
|
Start the optimizer. Reimplemented from itk::Optimizer. |
|
|
Decrease the reference count (release by another object). Reimplemented from itk::LightObject. |
|
|
|
|
|
Definition at line 94 of file itkObject.h. |
|
|
Definition at line 76 of file itkMultipleValuedNonLinearOptimizer.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. |
|
|
|
1.4.2 written by Dimitri van Heesch,
© 1997-2000