Point Cloud Library (PCL)
1.11.1-dev
pcl
outofcore
outofcore_breadth_first_iterator.h
1
/*
2
* Software License Agreement (BSD License)
3
*
4
* Point Cloud Library (PCL) - www.pointclouds.org
5
* Copyright (c) 2010-2012, Willow Garage, Inc.
6
*
7
* All rights reserved.
8
*
9
* Redistribution and use in source and binary forms, with or without
10
* modification, are permitted provided that the following conditions
11
* are met:
12
*
13
* * Redistributions of source code must retain the above copyright
14
* notice, this list of conditions and the following disclaimer.
15
* * Redistributions in binary form must reproduce the above
16
* copyright notice, this list of conditions and the following
17
* disclaimer in the documentation and/or other materials provided
18
* with the distribution.
19
* * Neither the name of Willow Garage, Inc. nor the names of its
20
* contributors may be used to endorse or promote products derived
21
* from this software without specific prior written permission.
22
*
23
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
24
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
25
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
26
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
27
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
28
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
29
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
30
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
31
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
33
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34
* POSSIBILITY OF SUCH DAMAGE.
35
*
36
* $Id: outofcore_depth_first_iterator.h 7938 2012-11-14 06:27:39Z jrosen $
37
*/
38
39
#pragma once
40
41
#include <pcl/outofcore/outofcore_iterator_base.h>
42
namespace
pcl
43
{
44
namespace
outofcore
45
{
46
47
/** \class OutofcoreBreadthFirstIterator
48
*
49
* \ingroup outofcore
50
* \author Justin Rosen (jmylesrosen@gmail.com)
51
* \note Code adapted from \ref octree_iterator.h in Module \ref pcl::octree written by Julius Kammerl
52
*/
53
template
<
typename
Po
int
T=pcl::Po
int
XYZ,
typename
ContainerT=OutofcoreOctreeDiskContainer<pcl::Po
int
XYZ> >
54
class
OutofcoreBreadthFirstIterator
:
public
OutofcoreIteratorBase
<PointT, ContainerT>
55
{
56
public
:
57
using
OctreeDisk
=
pcl::outofcore::OutofcoreOctreeBase<ContainerT, PointT>
;
58
using
OctreeDiskNode
=
pcl::outofcore::OutofcoreOctreeBaseNode<ContainerT, PointT>
;
59
60
using
LeafNode
=
pcl::outofcore::OutofcoreOctreeBaseNode<ContainerT, PointT>
;
61
using
BranchNode
=
pcl::outofcore::OutofcoreOctreeBaseNode<ContainerT, PointT>
;
62
63
64
explicit
65
OutofcoreBreadthFirstIterator
(
OctreeDisk
& octree_arg);
66
67
68
~OutofcoreBreadthFirstIterator
();
69
70
OutofcoreBreadthFirstIterator
&
71
operator++
();
72
73
inline
OutofcoreBreadthFirstIterator
74
operator++
(
int
)
75
{
76
OutofcoreBreadthFirstIterator
_Tmp = *
this
;
77
++*
this
;
78
return
(_Tmp);
79
}
80
81
inline
void
82
reset
()
override
83
{
84
OutofcoreIteratorBase<PointT, ContainerT>::reset
();
85
86
// Clear the FIFO queue and add the root as the first node
87
FIFO_
.clear ();
88
FIFO_
.push_back(this->
currentNode_
);
89
90
// Don't skip children
91
skip_child_voxels_
=
false
;
92
}
93
94
void
95
skipChildVoxels
()
96
{
97
skip_child_voxels_
=
true
;
98
}
99
100
protected
:
101
/** FIFO list */
102
std::deque<OctreeDiskNode*>
FIFO_
;
103
bool
skip_child_voxels_
;
104
};
105
}
106
}
pcl
Definition:
convolution.h:46
pcl::outofcore::OutofcoreIteratorBase
Abstract octree iterator class.
Definition:
outofcore_iterator_base.h:59
pcl::outofcore::OutofcoreBreadthFirstIterator
Definition:
outofcore_breadth_first_iterator.h:54
pcl::outofcore::OutofcoreBreadthFirstIterator::FIFO_
std::deque< OctreeDiskNode * > FIFO_
FIFO list.
Definition:
outofcore_breadth_first_iterator.h:102
pcl::outofcore::OutofcoreOctreeBaseNode
OutofcoreOctreeBaseNode Class internally representing nodes of an outofcore octree,...
Definition:
octree_base_node.h:62
pcl::outofcore::OutofcoreBreadthFirstIterator::~OutofcoreBreadthFirstIterator
~OutofcoreBreadthFirstIterator()
Definition:
outofcore_breadth_first_iterator.hpp:57
pcl::outofcore::OutofcoreBreadthFirstIterator::OutofcoreBreadthFirstIterator
OutofcoreBreadthFirstIterator(OctreeDisk &octree_arg)
Definition:
outofcore_breadth_first_iterator.hpp:48
pcl::outofcore::OutofcoreBreadthFirstIterator::operator++
OutofcoreBreadthFirstIterator & operator++()
Definition:
outofcore_breadth_first_iterator.hpp:65
pcl::outofcore::OutofcoreBreadthFirstIterator::skip_child_voxels_
bool skip_child_voxels_
Definition:
outofcore_breadth_first_iterator.h:103
pcl::outofcore::OutofcoreIteratorBase::reset
virtual void reset()
Definition:
outofcore_iterator_base.h:113
pcl::outofcore::OutofcoreBreadthFirstIterator::reset
void reset() override
Definition:
outofcore_breadth_first_iterator.h:82
pcl::outofcore::OutofcoreOctreeBase
This code defines the octree used for point storage at Urban Robotics.
Definition:
octree_base.h:150
pcl::outofcore::OutofcoreIteratorBase< pcl::PointXYZ, OutofcoreOctreeDiskContainer< pcl::PointXYZ > >::currentNode_
OctreeDiskNode * currentNode_
Definition:
outofcore_iterator_base.h:133
pcl::outofcore::OutofcoreBreadthFirstIterator::skipChildVoxels
void skipChildVoxels()
Definition:
outofcore_breadth_first_iterator.h:95