go home Home | Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Data Structures | File List | Namespace Members | Data Fields | Globals | Related Pages
elxRegularStepGradientDescent.h
Go to the documentation of this file.
1/*=========================================================================
2 *
3 * Copyright UMC Utrecht and contributors
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0.txt
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 *
17 *=========================================================================*/
18#ifndef elxRegularStepGradientDescent_h
19#define elxRegularStepGradientDescent_h
20
21#include "elxIncludes.h" // include first to avoid MSVS warning
22#include "itkRegularStepGradientDescentOptimizer.h"
23
24namespace elastix
25{
26
64template <class TElastix>
65class ITK_TEMPLATE_EXPORT RegularStepGradientDescent
66 : public itk::RegularStepGradientDescentOptimizer
67 , public OptimizerBase<TElastix>
68{
69public:
71
74 using Superclass1 = RegularStepGradientDescentOptimizer;
76 using Pointer = itk::SmartPointer<Self>;
77 using ConstPointer = itk::SmartPointer<const Self>;
78
80 itkNewMacro(Self);
81
83 itkTypeMacro(RegularStepGradientDescent, RegularStepGradientDescentOptimizer);
84
89 elxClassNameMacro("RegularStepGradientDescent");
90
92 using Superclass1::CostFunctionType;
93 using Superclass1::CostFunctionPointer;
94
96 using typename Superclass2::ElastixType;
97 using typename Superclass2::RegistrationType;
99
101 using typename Superclass1::ParametersType;
102
105 void
107
108 void
110
111 void
113
114 void
116
117 void
119
124 void
125 SetInitialPosition(const ParametersType & param) override;
126
127protected:
129 ~RegularStepGradientDescent() override = default;
130
131private:
133};
134
135} // end namespace elastix
136
137#ifndef ITK_MANUAL_INSTANTIATION
138# include "elxRegularStepGradientDescent.hxx"
139#endif
140
141#endif // end #ifndef elxRegularStepGradientDescent_h
This class is the elastix base class for all Optimizers.
typename ElastixType::RegistrationBaseType RegistrationType
itk::Optimizer ITKBaseType
typename ITKBaseType::ParametersType ParametersType
An optimizer based on gradient descent...
ITK_DISALLOW_COPY_AND_MOVE(RegularStepGradientDescent)
elxClassNameMacro("RegularStepGradientDescent")
itk::SmartPointer< const Self > ConstPointer
RegularStepGradientDescentOptimizer Superclass1
~RegularStepGradientDescent() override=default
void SetInitialPosition(const ParametersType &param) override
typename Superclass2::ITKBaseType ITKBaseType


Generated on 2023-01-13 for elastix by doxygen 1.9.6 elastix logo