ITK
4.4.0
Insight Segmentation and Registration Toolkit
Main Page
Related Pages
Modules
Namespaces
Classes
Files
Examples
File List
File Members
ITK
Modules
Numerics
Statistics
include
itkDistanceToCentroidMembershipFunction.h
Go to the documentation of this file.
1
/*=========================================================================
2
*
3
* Copyright Insight Software Consortium
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 __itkDistanceToCentroidMembershipFunction_h
19
#define __itkDistanceToCentroidMembershipFunction_h
20
21
#include "
itkMembershipFunctionBase.h
"
22
#include "
itkDistanceMetric.h
"
23
24
namespace
itk
25
{
26
namespace
Statistics
27
{
44
template
<
class
TVector >
45
class
ITK_EXPORT
DistanceToCentroidMembershipFunction
:
46
public
MembershipFunctionBase
< TVector >
47
{
48
public
:
50
typedef
DistanceToCentroidMembershipFunction
Self
;
51
typedef
MembershipFunctionBase< TVector >
Superclass
;
52
typedef
SmartPointer< Self >
Pointer
;
53
typedef
SmartPointer< const Self >
ConstPointer
;
54
56
itkTypeMacro(
DistanceToCentroidMembershipFunction
,
57
MembershipFunctionBase
);
58
itkNewMacro(
Self
);
60
62
typedef
typename
Superclass::Pointer
MembershipFunctionPointer
;
63
65
typedef
TVector
MeasurementVectorType
;
66
68
typedef
typename
Superclass::MeasurementVectorSizeType
69
MeasurementVectorSizeType
;
70
72
virtual
void
SetMeasurementVectorSize(
MeasurementVectorSizeType
);
73
75
typedef
DistanceMetric< MeasurementVectorType >
DistanceMetricType
;
76
typedef
typename
DistanceMetricType::Pointer
DistanceMetricPointer
;
77
typedef
typename
DistanceMetricType::OriginType
CentroidType
;
78
80
itkSetObjectMacro(
DistanceMetric
,
DistanceMetricType
);
81
83
itkGetModifiableObjectMacro(
DistanceMetric
,
DistanceMetricType
);
84
90
void
SetCentroid(
const
CentroidType
& centroid);
91
93
const
CentroidType
& GetCentroid()
const
;
94
98
double
Evaluate(
const
MeasurementVectorType
& measurement)
const
;
99
100
protected
:
101
DistanceToCentroidMembershipFunction
(
void
);
102
virtual
~DistanceToCentroidMembershipFunction
(
void
) {}
103
void
PrintSelf(std::ostream & os,
Indent
indent)
const
;
104
106
virtual
typename
LightObject::Pointer
InternalClone()
const
;
107
108
private
:
109
DistanceToCentroidMembershipFunction
(
const
Self &);
//purposely not implemented
110
void
operator=(
const
Self &);
//purposely not implemented
111
112
DistanceMetricPointer
m_DistanceMetric
;
113
};
114
}
// end of namespace Statistics
115
}
// end namespace itk
116
117
#ifndef ITK_MANUAL_INSTANTIATION
118
#include "itkDistanceToCentroidMembershipFunction.hxx"
119
#endif
120
121
#endif
122
Generated on Mon May 13 2013 00:48:40 for ITK by
1.8.3.1