freMVNonLinearVNLOptimizerControllerBase.h

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: freMVNonLinearVNLOptimizerControllerBase.h,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 #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 } //end of namespace FREE
00082 
00083 #ifndef ITK_MANUAL_INSTANTIATION
00084 #include "freMVNonLinearVNLOptimizerControllerBase.txx"
00085 #endif
00086 
00087 #endif

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