00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #ifndef __frePowellOptimizerController_h
00023 #define __frePowellOptimizerController_h
00024
00025 #include "freSVNonLinearOptimizerControllerBase.h"
00026
00027 #include "itkPowellOptimizer.h"
00028
00029 namespace FREE
00030 {
00031
00032
00041 freControllerIDMacro(PowellOptimizerController, "Powell Optimizer");
00042 class PowellOptimizerController : public SVNonLinearOptimizerControllerBase<itk::PowellOptimizer>
00043 {
00044 public:
00045 itkTypeMacro(PowellOptimizerController, SVNonLinearOptimizerControllerBase);
00046
00047 typedef itk::PowellOptimizer ComponentType;
00048 typedef SVNonLinearOptimizerControllerBase<ComponentType> Superclass;
00049
00050 DeclareParameterMacro(MaximumLineIteration);
00051 DeclareParameterMacro(StepLength);
00052 DeclareParameterMacro(StepTolerance);
00053 DeclareParameterMacro(ValueTolerance);
00054
00055 virtual MeasuresType GetCurrentValue(ComponentType* pOptimizer) const;
00056
00057 PowellOptimizerController();
00058
00059 protected:
00060 virtual void GenerateProfile(CtrlProfile::ControllerProfile& profile,
00061 const SessionComponentCache* pComponentCache,
00062 bool bRegardOldSetup) const;
00063
00064 virtual void ActualizeMainComponent(ComponentType* pMainComponent,
00065 SessionComponentCache* pComponentCache,
00066 SessionInfo* pSessionInfo,
00067 const unsigned int& iActLevel) const;
00068
00069 virtual void SetStatisticEntryMainComponent(StatisticEntry& rStatisticEntry,
00070 ComponentType* pMainComponent,
00071 SessionComponentCache* pMainComponentCache,
00072 SessionInfo* pSessionInfo,
00073 StatisticDictionary& rDictionary) const;
00074 };
00075
00076 }
00077
00078 #endif