|
| typedef OctreeBase< LeafContainerT, BranchContainerT > | OctreeBaseT |
| |
| typedef OctreePointCloudAdjacency< PointT, LeafContainerT, BranchContainerT > | OctreeAdjacencyT |
| |
| typedef boost::shared_ptr< OctreeAdjacencyT > | Ptr |
| |
| typedef boost::shared_ptr< const OctreeAdjacencyT > | ConstPtr |
| |
| typedef OctreePointCloud< PointT, LeafContainerT, BranchContainerT, OctreeBaseT > | OctreePointCloudT |
| |
| typedef OctreePointCloudT::LeafNode | LeafNode |
| |
| typedef OctreePointCloudT::BranchNode | BranchNode |
| |
| typedef pcl::PointCloud< PointT > | CloudT |
| |
| typedef OctreeDepthFirstIterator< OctreeAdjacencyT > | Iterator |
| |
| typedef const OctreeDepthFirstIterator< OctreeAdjacencyT > | ConstIterator |
| |
| typedef OctreeLeafNodeIterator< OctreeAdjacencyT > | LeafNodeIterator |
| |
| typedef const OctreeLeafNodeIterator< OctreeAdjacencyT > | ConstLeafNodeIterator |
| |
| typedef boost::adjacency_list< boost::setS, boost::setS, boost::undirectedS, PointT, float > | VoxelAdjacencyList |
| |
| typedef VoxelAdjacencyList::vertex_descriptor | VoxelID |
| |
| typedef VoxelAdjacencyList::edge_descriptor | EdgeID |
| |
| typedef std::vector< LeafContainerT * > | LeafVectorT |
| |
| typedef LeafVectorT::iterator | iterator |
| |
| typedef LeafVectorT::const_iterator | const_iterator |
| |
| typedef OctreeBase< LeafContainerT, BranchContainerT > | Base |
| |
| typedef OctreeBase< LeafContainerT, BranchContainerT >::LeafNode | LeafNode |
| |
| typedef OctreeBase< LeafContainerT, BranchContainerT >::BranchNode | BranchNode |
| |
| typedef OctreeDepthFirstIterator< OctreeBase< LeafContainerT, BranchContainerT > > | Iterator |
| |
| typedef const OctreeDepthFirstIterator< OctreeBase< LeafContainerT, BranchContainerT > > | ConstIterator |
| |
| typedef OctreeLeafNodeIterator< OctreeBase< LeafContainerT, BranchContainerT > > | LeafNodeIterator |
| |
| typedef const OctreeLeafNodeIterator< OctreeBase< LeafContainerT, BranchContainerT > > | ConstLeafNodeIterator |
| |
| typedef OctreeDepthFirstIterator< OctreeBase< LeafContainerT, BranchContainerT > > | DepthFirstIterator |
| |
| typedef const OctreeDepthFirstIterator< OctreeBase< LeafContainerT, BranchContainerT > > | ConstDepthFirstIterator |
| |
| typedef OctreeBreadthFirstIterator< OctreeBase< LeafContainerT, BranchContainerT > > | BreadthFirstIterator |
| |
| typedef const OctreeBreadthFirstIterator< OctreeBase< LeafContainerT, BranchContainerT > > | ConstBreadthFirstIterator |
| |
| typedef boost::shared_ptr< std::vector< int > > | IndicesPtr |
| |
| typedef boost::shared_ptr< const std::vector< int > > | IndicesConstPtr |
| |
| typedef pcl::PointCloud< PointT > | PointCloud |
| |
| typedef boost::shared_ptr< PointCloud > | PointCloudPtr |
| |
| typedef boost::shared_ptr< const PointCloud > | PointCloudConstPtr |
| |
| typedef OctreePointCloud< PointT, LeafContainerT, BranchContainerT, OctreeBase< LeafContainerT > > | SingleBuffer |
| |
| typedef boost::shared_ptr< OctreePointCloud< PointT, LeafContainerT, BranchContainerT, OctreeBase< LeafContainerT, BranchContainerT > > > | Ptr |
| |
| typedef boost::shared_ptr< const OctreePointCloud< PointT, LeafContainerT, BranchContainerT, OctreeBase< LeafContainerT, BranchContainerT > > > | ConstPtr |
| |
| typedef std::vector< PointT, Eigen::aligned_allocator< PointT > > | AlignedPointTVector |
| |
| typedef std::vector< PointXYZ, Eigen::aligned_allocator< PointXYZ > > | AlignedPointXYZVector |
| |
| typedef OctreeBase< LeafContainerT, BranchContainerT > | OctreeT |
| |
| typedef OctreeBranchNode< BranchContainerT > | BranchNode |
| |
| typedef OctreeLeafNode< LeafContainerT > | LeafNode |
| |
| typedef BranchContainerT | BranchContainer |
| |
| typedef LeafContainerT | LeafContainer |
| |
| typedef OctreeDepthFirstIterator< OctreeT > | Iterator |
| |
| typedef const OctreeDepthFirstIterator< OctreeT > | ConstIterator |
| |
| typedef OctreeLeafNodeIterator< OctreeT > | LeafNodeIterator |
| |
| typedef const OctreeLeafNodeIterator< OctreeT > | ConstLeafNodeIterator |
| |
| typedef OctreeDepthFirstIterator< OctreeT > | DepthFirstIterator |
| |
| typedef const OctreeDepthFirstIterator< OctreeT > | ConstDepthFirstIterator |
| |
| typedef OctreeBreadthFirstIterator< OctreeT > | BreadthFirstIterator |
| |
| typedef const OctreeBreadthFirstIterator< OctreeT > | ConstBreadthFirstIterator |
| |
|
| Iterator | depth_begin (unsigned int maxDepth_arg=0) |
| |
| const Iterator | depth_end () |
| |
| LeafNodeIterator | leaf_begin (unsigned int maxDepth_arg=0) |
| |
| const LeafNodeIterator | leaf_end () |
| |
| iterator | begin () |
| |
| iterator | end () |
| |
| size_t | size () const |
| |
| | OctreePointCloudAdjacency (const double resolution_arg) |
| | Constructor. More...
|
| |
| virtual | ~OctreePointCloudAdjacency () |
| | Empty class destructor. More...
|
| |
| void | addPointsFromInputCloud () |
| | Adds points from cloud to the octree. More...
|
| |
| LeafContainerT * | getLeafContainerAtPoint (const PointT &point_arg) const |
| | Gets the leaf container for a given point. More...
|
| |
| void | computeVoxelAdjacencyGraph (VoxelAdjacencyList &voxel_adjacency_graph) |
| | Computes an adjacency graph of voxel relations. More...
|
| |
| void | setTransformFunction (boost::function< void(PointT &p)> transform_func) |
| | Sets a point transform (and inverse) used to transform the space of the input cloud This is useful for changing how adjacency is calculated - such as relaxing the adjacency criterion for points further from the camera. More...
|
| |
| bool | testForOcclusion (const PointT &point_arg, const PointXYZ &camera_pos=PointXYZ(0, 0, 0)) |
| | Tests whether input point is occluded from specified camera point by other voxels. More...
|
| |
| | OctreePointCloud (const double resolution_arg) |
| | Octree pointcloud constructor. More...
|
| |
| virtual | ~OctreePointCloud () |
| | Empty deconstructor. More...
|
| |
| void | setInputCloud (const PointCloudConstPtr &cloud_arg, const IndicesConstPtr &indices_arg=IndicesConstPtr()) |
| | Provide a pointer to the input data set. More...
|
| |
| IndicesConstPtr const | getIndices () const |
| | Get a pointer to the vector of indices used. More...
|
| |
| PointCloudConstPtr | getInputCloud () const |
| | Get a pointer to the input point cloud dataset. More...
|
| |
| void | setEpsilon (double eps) |
| | Set the search epsilon precision (error bound) for nearest neighbors searches. More...
|
| |
| double | getEpsilon () const |
| | Get the search epsilon precision (error bound) for nearest neighbors searches. More...
|
| |
| void | setResolution (double resolution_arg) |
| | Set/change the octree voxel resolution. More...
|
| |
| double | getResolution () const |
| | Get octree voxel resolution. More...
|
| |
| unsigned int | getTreeDepth () const |
| | Get the maximum depth of the octree. More...
|
| |
| void | addPointsFromInputCloud () |
| | Add points from input point cloud to octree. More...
|
| |
| void | addPointFromCloud (const int point_idx_arg, IndicesPtr indices_arg) |
| | Add point at given index from input point cloud to octree. More...
|
| |
| void | addPointToCloud (const PointT &point_arg, PointCloudPtr cloud_arg) |
| | Add point simultaneously to octree and input point cloud. More...
|
| |
| void | addPointToCloud (const PointT &point_arg, PointCloudPtr cloud_arg, IndicesPtr indices_arg) |
| | Add point simultaneously to octree and input point cloud. More...
|
| |
| bool | isVoxelOccupiedAtPoint (const PointT &point_arg) const |
| | Check if voxel at given point exist. More...
|
| |
| bool | isVoxelOccupiedAtPoint (const double point_x_arg, const double point_y_arg, const double point_z_arg) const |
| | Check if voxel at given point coordinates exist. More...
|
| |
| bool | isVoxelOccupiedAtPoint (const int &point_idx_arg) const |
| | Check if voxel at given point from input cloud exist. More...
|
| |
| void | deleteTree () |
| | Delete the octree structure and its leaf nodes. More...
|
| |
| int | getOccupiedVoxelCenters (AlignedPointTVector &voxel_center_list_arg) const |
| | Get a PointT vector of centers of all occupied voxels. More...
|
| |
| int | getApproxIntersectedVoxelCentersBySegment (const Eigen::Vector3f &origin, const Eigen::Vector3f &end, AlignedPointTVector &voxel_center_list, float precision=0.2) |
| | Get a PointT vector of centers of voxels intersected by a line segment. More...
|
| |
| void | deleteVoxelAtPoint (const PointT &point_arg) |
| | Delete leaf node / voxel at given point. More...
|
| |
| void | deleteVoxelAtPoint (const int &point_idx_arg) |
| | Delete leaf node / voxel at given point from input cloud. More...
|
| |
| void | defineBoundingBox () |
| | Investigate dimensions of pointcloud data set and define corresponding bounding box for octree. More...
|
| |
| void | defineBoundingBox (const double min_x_arg, const double min_y_arg, const double min_z_arg, const double max_x_arg, const double max_y_arg, const double max_z_arg) |
| | Define bounding box for octree. More...
|
| |
| void | defineBoundingBox (const double max_x_arg, const double max_y_arg, const double max_z_arg) |
| | Define bounding box for octree. More...
|
| |
| void | defineBoundingBox (const double cubeLen_arg) |
| | Define bounding box cube for octree. More...
|
| |
| void | getBoundingBox (double &min_x_arg, double &min_y_arg, double &min_z_arg, double &max_x_arg, double &max_y_arg, double &max_z_arg) const |
| | Get bounding box for octree. More...
|
| |
| double | getVoxelSquaredDiameter (unsigned int tree_depth_arg) const |
| | Calculates the squared diameter of a voxel at given tree depth. More...
|
| |
| double | getVoxelSquaredDiameter () const |
| | Calculates the squared diameter of a voxel at leaf depth. More...
|
| |
| double | getVoxelSquaredSideLen (unsigned int tree_depth_arg) const |
| | Calculates the squared voxel cube side length at given tree depth. More...
|
| |
| double | getVoxelSquaredSideLen () const |
| | Calculates the squared voxel cube side length at leaf level. More...
|
| |
| void | getVoxelBounds (OctreeIteratorBase< OctreeBase< LeafContainerT, BranchContainerT > > &iterator, Eigen::Vector3f &min_pt, Eigen::Vector3f &max_pt) |
| | Generate bounds of the current voxel of an octree iterator. More...
|
| |
| void | enableDynamicDepth (size_t maxObjsPerLeaf) |
| | Enable dynamic octree structure. More...
|
| |
| Iterator | begin (unsigned int max_depth_arg=0) |
| |
| const Iterator | end () |
| |
| LeafNodeIterator | leaf_begin (unsigned int max_depth_arg=0) |
| |
| const LeafNodeIterator | leaf_end () |
| |
| DepthFirstIterator | depth_begin (unsigned int max_depth_arg=0) |
| |
| const DepthFirstIterator | depth_end () |
| |
| BreadthFirstIterator | breadth_begin (unsigned int max_depth_arg=0) |
| |
| const BreadthFirstIterator | breadth_end () |
| |
| | 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 (unsigned int max_voxel_index_arg) |
| | Set the maximum amount of voxels per dimension. More...
|
| |
| void | setTreeDepth (unsigned int max_depth_arg) |
| | Set the maximum depth of the octree. More...
|
| |
| unsigned int | getTreeDepth () const |
| | Get the maximum depth of the octree. More...
|
| |
| LeafContainerT * | createLeaf (unsigned int idx_x_arg, unsigned int idx_y_arg, unsigned int idx_z_arg) |
| | Create new leaf node at (idx_x_arg, idx_y_arg, idx_z_arg). More...
|
| |
| LeafContainerT * | findLeaf (unsigned int idx_x_arg, unsigned int idx_y_arg, unsigned int idx_z_arg) |
| | Find leaf node at (idx_x_arg, idx_y_arg, idx_z_arg). More...
|
| |
| bool | existLeaf (unsigned int idx_x_arg, unsigned int idx_y_arg, unsigned int 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 (unsigned int idx_x_arg, unsigned int idx_y_arg, unsigned int 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) |
| | 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) |
| | 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...
|
| |
|
| virtual void | addPointIdx (const int pointIdx_arg) |
| | Add point at index from input pointcloud dataset to octree. More...
|
| |
| void | computeNeighbors (OctreeKey &key_arg, LeafContainerT *leaf_container) |
| | Fills in the neighbors fields for new voxels. More...
|
| |
| void | genOctreeKeyforPoint (const PointT &point_arg, OctreeKey &key_arg) const |
| | Generates octree key for specified point (uses transform if provided) More...
|
| |
| void | expandLeafNode (LeafNode *leaf_node, BranchNode *parent_branch, unsigned char child_idx, unsigned int depth_mask) |
| | Add point at index from input pointcloud dataset to octree. More...
|
| |
| const PointT & | getPointByIndex (const unsigned int index_arg) const |
| | Get point at index from input pointcloud dataset. More...
|
| |
| LeafContainerT * | findLeafAtPoint (const PointT &point_arg) const |
| | Find octree leaf node at a given point. More...
|
| |
| void | getKeyBitSize () |
| | Define octree key setting and octree depth based on defined bounding box. More...
|
| |
| void | adoptBoundingBoxToPoint (const PointT &point_idx_arg) |
| | Grow the bounding box/octree until point fits. More...
|
| |
| bool | isPointWithinBoundingBox (const PointT &point_idx_arg) const |
| | Checks if given point is within the bounding box of the octree. More...
|
| |
| void | genOctreeKeyforPoint (const PointT &point_arg, OctreeKey &key_arg) const |
| | Generate octree key for voxel at a given point. More...
|
| |
| void | genOctreeKeyforPoint (const double point_x_arg, const double point_y_arg, const double point_z_arg, OctreeKey &key_arg) const |
| | Generate octree key for voxel at a given point. More...
|
| |
| virtual bool | genOctreeKeyForDataT (const int &data_arg, OctreeKey &key_arg) const |
| | Virtual method for generating octree key for a given point index. More...
|
| |
| void | genLeafNodeCenterFromOctreeKey (const OctreeKey &key_arg, PointT &point_arg) const |
| | Generate a point at center of leaf node voxel. More...
|
| |
| void | genVoxelCenterFromOctreeKey (const OctreeKey &key_arg, unsigned int tree_depth_arg, PointT &point_arg) const |
| | Generate a point at center of octree voxel at given tree level. More...
|
| |
| void | genVoxelBoundsFromOctreeKey (const OctreeKey &key_arg, unsigned int tree_depth_arg, Eigen::Vector3f &min_pt, Eigen::Vector3f &max_pt) const |
| | Generate bounds of an octree voxel using octree key and tree depth arguments. More...
|
| |
| int | getOccupiedVoxelCentersRecursive (const BranchNode *node_arg, const OctreeKey &key_arg, AlignedPointTVector &voxel_center_list_arg) const |
| | Recursively search the tree for all leaf nodes and return a vector of voxel centers. More...
|
| |
| 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 existance 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...
|
| |
| unsigned int | createLeafRecursive (const OctreeKey &key_arg, unsigned int 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, unsigned int 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, unsigned int 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, unsigned int 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...
|
| |
| double | Log2 (double n_arg) |
| | Helper function to calculate the binary logarithm. More...
|
| |
| bool | octreeCanResize () |
| | Test if octree is able to dynamically change its depth. More...
|
| |
template<typename PointT, typename LeafContainerT = OctreePointCloudAdjacencyContainer <PointT>, typename BranchContainerT = OctreeContainerEmpty>
class pcl::octree::OctreePointCloudAdjacency< PointT, LeafContainerT, BranchContainerT >
Octree pointcloud voxel class used for adjacency calculation
- Note
- This pointcloud octree class generate an octree from a point cloud (zero-copy).
-
The octree pointcloud is initialized with its voxel resolution. Its bounding box is automatically adjusted or can be predefined.
-
This class maintains adjacency information for its voxels
-
The OctreePointCloudAdjacencyContainer can be used to store data in leaf nodes
-
An optional transform function can be provided which changes how the voxel grid is computed - this can be used to, for example, make voxel bins larger as they increase in distance from the origin (camera)
-
See SupervoxelClustering for an example of how to provide a transform function
-
If used in academic work, please cite:
J. Papon, A. Abramov, M. Schoeler, F. Woergoetter Voxel Cloud Connectivity Segmentation - Supervoxels from PointClouds In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR) 2013
- Author
- Jeremie Papon (jpapo.nosp@m.n@gm.nosp@m.ail.c.nosp@m.om)
Definition at line 83 of file octree_pointcloud_adjacency.h.