go home Home | Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Data Structures | File List | Namespace Members | Data Fields | Globals | Related Pages
elxCMAEvolutionStrategy.h
Go to the documentation of this file.
1 /*======================================================================
2 
3  This file is part of the elastix software.
4 
5  Copyright (c) University Medical Center Utrecht. All rights reserved.
6  See src/CopyrightElastix.txt or http://elastix.isi.uu.nl/legal.php for
7  details.
8 
9  This software is distributed WITHOUT ANY WARRANTY; without even
10  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
11  PURPOSE. See the above copyright notices for more information.
12 
13 ======================================================================*/
14 
15 #ifndef __elxCMAEvolutionStrategy_h
16 #define __elxCMAEvolutionStrategy_h
17 
19 #include "elxIncludes.h"
20 
21 namespace elastix
22 {
23 
24 
112  template <class TElastix>
114  public
116  public
117  OptimizerBase<TElastix>
118  {
119  public:
120 
125  typedef itk::SmartPointer<Self> Pointer;
126  typedef itk::SmartPointer<const Self> ConstPointer;
127 
129  itkNewMacro( Self );
130 
133 
138  elxClassNameMacro( "CMAEvolutionStrategy" );
139 
141  typedef Superclass1::CostFunctionType CostFunctionType;
142  typedef Superclass1::CostFunctionPointer CostFunctionPointer;
143  typedef Superclass1::StopConditionType StopConditionType;
144  typedef Superclass1::ParametersType ParametersType;
145  typedef Superclass1::DerivativeType DerivativeType;
146  typedef Superclass1::ScalesType ScalesType;
147 
156 
157 
160  virtual void StartOptimization(void);
161 
164  virtual void BeforeRegistration(void);
165  virtual void BeforeEachResolution(void);
166  virtual void AfterEachResolution(void);
167  virtual void AfterEachIteration(void);
168  virtual void AfterRegistration(void);
169 
170 
171  protected:
172 
174  virtual ~CMAEvolutionStrategy() {};
175 
177  virtual void InitializeProgressVariables(void);
178 
179  private:
180 
181  CMAEvolutionStrategy( const Self& ); // purposely not implemented
182  void operator=( const Self& ); // purposely not implemented
183 
184 
185  }; // end class CMAEvolutionStrategy
186 
187 
188 } // end namespace elastix
189 
190 #ifndef ITK_MANUAL_INSTANTIATION
191 #include "elxCMAEvolutionStrategy.hxx"
192 #endif
193 
194 #endif // end #ifndef __elxCMAEvolutionStrategy_h
195 
virtual void StartOptimization(void)
Superclass::RegistrationPointer RegistrationPointer
Superclass2::RegistrationPointer RegistrationPointer
Superclass2::ConfigurationPointer ConfigurationPointer
elxClassNameMacro("CMAEvolutionStrategy")
Superclass1::DerivativeType DerivativeType
Superclass2::ElastixType ElastixType
This class is the elastix base class for all Optimizers.
virtual void BeforeRegistration(void)
itk::SmartPointer< const Self > ConstPointer
void operator=(const Self &)
virtual void AfterEachIteration(void)
Superclass::ElastixType ElastixType
Superclass::ConfigurationPointer ConfigurationPointer
Superclass2::RegistrationType RegistrationType
Superclass2::ElastixPointer ElastixPointer
Superclass::ElastixPointer ElastixPointer
Superclass1::CostFunctionType CostFunctionType
Superclass::ConfigurationType ConfigurationType
virtual void AfterRegistration(void)
virtual void AfterEachResolution(void)
itk::SmartPointer< Self > Pointer
An optimizer based on the itk::CMAEvolutionStrategyOptimizer.
CMAEvolutionStrategyOptimizer Superclass1
OptimizerBase< TElastix > Superclass2
itk::Optimizer ITKBaseType
Superclass1::StopConditionType StopConditionType
Superclass2::ConfigurationType ConfigurationType
Superclass2::ITKBaseType ITKBaseType
A Covariance Matrix Adaptation Evolution Strategy Optimizer.
virtual void BeforeEachResolution(void)
virtual void InitializeProgressVariables(void)
Superclass::RegistrationType RegistrationType
Superclass1::ParametersType ParametersType
Superclass1::CostFunctionPointer CostFunctionPointer


Generated on 04-01-2014 for elastix by doxygen 1.8.5 elastix logo