ITK  5.4.0
Insight Toolkit
itkVectorNeighborhoodInnerProduct.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 itkVectorNeighborhoodInnerProduct_h
19#define itkVectorNeighborhoodInnerProduct_h
20
22#include "itkVector.h"
25
26namespace itk
27{
44template <typename TImage>
45class ITK_TEMPLATE_EXPORT VectorNeighborhoodInnerProduct
46{
47public:
50
51 static constexpr unsigned int ImageDimension = TImage::ImageDimension;
52
55 using PixelType = typename TImage::PixelType;
56 using ScalarValueType = typename PixelType::ValueType;
58
61 static constexpr unsigned int VectorDimension = PixelType::Dimension;
62
65
68 operator()(const std::slice & s, const ConstNeighborhoodIterator<TImage> & it, const OperatorType & op) const;
69
73 {
74 return this->operator()(std::slice(0, it.Size(), 1), it, op);
75 }
76
77 PixelType
78 operator()(const std::slice & s, const NeighborhoodType & it, const OperatorType & op) const;
79};
80} // end namespace itk
81
82#ifndef ITK_MANUAL_INSTANTIATION
83# include "itkVectorNeighborhoodInnerProduct.hxx"
84#endif
85
86#endif
Const version of NeighborhoodIterator, defining iteration of a local N-dimensional neighborhood of pi...
NeighborIndexType Size() const
Defines the inner product operation between an itk::Neighborhood and an itk::NeighborhoodOperator.
PixelType operator()(const std::slice &s, const ConstNeighborhoodIterator< TImage > &it, const OperatorType &op) const
PixelType operator()(const ConstNeighborhoodIterator< TImage > &it, const OperatorType &op) const
PixelType operator()(const std::slice &s, const NeighborhoodType &it, const OperatorType &op) const
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....