44#include <octomap/octomap.h> 
   55  shared_ptr<const octomap::OcTree> 
tree;
 
   67      : tree(shared_ptr<const octomap::
OcTree>(
 
   68            new octomap::
OcTree(resolution))) {
 
   69    default_occupancy = 
Scalar(tree->getOccupancyThres());
 
   73    occupancy_threshold = 
Scalar(tree->getOccupancyThres());
 
 
   78  explicit OcTree(
const shared_ptr<const octomap::OcTree>& tree_)
 
   80    default_occupancy = 
Scalar(tree->getOccupancyThres());
 
   84    occupancy_threshold = 
Scalar(tree->getOccupancyThres());
 
 
   92        default_occupancy(other.default_occupancy),
 
   93        occupancy_threshold(other.occupancy_threshold),
 
   94        free_threshold(other.free_threshold) {}
 
 
  100  shared_ptr<const octomap::OcTree> 
getTree()
 const { 
return tree; }
 
  106    typedef Eigen::Matrix<float, 3, 1> Vec3float;
 
  107    Vec3float max_extent, min_extent;
 
  109    octomap::OcTree::iterator it =
 
  110        tree->begin((
unsigned char)tree->getTreeDepth());
 
  111    octomap::OcTree::iterator end = tree->end();
 
  113    if (it == end) 
return;
 
  116      const octomap::point3d& coord =
 
  118      max_extent = min_extent = Eigen::Map<const Vec3float>(&coord.x());
 
  119      for (++it; it != end; ++it) {
 
  120        const octomap::point3d& coord = it.getCoordinate();
 
  121        const Vec3float pos = Eigen::Map<const Vec3float>(&coord.x());
 
  122        max_extent = max_extent.array().max(pos.array());
 
  123        min_extent = min_extent.array().min(pos.array());
 
  128    const Scalar resolution = 
Scalar(tree->getResolution());
 
  129    max_extent.array() += float(resolution / 2.);
 
  130    min_extent.array() -= float(resolution / 2.);
 
  133    aabb_center = aabb_local.center();
 
  134    aabb_radius = (aabb_local.min_ - aabb_center).norm();
 
 
  140        Scalar((1 << tree->getTreeDepth()) * tree->getResolution() / 2);
 
  143    return AABB(
Vec3s(-delta, -delta, -delta), 
Vec3s(delta, delta, delta));
 
 
  150  unsigned long size()
 const { 
return tree->size(); }
 
  161    return node->getOccupancy() >= occupancy_threshold;
 
 
  167    return node->getOccupancy() <= free_threshold;
 
 
  172    return (!isNodeOccupied(node)) && (!isNodeFree(node));
 
 
  179    std::vector<Vec6s> boxes;
 
  180    boxes.reserve(tree->size() / 2);
 
  181    for (octomap::OcTree::iterator
 
  182             it = tree->begin((
unsigned char)tree->getTreeDepth()),
 
  186      if (isNodeOccupied(&*it)) {
 
  195        box << x, y, z, size, c, t;
 
  196        boxes.push_back(box);
 
 
  204    typedef Eigen::Matrix<float, 3, 1> Vec3sloat;
 
  205    const size_t total_size = (tree->size() * 
sizeof(
Scalar) * 3) / 2;
 
  206    std::vector<uint8_t> bytes;
 
  207    bytes.reserve(total_size);
 
  209    for (octomap::OcTree::iterator
 
  210             it = tree->begin((
unsigned char)tree->getTreeDepth()),
 
  213      const Vec3s box_pos =
 
  214          Eigen::Map<Vec3sloat>(&it.getCoordinate().x()).cast<
Scalar>();
 
  215      if (isNodeOccupied(&*it))
 
  216        std::copy(box_pos.data(), box_pos.data() + 
sizeof(
Scalar) * 3,
 
  217                  std::back_inserter(bytes));
 
 
  241#if OCTOMAP_VERSION_AT_LEAST(1, 8, 0) 
  242    return tree->getNodeChild(node, childIdx);
 
  244    return node->getChild(childIdx);
 
 
  250                                 unsigned int childIdx)
 const {
 
  251#if OCTOMAP_VERSION_AT_LEAST(1, 8, 0) 
  252    return tree->getNodeChild(node, childIdx);
 
  254    return node->getChild(childIdx);
 
 
  260#if OCTOMAP_VERSION_AT_LEAST(1, 8, 0) 
  261    return tree->nodeChildExists(node, childIdx);
 
  263    return node->childExists(childIdx);
 
 
  269#if OCTOMAP_VERSION_AT_LEAST(1, 8, 0) 
  270    return tree->nodeHasChildren(node);
 
  272    return node->hasChildren();
 
 
  284    const OcTree* other_ptr = 
dynamic_cast<const OcTree*
>(&_other);
 
  285    if (other_ptr == 
nullptr) 
return false;
 
  286    const OcTree& other = *other_ptr;
 
  288    return (tree.get() == other.
tree.get() || toBoxes() == other.
toBoxes()) &&
 
  295  EIGEN_MAKE_ALIGNED_OPERATOR_NEW
 
 
  299static inline void computeChildBV(
const AABB& root_bv, 
unsigned int i,
 
  303    child_bv.min_[0] = (root_bv.min_[0] + root_bv.max_[0]) * half;
 
  304    child_bv.max_[0] = root_bv.max_[0];
 
  306    child_bv.min_[0] = root_bv.min_[0];
 
  307    child_bv.max_[0] = (root_bv.min_[0] + root_bv.max_[0]) * half;
 
  311    child_bv.min_[1] = (root_bv.min_[1] + root_bv.max_[1]) * half;
 
  312    child_bv.max_[1] = root_bv.max_[1];
 
  314    child_bv.min_[1] = root_bv.min_[1];
 
  315    child_bv.max_[1] = (root_bv.min_[1] + root_bv.max_[1]) * half;
 
  319    child_bv.min_[2] = (root_bv.min_[2] + root_bv.max_[2]) * half;
 
  320    child_bv.max_[2] = root_bv.max_[2];
 
  322    child_bv.min_[2] = root_bv.min_[2];
 
  323    child_bv.max_[2] = (root_bv.min_[2] + root_bv.max_[2]) * half;
 
  336makeOctree(
const Eigen::Matrix<Scalar, Eigen::Dynamic, 3>& point_cloud,
 
A class describing the AABB collision structure, which is a box in 3D space determined by two diagona...
Definition AABB.h:55
The geometry for the object for collision or distance computation.
Definition collision_object.h:96
Octree is one type of collision geometry which can encode uncertainty information in the sensor data.
Definition octree.h:53
void setFreeThres(Scalar d)
Definition octree.h:237
Scalar getDefaultOccupancy() const
Definition octree.h:231
Scalar getResolution() const
Returns the resolution of the octree.
Definition octree.h:153
OBJECT_TYPE getObjectType() const
return object type, it is an octree
Definition octree.h:277
std::vector< Vec6s > toBoxes() const
transform the octree into a bunch of boxes; uncertainty information is kept in the boxes....
Definition octree.h:178
bool nodeChildExists(const OcTreeNode *node, unsigned int childIdx) const
return true if the child at childIdx exists
Definition octree.h:259
AABB getRootBV() const
get the bounding volume for the root
Definition octree.h:138
OcTree(const OcTree &other)
 
Definition octree.h:89
Scalar default_occupancy
Definition octree.h:57
void computeLocalAABB()
compute the AABB for the octree in its local coordinate system
Definition octree.h:105
void setCellDefaultOccupancy(Scalar d)
Definition octree.h:233
Scalar getOccupancyThres() const
the threshold used to decide whether one node is occupied, this is NOT the octree occupied_thresold
Definition octree.h:225
void exportAsObjFile(const std::string &filename) const
OcTreeNode * getNodeChild(OcTreeNode *node, unsigned int childIdx)
Definition octree.h:240
OcTree(Scalar resolution)
construct octree with a given resolution
Definition octree.h:66
shared_ptr< const octomap::OcTree > getTree() const
Returns the tree associated to the underlying octomap OcTree.
Definition octree.h:100
shared_ptr< const octomap::OcTree > tree
Definition octree.h:55
OcTree * clone() const
Clone *this into a new Octree.
Definition octree.h:97
void setOccupancyThres(Scalar d)
Definition octree.h:235
OcTreeNode * getRoot() const
get the root node of the octree
Definition octree.h:156
Scalar getFreeThres() const
the threshold used to decide whether one node is free, this is NOT the octree free_threshold
Definition octree.h:229
unsigned int getTreeDepth() const
Returns the depth of the octree.
Definition octree.h:147
const OcTreeNode * getNodeChild(const OcTreeNode *node, unsigned int childIdx) const
Definition octree.h:249
Scalar free_threshold
Definition octree.h:60
bool nodeHasChildren(const OcTreeNode *node) const
return true if node has at least one child
Definition octree.h:268
bool isNodeUncertain(const OcTreeNode *node) const
whether one node is uncertain
Definition octree.h:171
OcTree(const shared_ptr< const octomap::OcTree > &tree_)
construct octree from octomap
Definition octree.h:78
unsigned long size() const
Returns the size of the octree.
Definition octree.h:150
octomap::OcTreeNode OcTreeNode
Definition octree.h:63
Scalar occupancy_threshold
Definition octree.h:59
bool isNodeFree(const OcTreeNode *node) const
whether one node is completely free
Definition octree.h:165
NODE_TYPE getNodeType() const
return node type, it is an octree
Definition octree.h:280
std::vector< uint8_t > tobytes() const
Returns a byte description of *this.
Definition octree.h:203
bool isNodeOccupied(const OcTreeNode *node) const
whether one node is completely occupied
Definition octree.h:159
#define COAL_DLLAPI
Definition config.hh:88
@ GEOM_OCTREE
Definition collision_object.h:85
@ OT_OCTREE
Definition collision_object.h:56
Main namespace.
Definition broadphase_bruteforce.h:44
OcTreePtr_t makeOctree(const Eigen::Matrix< Scalar, Eigen::Dynamic, 3 > &point_cloud, const Scalar resolution)
Build an OcTree from a point cloud and a given resolution.
NODE_TYPE
traversal node type: bounding volume (AABB, OBB, RSS, kIOS, OBBRSS, KDOP16, KDOP18,...
Definition collision_object.h:64
shared_ptr< OcTree > OcTreePtr_t
Definition fwd.hh:144
Eigen::Matrix< Scalar, 3, 1 > Vec3s
Definition data_types.h:70
double Scalar
Definition data_types.h:68
OBJECT_TYPE
object type: BVH (mesh, points), basic geometry, octree
Definition collision_object.h:52
bool isEqual(const Eigen::MatrixBase< Derived > &lhs, const Eigen::MatrixBase< OtherDerived > &rhs, const Scalar tol=std::numeric_limits< Scalar >::epsilon() *100)
Definition tools.h:204
Eigen::Matrix< Scalar, 6, 1 > Vec6s
Definition data_types.h:72