ITK
5.2.0
Insight Toolkit
ITK
Modules
Core
Common
include
itkEllipsoidInteriorExteriorSpatialFunction.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 itkEllipsoidInteriorExteriorSpatialFunction_h
19
#define itkEllipsoidInteriorExteriorSpatialFunction_h
20
21
#include "
itkInteriorExteriorSpatialFunction.h
"
22
#include "vnl/vnl_matrix_fixed.h"
23
24
namespace
itk
25
{
38
template
<
unsigned
int
VDimension = 3,
typename
TInput = Po
int
<
double
, VDimension>>
39
class
ITK_TEMPLATE_EXPORT
EllipsoidInteriorExteriorSpatialFunction
40
:
public
InteriorExteriorSpatialFunction
<VDimension, TInput>
41
{
42
public
:
43
ITK_DISALLOW_COPY_AND_MOVE(
EllipsoidInteriorExteriorSpatialFunction
);
44
46
using
Self
=
EllipsoidInteriorExteriorSpatialFunction
;
47
using
Superclass
=
InteriorExteriorSpatialFunction<VDimension, TInput>
;
48
using
Pointer
=
SmartPointer<Self>
;
49
using
ConstPointer
=
SmartPointer<const Self>
;
50
52
itkTypeMacro(
EllipsoidInteriorExteriorSpatialFunction
,
InteriorExteriorSpatialFunction
);
53
55
itkNewMacro(
Self
);
56
58
using
InputType
=
typename
Superclass::InputType
;
59
61
using
OutputType
=
typename
Superclass::OutputType
;
62
64
using
OrientationType
= vnl_matrix_fixed<double, VDimension, VDimension>;
65
67
itkGetConstMacro(Center,
InputType
);
68
itkSetMacro(Center,
InputType
);
70
72
itkGetConstMacro(Axes,
InputType
);
73
itkSetMacro(Axes,
InputType
);
75
78
void
79
SetOrientations(
const
OrientationType
&);
80
82
OutputType
83
Evaluate(
const
InputType
& position)
const override
;
84
85
protected
:
86
EllipsoidInteriorExteriorSpatialFunction
();
87
~
EllipsoidInteriorExteriorSpatialFunction
()
override
;
88
89
void
90
PrintSelf(std::ostream & os,
Indent
indent)
const override
;
91
92
private
:
94
InputType
m_Center
;
95
97
InputType
m_Axes
;
98
100
double
**
m_Orientations
;
101
};
102
}
// end namespace itk
103
104
#ifndef ITK_MANUAL_INSTANTIATION
105
# include "itkEllipsoidInteriorExteriorSpatialFunction.hxx"
106
#endif
107
108
#endif
itk::EllipsoidInteriorExteriorSpatialFunction::m_Axes
InputType m_Axes
Definition:
itkEllipsoidInteriorExteriorSpatialFunction.h:97
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::EllipsoidInteriorExteriorSpatialFunction::OutputType
typename Superclass::OutputType OutputType
Definition:
itkEllipsoidInteriorExteriorSpatialFunction.h:61
itk::InteriorExteriorSpatialFunction::InputType
typename Superclass::InputType InputType
Definition:
itkInteriorExteriorSpatialFunction.h:64
itk::EllipsoidInteriorExteriorSpatialFunction::OrientationType
vnl_matrix_fixed< double, VDimension, VDimension > OrientationType
Definition:
itkEllipsoidInteriorExteriorSpatialFunction.h:64
itk::EllipsoidInteriorExteriorSpatialFunction::m_Orientations
double ** m_Orientations
Definition:
itkEllipsoidInteriorExteriorSpatialFunction.h:100
itk::EllipsoidInteriorExteriorSpatialFunction
Function implementation of an ellipsoid.
Definition:
itkEllipsoidInteriorExteriorSpatialFunction.h:39
itk::InteriorExteriorSpatialFunction::OutputType
typename Superclass::OutputType OutputType
Definition:
itkInteriorExteriorSpatialFunction.h:67
itk
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
Definition:
itkAnnulusOperator.h:24
itkInteriorExteriorSpatialFunction.h
itk::EllipsoidInteriorExteriorSpatialFunction::m_Center
InputType m_Center
Definition:
itkEllipsoidInteriorExteriorSpatialFunction.h:94
itk::EllipsoidInteriorExteriorSpatialFunction::InputType
typename Superclass::InputType InputType
Definition:
itkEllipsoidInteriorExteriorSpatialFunction.h:58
Generated on Thu Apr 1 2021 01:41:47 for ITK by
1.8.16