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: freLevenbergMarquardtOptimizerController.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 __freLevenbergMarquardtOptimizerController_h 00023 #define __freLevenbergMarquardtOptimizerController_h 00024 00025 #include "freMVNonLinearVNLOptimizerControllerBase.h" 00026 00027 #include "itkLevenbergMarquardtOptimizer.h" 00028 00029 namespace FREE 00030 { 00031 00041 freControllerIDMacro(LevenbergMarquardtOptimizerController, "Levenberg Marquardt Optimizer"); 00042 class LevenbergMarquardtOptimizerController : public MVNonLinearVNLOptimizerControllerBase<itk::LevenbergMarquardtOptimizer> 00043 { 00044 public: 00045 itkTypeMacro(LevenbergMarquardtOptimizerController, MVNonLinearVNLOptimizerControllerBase); 00046 00047 typedef itk::LevenbergMarquardtOptimizer ComponentType; 00048 typedef MVNonLinearVNLOptimizerControllerBase<ComponentType> Superclass; 00049 00050 LevenbergMarquardtOptimizerController(); 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 } //end of namespace free 00064 00065 #endif
1.5.3 written by Dimitri van Heesch,
© 1997-2000