SimpleITK  
sitkNaryAddImageFilter.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 sitkNaryAddImageFilter_h
19 #define sitkNaryAddImageFilter_h
20 
21 /*
22  * WARNING: DO NOT EDIT THIS FILE!
23  * THIS FILE IS AUTOMATICALLY GENERATED BY THE SIMPLEITK BUILD PROCESS.
24  * Please look at sitkMultiInputImageFilterTemplate.h.in to make changes.
25  */
26 
27 #include <memory>
28 
29 #include "sitkBasicFilters.h"
30 #include "sitkImageFilter.h"
31 
32 namespace itk::simple {
33 
65  : public ImageFilter
66  {
67  public:
69 
71  virtual ~NaryAddImageFilter();
72 
73 
77 
79  using PixelIDTypeList = typelist2::append<BasicPixelIDTypeList, ComplexPixelIDTypeList>::type;
80 
81 
82 
83 
85  std::string GetName() const { return std::string ("NaryAddImageFilter"); }
86 
88  std::string ToString() const;
89 
91  Image Execute ( const std::vector<Image> &images);
92  Image Execute ( const Image& image1 );
93  Image Execute ( const Image& image1, const Image& image2 );
94  Image Execute ( const Image& image1, const Image& image2, const Image& image3 );
95  Image Execute ( const Image& image1, const Image& image2, const Image& image3, const Image& image4 );
96  Image Execute ( const Image& image1, const Image& image2, const Image& image3, const Image& image4, const Image& image5 );
97 
98 
99 
100 
101  private:
102 
105  using MemberFunctionType = Image (Self::*)( const std::vector<Image> & );
106  template <class TImageType> Image ExecuteInternal ( const std::vector<Image> &images );
107 
108 
109 
111 
112  std::unique_ptr<detail::MemberFunctionFactory<MemberFunctionType> > m_MemberFactory;
113 
114 
115 
116  bool m_InPlace{false};
117  };
118 
119 
129  SITKBasicFilters_EXPORT Image NaryAdd ( const std::vector<Image> &images );
130 
131  SITKBasicFilters_EXPORT Image NaryAdd ( const Image& image1 );
132  SITKBasicFilters_EXPORT Image NaryAdd ( const Image& image1, const Image& image2 );
133  SITKBasicFilters_EXPORT Image NaryAdd ( const Image& image1, const Image& image2, const Image& image3 );
134  SITKBasicFilters_EXPORT Image NaryAdd ( const Image& image1, const Image& image2, const Image& image3, const Image& image4 );
135  SITKBasicFilters_EXPORT Image NaryAdd ( const Image& image1, const Image& image2, const Image& image3, const Image& image4, const Image& image5 );
136 
139 }
140 #endif
itk::simple::Image
The Image class for SimpleITK.
Definition: sitkImage.h:76
itk::simple::NaryAddImageFilter::m_MemberFactory
std::unique_ptr< detail::MemberFunctionFactory< MemberFunctionType > > m_MemberFactory
Definition: sitkNaryAddImageFilter.h:112
sitkBasicFilters.h
itk::simple::detail::MemberFunctionAddressor
Definition: sitkDetail.h:29
sitkImageFilter.h
itk::simple::NaryAddImageFilter::PixelIDTypeList
typelist2::append< BasicPixelIDTypeList, ComplexPixelIDTypeList >::type PixelIDTypeList
Definition: sitkNaryAddImageFilter.h:79
SITKBasicFilters_EXPORT
#define SITKBasicFilters_EXPORT
Definition: sitkBasicFilters.h:52
itk::simple::NaryAddImageFilter::GetName
std::string GetName() const
Definition: sitkNaryAddImageFilter.h:85
itk::simple::NaryAddImageFilter
Pixel-wise addition of N images.
Definition: sitkNaryAddImageFilter.h:64
itk::simple::ImageFilter
The base interface for SimpleITK filters that take one input image.
Definition: sitkImageFilter.h:35
itk::Image
Definition: sitkPixelIDTypes.h:28
itk::simple
Definition: sitkAdditionalProcedures.h:28
itk::images
*par Constraints *The filter requires an image with at least two dimensions and a vector *length of at least The theory supports extension to scalar images
itk::simple::NaryAddImageFilter::MemberFunctionType
Image(Self::*)(const std::vector< Image > &) MemberFunctionType
Definition: sitkNaryAddImageFilter.h:105
itk::simple::NaryAdd
Image NaryAdd(const std::vector< Image > &images)
Pixel-wise addition of N images.