/usr/include/InsightToolkit/Review/itkFlatStructuringElement.h is in libinsighttoolkit3-dev 3.20.1+git20120521-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 | /*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: itkFlatStructuringElement.h
Language: C++
Date: $Date$
Version: $Revision$
Copyright (c) Insight Software Consortium. All rights reserved.
See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
=========================================================================*/
#ifndef __itkFlatStructuringElement_h
#define __itkFlatStructuringElement_h
#include "itkNeighborhood.h"
#include "itkSize.h"
#include "itkOffset.h"
#include <vector>
#include "itkVector.h"
namespace itk {
/** \class FlatStructuringElement
* \brief A class to support a variety of flat structuring elements,
* including versions created by decomposition of lines.
*
* FlatStructuringElement provides several static methods, which can
* be used to create a structuring element with a particular shape,
* size, etc. Currently, those methods allow to create a ball, a box,
* a cross structuring element, and let create a structuring element
* based on an image.
*
*/
template<unsigned int VDimension>
class ITK_EXPORT FlatStructuringElement : public Neighborhood <bool, VDimension>
{
public:
/** Standard class typedefs. */
typedef FlatStructuringElement< VDimension> Self;
typedef Neighborhood<bool, VDimension> Superclass;
/** External support for pixel type. */
typedef typename Superclass::PixelType PixelType;
/** Iterator typedef support. Note the naming is intentional, i.e.,
* ::iterator and ::const_iterator, because the allocator may be a
* vnl object or other type, which uses this form. */
typedef typename Superclass::Iterator Iterator;
typedef typename Superclass::ConstIterator ConstIterator;
/** Size and value typedef support. */
typedef typename Superclass::SizeType SizeType;
typedef typename Superclass::SizeValueType SizeValueType;
typedef typename Superclass::OffsetType OffsetType;
/** Radius typedef support. */
typedef typename Superclass::RadiusType RadiusType;
/** External slice iterator type typedef support. */
typedef typename Superclass::SliceIteratorType SliceIteratorType;
/** External support for dimensionality. */
itkStaticConstMacro(NeighborhoodDimension, unsigned int, VDimension);
typedef Vector<float, VDimension> LType;
typedef std::vector<LType> DecompType;
/** Default destructor. */
virtual ~FlatStructuringElement() {}
/** Default consructor. */
FlatStructuringElement() {m_Decomposable=false;}
/** Various constructors */
/**
* Create a box structuring element. The structuring element is
* is decomposable.
*/
static Self Box(RadiusType radius);
/** Create a ball structuring element */
static Self Ball(RadiusType radius);
/** Create a cross structuring element */
static Self Cross( RadiusType radius );
/** Create an annulus structuring element */
static Self Annulus( RadiusType radius,
unsigned int thickness = 1,
bool includeCenter = false );
/**
* Create a polygon structuring element. The structuring element is
* is decomposable.
* lines is the number of elements in the decomposition
*/
static Self Poly(RadiusType radius, unsigned lines);
/**
* Returns wether the structuring element is decomposable or not. If the
* structuring is decomposable, the set of lines associated with the
* structuring may be used by an algorithm instead of the standard buffer.
*/
bool GetDecomposable() const
{
return m_Decomposable;
}
/** Return the lines associated with the structuring element */
const DecompType & GetLines() const
{
return(m_Lines);
}
void PrintSelf(std::ostream &os, Indent indent) const;
protected:
/**
* Fill the buffer of the structuring element based on the lines
* associated to the structuring element
*/
void ComputeBufferFromLines();
private:
bool m_Decomposable;
DecompType m_Lines;
// dispatch between 2D and 3D
struct DispatchBase {};
template<unsigned int VDimension2>
struct Dispatch : DispatchBase {};
virtual FlatStructuringElement PolySub(const Dispatch<2> &,
RadiusType radius,
unsigned lines) const;
virtual FlatStructuringElement PolySub(const Dispatch<3> &,
RadiusType radius,
unsigned lines) const;
virtual FlatStructuringElement PolySub(const DispatchBase &,
RadiusType radius,
unsigned lines) const;
bool checkParallel(LType NewVec, DecompType Lines);
template<unsigned int VDimension3>
struct StructuringElementFacet
{
LType P1, P2, P3;
};
typedef StructuringElementFacet<VDimension> FacetType;
};
} // namespace itk
#ifndef ITK_MANUAL_INSTANTIATION
#include "itkFlatStructuringElement.txx"
#endif
#endif
|