ITK
6.0.0
Insight Toolkit
ITK
Modules
Filtering
MathematicalMorphology
include
itkVanHerkGilWermanErodeImageFilter.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 itkVanHerkGilWermanErodeImageFilter_h
19
#define itkVanHerkGilWermanErodeImageFilter_h
20
21
// Intentionally include the Dilate filter to get the base class to avoid issues
22
// with itkFlatStructuringElement.hxx
23
#include "
itkVanHerkGilWermanDilateImageFilter.h
"
24
25
namespace
itk
26
{
27
template
<
typename
TPixel>
28
class
MinFunctor
29
{
30
public
:
31
inline
TPixel
32
operator()
(
const
TPixel & A,
const
TPixel & B)
const
33
{
34
return
std::min(A, B);
35
}
36
};
37
38
template
<
typename
TImage,
typename
TKernel>
39
class
VanHerkGilWermanErodeImageFilter
40
:
public
VanHerkGilWermanErodeDilateImageFilter
<TImage, TKernel, MinFunctor<typename TImage::PixelType>>
41
42
{
43
public
:
44
ITK_DISALLOW_COPY_AND_MOVE(
VanHerkGilWermanErodeImageFilter
);
45
46
using
Self
=
VanHerkGilWermanErodeImageFilter
;
47
using
Superclass
=
VanHerkGilWermanErodeDilateImageFilter<TImage, TKernel, MinFunctor<typename TImage::PixelType>
>;
48
50
itkOverrideGetNameOfClassMacro(
VanHerkGilWermanErodeImageFilter
);
51
52
using
Pointer
=
SmartPointer<Self>
;
53
using
ConstPointer
=
SmartPointer<const Self>
;
54
using
PixelType
=
typename
TImage::PixelType;
55
57
itkNewMacro(
Self
);
58
59
protected
:
60
VanHerkGilWermanErodeImageFilter
() { this->
m_Boundary
=
NumericTraits<PixelType>::max
(); }
61
~VanHerkGilWermanErodeImageFilter
()
override
=
default
;
62
63
private
:
64
};
65
}
// namespace itk
66
67
#endif
itkVanHerkGilWermanDilateImageFilter.h
itk::MinFunctor
Definition:
itkVanHerkGilWermanErodeImageFilter.h:28
itk::VanHerkGilWermanErodeImageFilter::PixelType
typename TImage::PixelType PixelType
Definition:
itkVanHerkGilWermanErodeImageFilter.h:54
itk::SmartPointer< Self >
itk::VanHerkGilWermanErodeImageFilter
Definition:
itkVanHerkGilWermanErodeImageFilter.h:39
itk::ImageSource
Base class for all process objects that output image data.
Definition:
itkImageSource.h:67
itk::NumericTraits::max
static constexpr T max(const T &)
Definition:
itkNumericTraits.h:169
itk
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
Definition:
itkAnatomicalOrientation.h:29
itk::ProcessObject
The base class for all process objects (source, filters, mappers) in the Insight data processing pipe...
Definition:
itkProcessObject.h:139
itk::VanHerkGilWermanErodeImageFilter::VanHerkGilWermanErodeImageFilter
VanHerkGilWermanErodeImageFilter()
Definition:
itkVanHerkGilWermanErodeImageFilter.h:60
itk::VanHerkGilWermanErodeDilateImageFilter< TImage, TKernel, MinFunctor< TImage::PixelType > >::m_Boundary
InputImagePixelType m_Boundary
Definition:
itkVanHerkGilWermanErodeDilateImageFilter.h:93
itk::VanHerkGilWermanErodeDilateImageFilter
class to implement erosions and dilations using anchor methods. This is the base class that must be i...
Definition:
itkVanHerkGilWermanErodeDilateImageFilter.h:42
itk::MinFunctor::operator()
TPixel operator()(const TPixel &A, const TPixel &B) const
Definition:
itkVanHerkGilWermanErodeImageFilter.h:32
itk::VanHerkGilWermanErodeImageFilter::~VanHerkGilWermanErodeImageFilter
~VanHerkGilWermanErodeImageFilter() override=default
Generated on
unknown
for ITK by
1.8.16