freVnlSetupOptimizationOptimizerControllerBase.txx

Go to the documentation of this file.
00001 /*=========================================================================
00002 
00003   Program:   F.R.E.E. - flexible registration evaluation engine
00004   Version:   v.1.0.0
00005   Date:      $Date: 2006/09/01 12:00:00 $
00006   Module:    $RCSfile: freVnlSetupOptimizationOptimizerControllerBase.cxx,v $
00007   Language:  C++
00008 
00009 
00010 
00011   Copyright (c) 2007 Ralf o Floca (Department of Medical Informatics,
00012   Institute for Medical Biometry and Informatics, University of Heidelberg,
00013   Germany). All rights reserved.
00014   See FREECopyright.txt or http://www.mi.med.uni-hd.de/free/copyright.htm
00015   for details.
00016 
00017      This software is distributed WITHOUT ANY WARRANTY; without even 
00018      the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 
00019      PURPOSE.  See the above copyright notices for more information.
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 } //end of namespace FREE
00100 
00101 #endif

Generated at Sat Oct 13 18:02:21 2007 for f.r.e.e. - Flexible Registration and Evaluation Engine by doxygen 1.5.3 written by Dimitri van Heesch, © 1997-2000