go home Home | Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Data Structures | File List | Namespace Members | Data Fields | Globals | Related Pages
itkGPUIdentityTransform.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 itkGPUIdentityTransform_h
19#define itkGPUIdentityTransform_h
20
21#include "itkIdentityTransform.h"
22#include "itkVersion.h"
23
24#include "itkGPUTransformBase.h"
25
26namespace itk
27{
29itkGPUKernelClassMacro(GPUIdentityTransformKernel);
30
42template <typename TScalarType = float,
43 unsigned int NDimensions = 3,
44 typename TParentTransform = IdentityTransform<TScalarType, NDimensions>>
45class ITK_EXPORT GPUIdentityTransform
46 : public TParentTransform
47 , public GPUTransformBase
48{
49public:
52 using CPUSuperclass = TParentTransform;
54 using Pointer = SmartPointer<Self>;
55 using ConstPointer = SmartPointer<const Self>;
56
58 itkNewMacro(Self);
59
61 itkTypeMacro(GPUIdentityTransform, TParentTransform);
62
65 bool
66 IsIdentityTransform() const override
67 {
68 return true;
69 }
70
71protected:
73 ~GPUIdentityTransform() override = default;
74 void
75 PrintSelf(std::ostream & os, Indent indent) const override;
76
79 bool
80 GetSourceCode(std::string & source) const override;
81
82private:
83 GPUIdentityTransform(const Self & other) = delete;
84 const Self &
85 operator=(const Self &) = delete;
86
87 std::vector<std::string> m_Sources{};
88};
89
90} // end namespace itk
91
92#ifndef ITK_MANUAL_INSTANTIATION
93# include "itkGPUIdentityTransform.hxx"
94#endif
95
96#endif /* itkGPUIdentityTransform_h */
GPU version of IdentityTransform.
void PrintSelf(std::ostream &os, Indent indent) const override
~GPUIdentityTransform() override=default
const Self & operator=(const Self &)=delete
bool IsIdentityTransform() const override
GPUIdentityTransform(const Self &other)=delete
SmartPointer< const Self > ConstPointer
bool GetSourceCode(std::string &source) const override
Base class for all GPU transforms.
itkGPUKernelClassMacro(GPUBSplineTransformKernel)


Generated on 2024-07-17 for elastix by doxygen 1.11.0 (9b424b03c9833626cd435af22a444888fbbb192d) elastix logo