00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #ifndef __freRegStepGradDescOptimizerControllerBase_h
00023 #define __freRegStepGradDescOptimizerControllerBase_h
00024
00025 #include "freSVNonLinearOptimizerControllerBase.h"
00026
00027 namespace FREE
00028 {
00029
00038 freControllerIDMacro(RegStepGradDescOptimizerControllerBase, "RegularStepGradientDescentOptimizerBase");
00039 template <class TOptimizer>
00040 class RegStepGradDescOptimizerControllerBase : public SVNonLinearOptimizerControllerBase<TOptimizer>
00041 {
00042 public:
00043 DeclareParameterMacro(RelaxationFactor);
00044
00045 itkTypeMacro(RegStepGradDescOptimizerControllerBase, SVNonLinearOptimizerControllerBase);
00046
00047 typedef TOptimizer ComponentType;
00048 typedef SVNonLinearOptimizerControllerBase<ComponentType> Superclass;
00049
00050 RegStepGradDescOptimizerControllerBase();
00051
00052 protected:
00053 virtual void GenerateProfile(CtrlProfile::ControllerProfile& profile,
00054 const SessionComponentCache* pComponentCache,
00055 bool bRegardOldSetup) const;
00056
00057 virtual void ActualizeMainComponent(ComponentType* pMainComponent,
00058 SessionComponentCache* pComponentCache,
00059 SessionInfo* pSessionInfo,
00060 const unsigned int& iActLevel) const;
00061
00062
00063 virtual void SetStatisticEntryMainComponent(StatisticEntry& rStatisticEntry,
00064 ComponentType* pMainComponent,
00065 SessionComponentCache* pMainComponentCache,
00066 SessionInfo* pSessionInfo,
00067 StatisticDictionary& rDictionary) const;
00068 };
00069
00070 }
00071
00072 #ifndef ITK_MANUAL_INSTANTIATION
00073 #include "freRegStepGradDescOptimizerControllerBase.txx"
00074 #endif
00075
00076 #endif