00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023 #ifndef __freVnlSetupOptimizationOptimizerControllerBase_txx
00024 #define __freVnlSetupOptimizationOptimizerControllerBase_txx
00025
00026 #include "freVnlSetupOptimizationOptimizerControllerBase.h"
00027
00028 namespace FREE
00029 {
00030
00034
00035
00036
00037 template <class TControlledVnlOptimizer>
00038 const char* const VnlSetupOptimizationOptimizerControllerBase<TControlledVnlOptimizer>::cParam_Minimize = "Minimize";
00039 template <class TControlledVnlOptimizer>
00040 const char* const VnlSetupOptimizationOptimizerControllerBase<TControlledVnlOptimizer>::cParamDsc_Minimize = "Indicates if regarding to the given metric scales the vnl optimizer should minimize or maximize the cost function.";
00041
00042 template <class TControlledVnlOptimizer>
00043 VnlSetupOptimizationOptimizerControllerBase<TControlledVnlOptimizer>::
00044 VnlSetupOptimizationOptimizerControllerBase()
00045 {
00046 this->UpdateControllerID(ControllerID::VnlSetupOptimizationOptimizerControllerBase);
00047 this->m_Description = "Base class for registration optimizer controller with vnl optimizer; not for practical use.";
00048 };
00049
00050 template <class TControlledVnlOptimizer>
00051 void
00052 VnlSetupOptimizationOptimizerControllerBase<TControlledVnlOptimizer>::
00053 GenerateProfile(CtrlProfile::ControllerProfile& profile,
00054 const SessionComponentCache* pComponentCache,
00055 bool bRegardOldSetup) const
00056 {
00057 Superclass::GenerateProfile(profile,pComponentCache,bRegardOldSetup);
00058
00059 profile.Parameters().AddParameter(cParam_Minimize,CtrlProfile::Parameter::PVTBool,cParamDsc_Minimize,1,"true");
00060 };
00061
00062 template <class TControlledVnlOptimizer>
00063 void
00064 VnlSetupOptimizationOptimizerControllerBase<TControlledVnlOptimizer>::
00065 ActualizeMainComponent(ComponentType* pMainComponent,
00066 SessionComponentCache* pComponentCache, SessionInfo* pSessionInfo,
00067 const unsigned int& iActLevel) const
00068 {
00069 Superclass::ActualizeMainComponent(pMainComponent, pComponentCache,
00070 pSessionInfo, iActLevel);
00071
00072 bool bMinimize;
00073
00074 try
00075 {
00076 SessionAccessor::GetParameterValue(pComponentCache,cParam_Minimize,bMinimize);
00077 }
00078 catchAllNPassMacro("Error while retrieving parameter values.");
00079
00080 pMainComponent->SetMinimize(bMinimize);
00081 };
00082
00083 template <class TControlledVnlOptimizer>
00084 typename VnlSetupOptimizationOptimizerControllerBase<TControlledVnlOptimizer>::ParametersType
00085 VnlSetupOptimizationOptimizerControllerBase<TControlledVnlOptimizer>::
00086 GetCurrentPosition(TControlledVnlOptimizer* pOptimizer) const
00087 {
00088 return pOptimizer->GetCachedCurrentPosition();
00089 };
00090
00091 template <class TControlledVnlOptimizer>
00092 typename VnlSetupOptimizationOptimizerControllerBase<TControlledVnlOptimizer>::MeasuresType
00093 VnlSetupOptimizationOptimizerControllerBase<TControlledVnlOptimizer>::
00094 GetCurrentValue(TControlledVnlOptimizer* pOptimizer) const
00095 {
00096 return pOptimizer->GetCurrentDecomposedValue();
00097 };
00098
00099 }
00100
00101 #endif