freRegStepGradDescOptimizerControllerBase.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: freRegStepGradDescOptimizerControllerBase.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 __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 } //end of namespace free
00071 
00072 #ifndef ITK_MANUAL_INSTANTIATION
00073 #include "freRegStepGradDescOptimizerControllerBase.txx"
00074 #endif
00075 
00076 #endif

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