ITK
6.0.0
Insight Toolkit
ITK
Modules
Filtering
GPUAnisotropicSmoothing
include
itkGPUGradientAnisotropicDiffusionImageFilter.h
Go to the documentation of this file.
1
/*=========================================================================
2
*
3
* Copyright NumFOCUS
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
* https://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 itkGPUGradientAnisotropicDiffusionImageFilter_h
19
#define itkGPUGradientAnisotropicDiffusionImageFilter_h
20
21
#include "
itkOpenCLUtil.h
"
22
#include "
itkGradientAnisotropicDiffusionImageFilter.h
"
23
#include "
itkGPUAnisotropicDiffusionImageFilter.h
"
24
#include "
itkGPUGradientNDAnisotropicDiffusionFunction.h
"
25
26
namespace
itk
27
{
46
template
<
typename
TInputImage,
47
typename
TOutputImage,
48
typename
TParentImageFilter = GradientAnisotropicDiffusionImageFilter<TInputImage, TOutputImage>>
49
class
GPUGradientAnisotropicDiffusionImageFilter
50
:
public
GPUAnisotropicDiffusionImageFilter
<TInputImage, TOutputImage, TParentImageFilter>
51
{
52
public
:
53
ITK_DISALLOW_COPY_AND_MOVE(
GPUGradientAnisotropicDiffusionImageFilter
);
54
56
using
Self
=
GPUGradientAnisotropicDiffusionImageFilter
;
57
using
Superclass
=
GPUAnisotropicDiffusionImageFilter<TInputImage, TOutputImage, TParentImageFilter>
;
58
using
GPUSuperclass
=
GPUAnisotropicDiffusionImageFilter<TInputImage, TOutputImage, TParentImageFilter>
;
59
using
Pointer
=
SmartPointer<Self>
;
60
using
ConstPointer
=
SmartPointer<const Self>
;
61
63
itkNewMacro(
Self
);
64
66
itkOverrideGetNameOfClassMacro(
GPUGradientAnisotropicDiffusionImageFilter
);
67
69
using
UpdateBufferType
=
typename
GPUSuperclass::UpdateBufferType
;
70
72
static
constexpr
unsigned
int
ImageDimension
=
GPUSuperclass::ImageDimension
;
73
74
#ifdef ITK_USE_CONCEPT_CHECKING
75
// Begin concept checking
76
itkConceptMacro
(UpdateBufferHasNumericTraitsCheck, (
Concept::HasNumericTraits<typename UpdateBufferType::PixelType>
));
77
// End concept checking
78
#endif
79
80
protected
:
81
GPUGradientAnisotropicDiffusionImageFilter
()
82
{
83
// Set DiffusionFunction
84
auto
p =
GPUGradientNDAnisotropicDiffusionFunction<UpdateBufferType>::New
();
85
this->
SetDifferenceFunction
(p);
86
}
87
88
~GPUGradientAnisotropicDiffusionImageFilter
()
override
=
default
;
89
};
90
91
}
// namespace itk
92
93
#endif
itk::GPUAnisotropicDiffusionImageFilter::UpdateBufferType
typename GPUSuperclass::UpdateBufferType UpdateBufferType
Definition:
itkGPUAnisotropicDiffusionImageFilter.h:56
itk::Concept::HasNumericTraits
Definition:
itkConceptChecking.h:716
itkGradientAnisotropicDiffusionImageFilter.h
itk::GPUAnisotropicDiffusionImageFilter
Definition:
itkGPUAnisotropicDiffusionImageFilter.h:37
itk::SmartPointer< Self >
itkOpenCLUtil.h
itk::GPUDenseFiniteDifferenceImageFilter::UpdateBufferType
OutputImageType UpdateBufferType
Definition:
itkGPUDenseFiniteDifferenceImageFilter.h:88
itk::GPUGradientNDAnisotropicDiffusionFunction::New
static Pointer New()
itk::GPUAnisotropicDiffusionImageFilter::ImageDimension
static constexpr unsigned int ImageDimension
Definition:
itkGPUAnisotropicDiffusionImageFilter.h:60
itk::GPUImageToImageFilter
class to abstract the behaviour of the GPU filters.
Definition:
itkGPUImageToImageFilter.h:41
itk::GPUGradientAnisotropicDiffusionImageFilter::~GPUGradientAnisotropicDiffusionImageFilter
~GPUGradientAnisotropicDiffusionImageFilter() override=default
itk::GPUImageToImageFilter::Superclass
TParentImageFilter Superclass
Definition:
itkGPUImageToImageFilter.h:48
itk::GPUGradientAnisotropicDiffusionImageFilter
Definition:
itkGPUGradientAnisotropicDiffusionImageFilter.h:49
itkConceptMacro
#define itkConceptMacro(name, concept)
Definition:
itkConceptChecking.h:65
itkGPUAnisotropicDiffusionImageFilter.h
itk
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
Definition:
itkAnatomicalOrientation.h:29
itk::GPUGradientAnisotropicDiffusionImageFilter::ImageDimension
static constexpr unsigned int ImageDimension
Definition:
itkGPUGradientAnisotropicDiffusionImageFilter.h:72
itk::GPUFiniteDifferenceImageFilter::SetDifferenceFunction
void SetDifferenceFunction(FiniteDifferenceFunctionType *differenceFunction) override
Definition:
itkGPUFiniteDifferenceImageFilter.h:93
itk::GPUGradientAnisotropicDiffusionImageFilter::GPUGradientAnisotropicDiffusionImageFilter
GPUGradientAnisotropicDiffusionImageFilter()
Definition:
itkGPUGradientAnisotropicDiffusionImageFilter.h:81
itkGPUGradientNDAnisotropicDiffusionFunction.h
Generated on
unknown
for ITK by
1.8.16