ITK
6.0.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
* 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 itkRegularizedHeavisideStepFunction_h
19
#define itkRegularizedHeavisideStepFunction_h
20
21
#include "
itkHeavisideStepFunctionBase.h
"
22
23
namespace
itk
24
{
49
template
<
typename
TInput =
float
,
typename
TOutput =
double
>
50
class
ITK_TEMPLATE_EXPORT
RegularizedHeavisideStepFunction
:
public
HeavisideStepFunctionBase
<TInput, TOutput>
51
{
52
public
:
53
ITK_DISALLOW_COPY_AND_MOVE(
RegularizedHeavisideStepFunction
);
54
55
using
Self
=
RegularizedHeavisideStepFunction
;
56
using
Superclass
=
HeavisideStepFunctionBase<TInput, TOutput>
;
57
using
Pointer
=
SmartPointer<Self>
;
58
using
ConstPointer
=
SmartPointer<const Self>
;
59
60
using
typename
Superclass::InputType;
61
using
typename
Superclass::OutputType;
62
63
using
RealType
=
typename
NumericTraits<InputType>::RealType
;
64
65
void
66
SetEpsilon(
const
RealType
& ieps);
67
68
itkGetConstMacro(Epsilon,
RealType
);
69
itkGetConstMacro(OneOverEpsilon,
RealType
);
70
71
protected
:
72
RegularizedHeavisideStepFunction
() =
default
;
73
~
RegularizedHeavisideStepFunction
()
override
=
default
;
74
75
private
:
76
RealType
m_Epsilon{
NumericTraits<RealType>::OneValue
() };
77
RealType
m_OneOverEpsilon{
NumericTraits<RealType>::OneValue
() };
78
};
79
}
// namespace itk
80
81
#ifndef ITK_MANUAL_INSTANTIATION
82
# include "itkRegularizedHeavisideStepFunction.hxx"
83
#endif
84
85
#endif
itk::RegularizedHeavisideStepFunction
Base class of the Regularized (smoothed) Heaviside functions.
Definition:
itkRegularizedHeavisideStepFunction.h:50
itk::SmartPointer< Self >
itk::HeavisideStepFunctionBase
Base class of the Heaviside function.
Definition:
itkHeavisideStepFunctionBase.h:51
itk::NumericTraits::OneValue
static T OneValue()
Definition:
itkNumericTraits.h:158
itk::NumericTraits
Define additional traits for native types such as int or float.
Definition:
itkNumericTraits.h:60
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:
itkAnatomicalOrientation.h:29
itkHeavisideStepFunctionBase.h
itk::Object
Base class for most ITK classes.
Definition:
itkObject.h:61
itk::RegularizedHeavisideStepFunction::RealType
typename NumericTraits< InputType >::RealType RealType
Definition:
itkRegularizedHeavisideStepFunction.h:63
Generated on
unknown
for ITK by
1.8.16