/usr/include/ITK-4.5/itkWatershedSegmentTree.h is in libinsighttoolkit4-dev 4.5.0-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 175 176 177 178 | /*=========================================================================
*
* Copyright Insight Software Consortium
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0.txt
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*=========================================================================*/
#ifndef __itkWatershedSegmentTree_h
#define __itkWatershedSegmentTree_h
#include "itkProcessObject.h"
#include <deque>
#include <functional>
namespace itk
{
namespace watershed
{
/** \class SegmentTree
* A data structure for storing segment merge information used in filters of
* the watershed segmentation algorithm. See itk::WatershedImageFilter for an
* overview.
*
* \par
* This class is the implemenation of the ``merge tree'' referred to in the
* documentation for itk::WatershedImageFilter and other watershed segmentation
* component classes. It holds a list of merges among image segments at
* various saliency levels. The list is actually a representation of a binary
* tree, whose nodes are segments and edges are saliencies.
*
* \ingroup WatershedSegmentation
* \sa itk::WatershedImageFilter
*
* \ingroup ITKWatersheds
*/
template< typename TScalar >
class SegmentTree:public DataObject
{
public:
/** Define itk Smart Pointers for this object */
typedef SegmentTree Self;
typedef DataObject Superclass;
typedef SmartPointer< Self > Pointer;
typedef SmartPointer< const Self > ConstPointer;
itkNewMacro(Self);
itkTypeMacro(WatershedSegmentTree, DataObject);
typedef TScalar ScalarType;
/** Elements of the list (nodes of the tree). A record of a merge
* between two segments (IdentifierType labels) at a particular
* saliency. */
struct merge_t {
IdentifierType from;
IdentifierType to;
ScalarType saliency;
};
/** Define the container type used in this list data structure */
typedef std::deque< merge_t > DequeType;
typedef typename DequeType::iterator Iterator;
typedef typename DequeType::const_iterator ConstIterator;
typedef typename DequeType::value_type ValueType;
/** Boolean comparison functor for use in sorting functions. */
struct merge_comp:public std:: binary_function< bool, const merge_t &,
const merge_t & > {
merge_comp() {}
bool operator()(const merge_t & a, const merge_t & b)
{
return b.saliency < a.saliency;
}
};
/** Boolean comparison functor for use in sorting functions. */
struct sort_comp:public std:: binary_function< bool, const merge_t &,
const merge_t & > {
bool operator()(const merge_t & a, const merge_t & b)
{
return a.saliency < b.Saliency;
}
};
/** Returns the size of the list. */
typename DequeType::size_type Size() const
{ return m_Deque.size(); }
/** Returns TRUE if the SegmentTree is empty, FALSE if the SegmentTree is not
* empty. */
bool Empty() const
{ return m_Deque.empty(); }
/** Returns a const reference to the front of the list (node with the least
* saliency value). */
const merge_t & Front() const
{ return m_Deque.front(); }
/** Returns a const reference to the back of the list (node with the greatest
* saliency value). */
const merge_t & Back() const
{ return m_Deque.back(); }
/** Returns a reference to the front of the list */
merge_t & Front()
{ return m_Deque.front(); }
/** Returns a reference to the back of the list */
merge_t & Back()
{ return m_Deque.back(); }
/** Inserts a node at the front of the list. */
void PushFront(const ValueType & t)
{ m_Deque.push_front(t); }
/** Inserts a node at the back of the list */
void PushBack(const ValueType & t)
{ m_Deque.push_back(t); }
/** Erases the node at the front of the list. */
void PopFront()
{ m_Deque.pop_front(); }
/** Erases the node at the back of the list. */
void PopBack()
{ m_Deque.pop_back(); }
/** Returns an iterator pointing to the first element in the list. */
Iterator Begin()
{ return m_Deque.begin(); }
/** Returns a const iterator pointing to the first element in the list. */
ConstIterator Begin() const
{ return m_Deque.begin(); }
/** Returns an iterator pointing one element past the last element in the
* list. */
Iterator End()
{ return m_Deque.end(); }
/** Returns a const iterator pointing one element past the last element in the
* list. */
ConstIterator End() const
{ return m_Deque.end(); }
/** Clears the Deque completely */
void Clear()
{ m_Deque.clear(); }
/** Standard DataObject routine to initialize. Returns the segment
* tree to a default state, deallocating memory. */
void Initialize();
protected:
SegmentTree() {}
virtual ~SegmentTree() {}
SegmentTree(const Self &) {}
void operator=(const Self &) {}
void PrintSelf(std::ostream & os, Indent indent) const;
DequeType m_Deque;
};
} // end namespace watershed
} // end namespace itk
#ifndef ITK_MANUAL_INSTANTIATION
#include "itkWatershedSegmentTree.hxx"
#endif
#endif
|