|
Point Cloud Library (PCL)
1.15.1-dev
|
Octree class. More...
#include <pcl/octree/octree_base.h>
Inheritance diagram for pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >:
Collaboration diagram for pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >:Public Member Functions | |
| Iterator | begin (uindex_t max_depth_arg=0u) |
| ConstIterator | begin (uindex_t max_depth_arg=0u) const |
| ConstIterator | cbegin (uindex_t max_depth_arg=0u) const |
| const Iterator | end () |
| const ConstIterator | end () const |
| const ConstIterator | cend () const |
| LeafNodeDepthFirstIterator | leaf_depth_begin (uindex_t max_depth_arg=0u) |
| ConstLeafNodeDepthFirstIterator | leaf_depth_begin (uindex_t max_depth_arg=0u) const |
| const LeafNodeDepthFirstIterator | leaf_depth_end () |
| const ConstLeafNodeDepthFirstIterator | leaf_depth_end () const |
| DepthFirstIterator | depth_begin (uindex_t max_depth_arg=0u) |
| ConstDepthFirstIterator | depth_begin (uindex_t max_depth_arg=0u) const |
| const DepthFirstIterator | depth_end () |
| const ConstDepthFirstIterator | depth_end () const |
| BreadthFirstIterator | breadth_begin (uindex_t max_depth_arg=0u) |
| ConstBreadthFirstIterator | breadth_begin (uindex_t max_depth_arg=0u) const |
| const BreadthFirstIterator | breadth_end () |
| const ConstBreadthFirstIterator | breadth_end () const |
| FixedDepthIterator | fixed_depth_begin (uindex_t fixed_depth_arg=0u) |
| ConstFixedDepthIterator | fixed_depth_begin (uindex_t fixed_depth_arg=0u) const |
| const FixedDepthIterator | fixed_depth_end () |
| const ConstFixedDepthIterator | fixed_depth_end () const |
| LeafNodeBreadthFirstIterator | leaf_breadth_begin (uindex_t max_depth_arg=0u) |
| ConstLeafNodeBreadthFirstIterator | leaf_breadth_begin (uindex_t max_depth_arg=0u) const |
| const LeafNodeBreadthFirstIterator | leaf_breadth_end () |
| const ConstLeafNodeBreadthFirstIterator | leaf_breadth_end () const |
| OctreeBase () | |
| Empty constructor. More... | |
| virtual | ~OctreeBase () |
| Empty deconstructor. More... | |
| OctreeBase (const OctreeBase &source) | |
| Copy constructor. More... | |
| OctreeBase & | operator= (const OctreeBase &source) |
| Copy operator. More... | |
| void | setMaxVoxelIndex (uindex_t max_voxel_index_arg) |
| Set the maximum amount of voxels per dimension. More... | |
| void | setTreeDepth (uindex_t max_depth_arg) |
| Set the maximum depth of the octree. More... | |
| uindex_t | getTreeDepth () const |
| Get the maximum depth of the octree. More... | |
| LeafContainerT * | createLeaf (uindex_t idx_x_arg, uindex_t idx_y_arg, uindex_t idx_z_arg) |
| Create new leaf node at (idx_x_arg, idx_y_arg, idx_z_arg). More... | |
| LeafContainerT * | findLeaf (uindex_t idx_x_arg, uindex_t idx_y_arg, uindex_t idx_z_arg) const |
| Find leaf node at (idx_x_arg, idx_y_arg, idx_z_arg). More... | |
| bool | existLeaf (uindex_t idx_x_arg, uindex_t idx_y_arg, uindex_t idx_z_arg) const |
| idx_x_arg for the existence of leaf node at (idx_x_arg, idx_y_arg, idx_z_arg). More... | |
| void | removeLeaf (uindex_t idx_x_arg, uindex_t idx_y_arg, uindex_t idx_z_arg) |
| Remove leaf node at (idx_x_arg, idx_y_arg, idx_z_arg). More... | |
| std::size_t | getLeafCount () const |
| Return the amount of existing leafs in the octree. More... | |
| std::size_t | getBranchCount () const |
| Return the amount of existing branch nodes in the octree. More... | |
| void | deleteTree () |
| Delete the octree structure and its leaf nodes. More... | |
| void | serializeTree (std::vector< char > &binary_tree_out_arg) const |
| Serialize octree into a binary output vector describing its branch node structure. More... | |
| void | serializeTree (std::vector< char > &binary_tree_out_arg, std::vector< LeafContainerT * > &leaf_container_vector_arg) const |
| Serialize octree into a binary output vector describing its branch node structure and push all LeafContainerT elements stored in the octree to a vector. More... | |
| void | serializeLeafs (std::vector< LeafContainerT * > &leaf_container_vector_arg) |
| Outputs a vector of all LeafContainerT elements that are stored within the octree leaf nodes. More... | |
| void | deserializeTree (std::vector< char > &binary_tree_input_arg) |
| Deserialize a binary octree description vector and create a corresponding octree structure. More... | |
| void | deserializeTree (std::vector< char > &binary_tree_input_arg, std::vector< LeafContainerT * > &leaf_container_vector_arg) |
| Deserialize a binary octree description and create a corresponding octree structure. More... | |
Protected Member Functions | |
| LeafContainerT * | createLeaf (const OctreeKey &key_arg) |
| Create a leaf node. More... | |
| LeafContainerT * | findLeaf (const OctreeKey &key_arg) const |
| Find leaf node. More... | |
| bool | existLeaf (const OctreeKey &key_arg) const |
| Check for existence of a leaf node in the octree. More... | |
| void | removeLeaf (const OctreeKey &key_arg) |
| Remove leaf node from octree. More... | |
| OctreeNode * | getRootNode () const |
| Retrieve root node. More... | |
| bool | branchHasChild (const BranchNode &branch_arg, unsigned char child_idx_arg) const |
| Check if branch is pointing to a particular child node. More... | |
| OctreeNode * | getBranchChildPtr (const BranchNode &branch_arg, unsigned char child_idx_arg) const |
| Retrieve a child node pointer for child node at child_idx. More... | |
| void | setBranchChildPtr (BranchNode &branch_arg, unsigned char child_idx_arg, OctreeNode *new_child_arg) |
| Assign new child node to branch. More... | |
| char | getBranchBitPattern (const BranchNode &branch_arg) const |
| Generate bit pattern reflecting the existence of child node pointers. More... | |
| void | deleteBranchChild (BranchNode &branch_arg, unsigned char child_idx_arg) |
| Delete child node and all its subchilds from octree. More... | |
| void | deleteBranch (BranchNode &branch_arg) |
| Delete branch and all its subchilds from octree. More... | |
| BranchNode * | createBranchChild (BranchNode &branch_arg, unsigned char child_idx_arg) |
| Create and add a new branch child to a branch class. More... | |
| LeafNode * | createLeafChild (BranchNode &branch_arg, unsigned char child_idx_arg) |
| Create and add a new leaf child to a branch class. More... | |
| uindex_t | createLeafRecursive (const OctreeKey &key_arg, uindex_t depth_mask_arg, BranchNode *branch_arg, LeafNode *&return_leaf_arg, BranchNode *&parent_of_leaf_arg) |
| Create a leaf node at octree key. More... | |
| void | findLeafRecursive (const OctreeKey &key_arg, uindex_t depth_mask_arg, BranchNode *branch_arg, LeafContainerT *&result_arg) const |
| Recursively search for a given leaf node and return a pointer. More... | |
| bool | deleteLeafRecursive (const OctreeKey &key_arg, uindex_t depth_mask_arg, BranchNode *branch_arg) |
| Recursively search and delete leaf node. More... | |
| void | serializeTreeRecursive (const BranchNode *branch_arg, OctreeKey &key_arg, std::vector< char > *binary_tree_out_arg, typename std::vector< LeafContainerT * > *leaf_container_vector_arg) const |
| Recursively explore the octree and output binary octree description together with a vector of leaf node LeafContainerTs. More... | |
| void | deserializeTreeRecursive (BranchNode *branch_arg, uindex_t depth_mask_arg, OctreeKey &key_arg, typename std::vector< char >::const_iterator &binary_tree_input_it_arg, typename std::vector< char >::const_iterator &binary_tree_input_it_end_arg, typename std::vector< LeafContainerT * >::const_iterator *leaf_container_vector_it_arg, typename std::vector< LeafContainerT * >::const_iterator *leaf_container_vector_it_end_arg) |
| Recursive method for deserializing octree structure. More... | |
| virtual void | serializeTreeCallback (LeafContainerT &, const OctreeKey &) const |
| Callback executed for every leaf node during serialization. More... | |
| virtual void | deserializeTreeCallback (LeafContainerT &, const OctreeKey &) |
| Callback executed for every leaf node during deserialization. More... | |
| bool | octreeCanResize () const |
| Test if octree is able to dynamically change its depth. More... | |
Protected Attributes | |
| std::size_t | leaf_count_ {0} |
| Amount of leaf nodes More... | |
| std::size_t | branch_count_ {1} |
| Amount of branch nodes More... | |
| BranchNode * | root_node_ |
| Pointer to root branch node of octree More... | |
| uindex_t | depth_mask_ {0} |
| Depth mask based on octree depth More... | |
| uindex_t | octree_depth_ {0} |
| Octree depth. More... | |
| bool | dynamic_depth_enabled_ {false} |
| Enable dynamic_depth. More... | |
| OctreeKey | max_key_ |
| key range More... | |
Octree class.
Definition at line 62 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::BranchContainer = BranchContainerT |
Definition at line 69 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::BranchNode = OctreeBranchNode<BranchContainerT> |
Definition at line 66 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::BreadthFirstIterator = OctreeBreadthFirstIterator<OctreeT> |
Definition at line 222 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::ConstBreadthFirstIterator = OctreeBreadthFirstIterator<const OctreeT> |
Definition at line 223 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::ConstDepthFirstIterator = OctreeDepthFirstIterator<const OctreeT> |
Definition at line 193 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::ConstFixedDepthIterator = OctreeFixedDepthIterator<const OctreeT> |
Definition at line 253 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::ConstIterator = OctreeDepthFirstIterator<const OctreeT> |
Definition at line 115 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::ConstLeafNodeBreadthFirstIterator = OctreeLeafNodeBreadthFirstIterator<const OctreeT> |
Definition at line 281 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::ConstLeafNodeDepthFirstIterator = OctreeLeafNodeDepthFirstIterator<const OctreeT> |
Definition at line 162 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::ConstLeafNodeIterator = OctreeLeafNodeDepthFirstIterator<const OctreeT> |
Definition at line 158 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::DepthFirstIterator = OctreeDepthFirstIterator<OctreeT> |
Definition at line 192 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::FixedDepthIterator = OctreeFixedDepthIterator<OctreeT> |
Definition at line 252 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::Iterator = OctreeDepthFirstIterator<OctreeT> |
Definition at line 114 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::LeafContainer = LeafContainerT |
Definition at line 70 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::LeafNode = OctreeLeafNode<LeafContainerT> |
Definition at line 67 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::LeafNodeBreadthFirstIterator = OctreeLeafNodeBreadthFirstIterator<OctreeT> |
Definition at line 280 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::LeafNodeDepthFirstIterator = OctreeLeafNodeDepthFirstIterator<OctreeT> |
Definition at line 161 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::LeafNodeIterator = OctreeLeafNodeDepthFirstIterator<OctreeT> |
Definition at line 157 of file octree_base.h.
| using pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::OctreeT = OctreeBase<LeafContainerT, BranchContainerT> |
Definition at line 64 of file octree_base.h.
| pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::OctreeBase |
Empty constructor.
Definition at line 48 of file octree_base.hpp.
|
virtual |
Empty deconstructor.
Definition at line 54 of file octree_base.hpp.
|
inline |
Copy constructor.
Definition at line 317 of file octree_base.h.
|
inline |
Definition at line 118 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 124 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inlineprotected |
Check if branch is pointing to a particular child node.
| branch_arg | reference to octree branch class |
| child_idx_arg | index to child node |
Definition at line 542 of file octree_base.h.
References pcl::octree::OctreeBranchNode< ContainerT >::getChildPtr().
|
inline |
Definition at line 226 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 233 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 240 of file octree_base.h.
|
inline |
Definition at line 246 of file octree_base.h.
|
inline |
Definition at line 130 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 148 of file octree_base.h.
|
inlineprotected |
Create and add a new branch child to a branch class.
| branch_arg | reference to octree branch class |
| child_idx_arg | index to child node |
Definition at line 640 of file octree_base.h.
|
inlineprotected |
Create a leaf node.
| key_arg | octree key addressing a leaf node. |
Definition at line 480 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::createLeafRecursive(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::depth_mask_, pcl::octree::OctreeLeafNode< ContainerT >::getContainerPtr(), and pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::root_node_.
| LeafContainerT * pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::createLeaf | ( | uindex_t | idx_x_arg, |
| uindex_t | idx_y_arg, | ||
| uindex_t | idx_z_arg | ||
| ) |
Create new leaf node at (idx_x_arg, idx_y_arg, idx_z_arg).
| idx_x_arg | index of leaf node in the X axis. |
| idx_y_arg | index of leaf node in the Y axis. |
| idx_z_arg | index of leaf node in the Z axis. |
Definition at line 129 of file octree_base.hpp.
Referenced by pcl::octree::OctreePointCloudOccupancy< PointT, LeafContainerT, BranchContainerT >::setOccupiedVoxelAtPoint().
|
inlineprotected |
Create and add a new leaf child to a branch class.
| branch_arg | reference to octree branch class |
| child_idx_arg | index to child node |
Definition at line 654 of file octree_base.h.
|
protected |
Create a leaf node at octree key.
If leaf node does already exist, it is returned.
| key_arg | reference to an octree key |
| depth_mask_arg | depth mask used for octree key analysis and for branch depth indicator |
| branch_arg | current branch node |
| return_leaf_arg | return pointer to leaf node |
| parent_of_leaf_arg | return pointer to parent of leaf node |
Definition at line 293 of file octree_base.hpp.
References pcl::octree::OctreeKey::getChildIdxWithDepthMask().
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::createLeaf().
|
inlineprotected |
Delete branch and all its subchilds from octree.
| branch_arg | reference to octree branch class |
Definition at line 627 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::deleteBranchChild().
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::deleteBranchChild().
|
inlineprotected |
Delete child node and all its subchilds from octree.
| branch_arg | reference to octree branch class |
| child_idx_arg | index to child node |
Definition at line 596 of file octree_base.h.
References pcl::octree::BRANCH_NODE, pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::deleteBranch(), pcl::octree::OctreeNode::getNodeType(), pcl::octree::OctreeBranchNode< ContainerT >::hasChild(), and pcl::octree::LEAF_NODE.
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::deleteBranch().
|
protected |
Recursively search and delete leaf node.
| key_arg | reference to an octree key |
| depth_mask_arg | depth mask used for octree key analysis and branch depth indicator |
| branch_arg | current branch node |
Definition at line 391 of file octree_base.hpp.
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::removeLeaf().
| void pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::deleteTree |
Delete the octree structure and its leaf nodes.
Definition at line 171 of file octree_base.hpp.
|
inline |
Definition at line 196 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 203 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 210 of file octree_base.h.
|
inline |
Definition at line 216 of file octree_base.h.
| void pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::deserializeTree | ( | std::vector< char > & | binary_tree_input_arg | ) |
Deserialize a binary octree description vector and create a corresponding octree structure.
Leaf nodes are initialized with getDataTByKey(..).
| binary_tree_input_arg | reference to input vector for reading binary tree structure. |
Definition at line 238 of file octree_base.hpp.
| void pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::deserializeTree | ( | std::vector< char > & | binary_tree_input_arg, |
| std::vector< LeafContainerT * > & | leaf_container_vector_arg | ||
| ) |
Deserialize a binary octree description and create a corresponding octree structure.
Leaf nodes are initialized with LeafContainerT elements from the dataVector.
| binary_tree_input_arg | reference to input vector for reading binary tree structure. |
| leaf_container_vector_arg | pointer to container vector. |
Definition at line 262 of file octree_base.hpp.
|
inlineprotectedvirtual |
Callback executed for every leaf node during deserialization.
Definition at line 762 of file octree_base.h.
|
protected |
Recursive method for deserializing octree structure.
| branch_arg | current branch node |
| depth_mask_arg | depth mask used for octree key analysis and branch depth indicator |
| key_arg | reference to an octree key |
| binary_tree_input_it_arg | iterator to binary input vector |
| binary_tree_input_it_end_arg | end iterator of binary input vector |
| leaf_container_vector_it_arg | iterator pointing to current LeafContainerT object to be added to a leaf node |
| leaf_container_vector_it_end_arg | iterator pointing to last object in LeafContainerT input vector. |
Definition at line 500 of file octree_base.hpp.
References pcl::octree::OctreeKey::popBranch(), and pcl::octree::OctreeKey::pushBranch().
|
inline |
Definition at line 136 of file octree_base.h.
|
inline |
Definition at line 142 of file octree_base.h.
|
inlineprotected |
Check for existence of a leaf node in the octree.
| key_arg | octree key addressing a leaf node. |
Definition at line 510 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::findLeaf().
| bool pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::existLeaf | ( | uindex_t | idx_x_arg, |
| uindex_t | idx_y_arg, | ||
| uindex_t | idx_z_arg | ||
| ) | const |
idx_x_arg for the existence of leaf node at (idx_x_arg, idx_y_arg, idx_z_arg).
| idx_x_arg | index of leaf node in the X axis. |
| idx_y_arg | index of leaf node in the Y axis. |
| idx_z_arg | index of leaf node in the Z axis. |
Definition at line 143 of file octree_base.hpp.
|
inlineprotected |
Find leaf node.
| key_arg | octree key addressing a leaf node. |
Definition at line 498 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::depth_mask_, pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::findLeafRecursive(), and pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::root_node_.
| LeafContainerT * pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::findLeaf | ( | uindex_t | idx_x_arg, |
| uindex_t | idx_y_arg, | ||
| uindex_t | idx_z_arg | ||
| ) | const |
Find leaf node at (idx_x_arg, idx_y_arg, idx_z_arg).
| idx_x_arg | index of leaf node in the X axis. |
| idx_y_arg | index of leaf node in the Y axis. |
| idx_z_arg | index of leaf node in the Z axis. |
Definition at line 115 of file octree_base.hpp.
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::existLeaf().
|
protected |
Recursively search for a given leaf node and return a pointer.
| key_arg | reference to an octree key |
| depth_mask_arg | depth mask used for octree key analysis and for branch depth indicator |
| branch_arg | current branch node |
| result_arg | pointer to leaf node class |
Definition at line 353 of file octree_base.hpp.
References pcl::octree::BRANCH_NODE, pcl::octree::OctreeKey::getChildIdxWithDepthMask(), and pcl::octree::OctreeNode::getNodeType().
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::findLeaf().
|
inline |
Definition at line 256 of file octree_base.h.
|
inline |
Definition at line 262 of file octree_base.h.
|
inline |
Definition at line 268 of file octree_base.h.
|
inline |
Definition at line 274 of file octree_base.h.
|
inlineprotected |
Generate bit pattern reflecting the existence of child node pointers.
| branch_arg | reference to octree branch class |
Definition at line 577 of file octree_base.h.
References pcl::octree::OctreeBranchNode< ContainerT >::getChildPtr().
|
inlineprotected |
Retrieve a child node pointer for child node at child_idx.
| branch_arg | reference to octree branch class |
| child_idx_arg | index to child node |
Definition at line 554 of file octree_base.h.
References pcl::octree::OctreeBranchNode< ContainerT >::getChildPtr().
|
inline |
Return the amount of existing branch nodes in the octree.
Definition at line 415 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::branch_count_.
|
inline |
Return the amount of existing leafs in the octree.
Definition at line 406 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::leaf_count_.
|
inlineprotected |
Retrieve root node.
Definition at line 531 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::root_node_.
|
inline |
Get the maximum depth of the octree.
Definition at line 359 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 285 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 292 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 299 of file octree_base.h.
|
inline |
Definition at line 305 of file octree_base.h.
|
inline |
Definition at line 166 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 173 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_.
|
inline |
Definition at line 180 of file octree_base.h.
|
inline |
Definition at line 186 of file octree_base.h.
|
inlineprotected |
Test if octree is able to dynamically change its depth.
This is required for adaptive bounding box adjustment.
Definition at line 774 of file octree_base.h.
|
inline |
Copy operator.
Definition at line 329 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::branch_count_, pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::depth_mask_, pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::dynamic_depth_enabled_, pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::leaf_count_, pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::max_key_, pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::octree_depth_, and pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::root_node_.
|
inlineprotected |
Remove leaf node from octree.
| key_arg | octree key addressing a leaf node. |
Definition at line 519 of file octree_base.h.
References pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::deleteLeafRecursive(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::depth_mask_, pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::max_key_, and pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::root_node_.
| void pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::removeLeaf | ( | uindex_t | idx_x_arg, |
| uindex_t | idx_y_arg, | ||
| uindex_t | idx_z_arg | ||
| ) |
Remove leaf node at (idx_x_arg, idx_y_arg, idx_z_arg).
| idx_x_arg | index of leaf node in the X axis. |
| idx_y_arg | index of leaf node in the Y axis. |
| idx_z_arg | index of leaf node in the Z axis. |
Definition at line 157 of file octree_base.hpp.
| void pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::serializeLeafs | ( | std::vector< LeafContainerT * > & | leaf_container_vector_arg | ) |
Outputs a vector of all LeafContainerT elements that are stored within the octree leaf nodes.
| leaf_container_vector_arg | pointers to LeafContainerT vector that receives a copy of all LeafContainerT objects in the octree. |
Definition at line 222 of file octree_base.hpp.
| void pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::serializeTree | ( | std::vector< char > & | binary_tree_out_arg | ) | const |
Serialize octree into a binary output vector describing its branch node structure.
| binary_tree_out_arg | reference to output vector for writing binary tree structure. |
Definition at line 185 of file octree_base.hpp.
| void pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::serializeTree | ( | std::vector< char > & | binary_tree_out_arg, |
| std::vector< LeafContainerT * > & | leaf_container_vector_arg | ||
| ) | const |
Serialize octree into a binary output vector describing its branch node structure and push all LeafContainerT elements stored in the octree to a vector.
| binary_tree_out_arg | reference to output vector for writing binary tree structure. |
| leaf_container_vector_arg | pointer to all LeafContainerT objects in the octree |
Definition at line 201 of file octree_base.hpp.
|
inlineprotectedvirtual |
Callback executed for every leaf node during serialization.
Definition at line 756 of file octree_base.h.
|
protected |
Recursively explore the octree and output binary octree description together with a vector of leaf node LeafContainerTs.
| branch_arg | current branch node |
| key_arg | reference to an octree key |
| binary_tree_out_arg | binary output vector |
| leaf_container_vector_arg | writes LeafContainerT pointers to this LeafContainerT* vector. |
Definition at line 443 of file octree_base.hpp.
|
inlineprotected |
Assign new child node to branch.
| branch_arg | reference to octree branch class |
| child_idx_arg | index to child node |
| new_child_arg | pointer to new child node |
Definition at line 565 of file octree_base.h.
| void pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::setMaxVoxelIndex | ( | uindex_t | max_voxel_index_arg | ) |
Set the maximum amount of voxels per dimension.
| [in] | max_voxel_index_arg | maximum amount of voxels per dimension |
Definition at line 64 of file octree_base.hpp.
References pcl::octree::OctreeKey::maxDepth.
| void pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::setTreeDepth | ( | uindex_t | max_depth_arg | ) |
Set the maximum depth of the octree.
| max_depth_arg | maximum depth of octree |
Definition at line 87 of file octree_base.hpp.
References pcl::octree::OctreeKey::maxDepth.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
friend |
Definition at line 96 of file octree_base.h.
|
protected |
Amount of branch nodes
Definition at line 81 of file octree_base.h.
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::getBranchCount(), and pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::operator=().
|
protected |
Depth mask based on octree depth
Definition at line 87 of file octree_base.h.
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::createLeaf(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::findLeaf(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::operator=(), and pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::removeLeaf().
|
protected |
Enable dynamic_depth.
Definition at line 93 of file octree_base.h.
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::operator=().
|
protected |
Amount of leaf nodes
Definition at line 78 of file octree_base.h.
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::getLeafCount(), and pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::operator=().
|
protected |
key range
Definition at line 96 of file octree_base.h.
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::operator=(), and pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::removeLeaf().
|
protected |
Octree depth.
Definition at line 90 of file octree_base.h.
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::begin(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::breadth_begin(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::cbegin(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::depth_begin(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::getTreeDepth(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::leaf_breadth_begin(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::leaf_depth_begin(), and pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::operator=().
|
protected |
Pointer to root branch node of octree
Definition at line 84 of file octree_base.h.
Referenced by pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::createLeaf(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::findLeaf(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::getRootNode(), pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::operator=(), and pcl::octree::OctreeBase< LeafContainerT, BranchContainerT >::removeLeaf().