go home Home | Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Data Structures | File List | Namespace Members | Data Fields | Globals | Related Pages
elxSimultaneousPerturbation.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 __elxSimultaneousPerturbation_h
16 #define __elxSimultaneousPerturbation_h
17 
18 #include "itkSPSAOptimizer.h"
19 #include "elxIncludes.h"
20 
21 namespace elastix
22 {
23 
79  template <class TElastix>
81  public
82  itk::SPSAOptimizer,
83  public
84  OptimizerBase<TElastix>
85  {
86  public:
87 
90  typedef SPSAOptimizer Superclass1;
92  typedef itk::SmartPointer<Self> Pointer;
93  typedef itk::SmartPointer<const Self> ConstPointer;
94 
96  itkNewMacro( Self );
97 
99  itkTypeMacro( SimultaneousPerturbation, SPSAOptimizer );
100 
105  elxClassNameMacro( "SimultaneousPerturbation" );
106 
108  typedef Superclass1::CostFunctionType CostFunctionType;
109  typedef Superclass1::CostFunctionPointer CostFunctionPointer;
110  typedef Superclass1::StopConditionType StopConditionType;
111 
120 
122  typedef typename Superclass1::ParametersType ParametersType;
123 
125  virtual void BeforeRegistration(void);
126  virtual void BeforeEachResolution(void);
127  virtual void AfterEachResolution(void);
128  virtual void AfterEachIteration(void);
129  virtual void AfterRegistration(void);
130 
135  virtual void SetInitialPosition( const ParametersType & param );
136 
137  protected:
138 
141 
142  bool m_ShowMetricValues;
143 
144  private:
145 
146  SimultaneousPerturbation( const Self& ); // purposely not implemented
147  void operator=( const Self& ); // purposely not implemented
148 
149  }; // end class SimultaneousPerturbation
150 
151 
152 } // end namespace elastix
153 
154 #ifndef ITK_MANUAL_INSTANTIATION
155 #include "elxSimultaneousPerturbation.hxx"
156 #endif
157 
158 #endif // end #ifndef __elxSimultaneousPerturbation_h
Superclass1::CostFunctionType CostFunctionType
Superclass::RegistrationPointer RegistrationPointer
virtual void AfterRegistration(void)
This class is the elastix base class for all Optimizers.
virtual void SetInitialPosition(const ParametersType &param)
virtual void AfterEachResolution(void)
Superclass::ElastixType ElastixType
Superclass::ConfigurationPointer ConfigurationPointer
elxClassNameMacro("SimultaneousPerturbation")
Superclass::ElastixPointer ElastixPointer
Superclass1::StopConditionType StopConditionType
Superclass::ConfigurationType ConfigurationType
Superclass2::RegistrationType RegistrationType
Superclass1::CostFunctionPointer CostFunctionPointer
itk::Optimizer ITKBaseType
Superclass2::RegistrationPointer RegistrationPointer
virtual void BeforeEachResolution(void)
itk::SmartPointer< const Self > ConstPointer
Superclass2::ConfigurationType ConfigurationType
virtual void AfterEachIteration(void)
virtual void BeforeRegistration(void)
Superclass::RegistrationType RegistrationType
Superclass2::ConfigurationPointer ConfigurationPointer
An optimizer based on the itk::SPSAOptimizer.


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