ITK  6.0.0
Insight Toolkit
itkSinRegularizedHeavisideStepFunction.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 itkSinRegularizedHeavisideStepFunction_h
19#define itkSinRegularizedHeavisideStepFunction_h
20
22
23namespace itk
24{
49template <typename TInput = float, typename TOutput = double>
50class ITK_TEMPLATE_EXPORT SinRegularizedHeavisideStepFunction : public RegularizedHeavisideStepFunction<TInput, TOutput>
51{
52public:
53 ITK_DISALLOW_COPY_AND_MOVE(SinRegularizedHeavisideStepFunction);
54
59
60 itkNewMacro(Self);
61
62 itkOverrideGetNameOfClassMacro(SinRegularizedHeavisideStepFunction);
63
64 using typename Superclass::InputType;
65 using typename Superclass::OutputType;
66 using typename Superclass::RealType;
67
70 Evaluate(const InputType & input) const override;
71
74 EvaluateDerivative(const InputType & input) const override;
75
76protected:
79};
80} // namespace itk
81
82#ifndef ITK_MANUAL_INSTANTIATION
83# include "itkSinRegularizedHeavisideStepFunction.hxx"
84#endif
85
86#endif
Light weight base class for most itk classes.
Base class of the Regularized (smoothed) Heaviside functions.
Sin-based implementation of the Regularized (smoothed) Heaviside functions.
OutputType EvaluateDerivative(const InputType &input) const override
OutputType Evaluate(const InputType &input) const override
~SinRegularizedHeavisideStepFunction() override=default
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....