00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #ifndef __freMVNonLinearVNLOptimizerControllerBase_h
00023 #define __freMVNonLinearVNLOptimizerControllerBase_h
00024
00025 #include "freMVNonLinearOptimizerControllerBase.h"
00026
00027 namespace FREE
00028 {
00029
00040 freControllerIDMacro(MVNonLinearVNLOptimizerControllerBase, "MVNonLinearVNLOptimizerBase");
00041 template <class TControlledVNLOptimizer>
00042 class MVNonLinearVNLOptimizerControllerBase : public MVNonLinearOptimizerControllerBase<TControlledVNLOptimizer>
00043 {
00044 public:
00045 itkTypeMacro(MVNonLinearVNLOptimizerControllerBase, MVNonLinearOptimizerControllerBase);
00046
00047 DeclareParameterMacro(UseCostFunctionGradient);
00048
00049 typedef MVNonLinearOptimizerControllerBase<TControlledVNLOptimizer> Superclass;
00050 typedef typename Superclass::ComponentType ComponentType;
00051 typedef MVNonLinearOptimizerControllerBase<TControlledVNLOptimizer> Self;
00052 typedef typename Superclass::GenericComponentType GenericComponentType;
00053 typedef typename Superclass::GenericComponentPointer GenericComponentPointer;
00054 typedef typename Superclass::GenericMediaPointer GenericMediaPointer;
00055 typedef typename Superclass::MeasuresType MeasuresType;
00056 typedef typename Superclass::ParametersType ParametersType;
00057
00058 virtual ParametersType GetCurrentPosition(TControlledVNLOptimizer* pOptimizer) const;
00059 virtual MeasuresType GetCurrentValue(TControlledVNLOptimizer* pOptimizer) const;
00060
00061 MVNonLinearVNLOptimizerControllerBase();
00062
00063 protected:
00064 virtual void GenerateProfile(CtrlProfile::ControllerProfile& profile,
00065 const SessionComponentCache* pComponentCache,
00066 bool bRegardOldSetup) const;
00067
00068 virtual void SetStatisticEntryMainComponent(StatisticEntry& rStatisticEntry,
00069 ComponentType* pMainComponent,
00070 SessionComponentCache* pMainComponentCache,
00071 SessionInfo* pSessionInfo,
00072 StatisticDictionary& rDictionary) const;
00073
00074 virtual void ActualizeMainComponent(ComponentType* pMainComponent,
00075 SessionComponentCache* pComponentCache,
00076 SessionInfo* pSessionInfo,
00077 const unsigned int& iActLevel) const;
00078
00079 };
00080
00081 }
00082
00083 #ifndef ITK_MANUAL_INSTANTIATION
00084 #include "freMVNonLinearVNLOptimizerControllerBase.txx"
00085 #endif
00086
00087 #endif