ITK
5.1.0
Insight Toolkit
ITK
Modules
Core
Common
include
itkRegularizedHeavisideStepFunction.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
* 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 itkRegularizedHeavisideStepFunction_h
19
#define itkRegularizedHeavisideStepFunction_h
20
21
#include "
itkHeavisideStepFunctionBase.h
"
22
23
namespace
itk
24
{
52
template
<
typename
TInput =
float
,
typename
TOutput =
double
>
53
class
ITK_TEMPLATE_EXPORT
RegularizedHeavisideStepFunction
:
public
HeavisideStepFunctionBase
<TInput, TOutput>
54
{
55
public
:
56
ITK_DISALLOW_COPY_AND_ASSIGN(
RegularizedHeavisideStepFunction
);
57
58
using
Self
=
RegularizedHeavisideStepFunction
;
59
using
Superclass
=
HeavisideStepFunctionBase<TInput, TOutput>
;
60
using
Pointer
=
SmartPointer<Self>
;
61
using
ConstPointer
=
SmartPointer<const Self>
;
62
63
using
InputType
=
typename
Superclass::InputType;
64
using
OutputType
=
typename
Superclass::OutputType;
65
66
using
RealType
=
typename
NumericTraits<InputType>::RealType
;
67
68
void
69
SetEpsilon(
const
RealType
& ieps);
70
71
itkGetConstMacro(Epsilon,
RealType
);
72
itkGetConstMacro(OneOverEpsilon,
RealType
);
73
74
protected
:
75
RegularizedHeavisideStepFunction
();
76
~
RegularizedHeavisideStepFunction
()
override
=
default
;
77
78
private
:
79
RealType
m_Epsilon
;
80
RealType
m_OneOverEpsilon
;
81
};
82
}
// namespace itk
83
84
#ifndef ITK_MANUAL_INSTANTIATION
85
# include "itkRegularizedHeavisideStepFunction.hxx"
86
#endif
87
88
#endif
itk::RegularizedHeavisideStepFunction::InputType
typename Superclass::InputType InputType
Definition:
itkRegularizedHeavisideStepFunction.h:63
itk::RegularizedHeavisideStepFunction::m_OneOverEpsilon
RealType m_OneOverEpsilon
Definition:
itkRegularizedHeavisideStepFunction.h:80
itk::RegularizedHeavisideStepFunction
Base class of the Regularized (smoothed) Heaviside functions.
Definition:
itkRegularizedHeavisideStepFunction.h:53
itk::SmartPointer< Self >
itk::FunctionBase::OutputType
TOutput OutputType
Definition:
itkFunctionBase.h:62
itk::HeavisideStepFunctionBase
Base class of the Heaviside function.
Definition:
itkHeavisideStepFunctionBase.h:54
itk::NumericTraits
Define additional traits for native types such as int or float.
Definition:
itkNumericTraits.h:58
itk::FunctionBase
Base class for all ITK function objects.
Definition:
itkFunctionBase.h:44
itk
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
Definition:
itkArray.h:26
itkHeavisideStepFunctionBase.h
itk::Object
Base class for most ITK classes.
Definition:
itkObject.h:60
itk::RegularizedHeavisideStepFunction::m_Epsilon
RealType m_Epsilon
Definition:
itkRegularizedHeavisideStepFunction.h:79
itk::RegularizedHeavisideStepFunction::RealType
typename NumericTraits< InputType >::RealType RealType
Definition:
itkRegularizedHeavisideStepFunction.h:66
Generated on Sat Apr 25 2020 02:01:32 for ITK by
1.8.16