ITK
5.2.0
Insight Toolkit
ITK
Modules
Core
Common
include
itkSphereSpatialFunction.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 itkSphereSpatialFunction_h
19
#define itkSphereSpatialFunction_h
20
21
#include "
itkInteriorExteriorSpatialFunction.h
"
22
23
namespace
itk
24
{
34
template
<
unsigned
int
VImageDimension = 3,
typename
TInput = Po
int
<
double
, VImageDimension>>
35
class
ITK_TEMPLATE_EXPORT
SphereSpatialFunction
:
public
InteriorExteriorSpatialFunction
<VImageDimension, TInput>
36
{
37
public
:
38
ITK_DISALLOW_COPY_AND_MOVE(
SphereSpatialFunction
);
39
41
using
Self
=
SphereSpatialFunction<VImageDimension, TInput>
;
42
using
Superclass
=
InteriorExteriorSpatialFunction<VImageDimension, TInput>
;
43
using
Pointer
=
SmartPointer<Self>
;
44
using
ConstPointer
=
SmartPointer<const Self>
;
45
47
itkNewMacro(
Self
);
48
50
itkTypeMacro(
SphereSpatialFunction
,
InteriorExteriorSpatialFunction
);
51
53
using
InputType
=
typename
Superclass::InputType;
54
56
using
OutputType
=
typename
Superclass::OutputType;
57
59
OutputType
60
Evaluate(
const
InputType
& position)
const override
;
61
63
itkGetConstMacro(Center,
InputType
);
64
itkSetMacro(Center,
InputType
);
66
68
itkGetConstMacro(Radius,
double
);
69
itkSetMacro(Radius,
double
);
71
72
protected
:
73
SphereSpatialFunction
();
74
~
SphereSpatialFunction
()
override
=
default
;
75
void
76
PrintSelf(std::ostream & os,
Indent
indent)
const override
;
77
78
private
:
80
InputType
m_Center
;
81
83
double
m_Radius
;
84
};
85
}
// end namespace itk
86
87
#ifndef ITK_MANUAL_INSTANTIATION
88
# include "itkSphereSpatialFunction.hxx"
89
#endif
90
91
#endif
itk::SphereSpatialFunction::m_Radius
double m_Radius
Definition:
itkSphereSpatialFunction.h:83
itk::InteriorExteriorSpatialFunction
Returns whether or not a location is "inside" or "outside" a function.
Definition:
itkInteriorExteriorSpatialFunction.h:49
itk::SmartPointer< Self >
itk::Indent
Control indentation during Print() invocation.
Definition:
itkIndent.h:49
itk::SphereSpatialFunction
Spatial function implementation of a sphere.
Definition:
itkSphereSpatialFunction.h:35
itk::LightObject
Light weight base class for most itk classes.
Definition:
itkLightObject.h:59
itk::SphereSpatialFunction::m_Center
InputType m_Center
Definition:
itkSphereSpatialFunction.h:80
itk::SphereSpatialFunction::InputType
typename Superclass::InputType InputType
Definition:
itkSphereSpatialFunction.h:53
itk::SphereSpatialFunction::OutputType
typename Superclass::OutputType OutputType
Definition:
itkSphereSpatialFunction.h:56
itk
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
Definition:
itkAnnulusOperator.h:24
itkInteriorExteriorSpatialFunction.h
Generated on Thu Apr 1 2021 02:05:06 for ITK by
1.8.16