Traversal node for collision between BVH models. More...
#include <hpp/fcl/traversal/traversal_node_bvhs.h>
Public Member Functions | |
BVHCollisionTraversalNode (bool enable_distance_lower_bound) | |
bool | isFirstNodeLeaf (int b) const |
Whether the BV node in the first BVH tree is leaf. More... | |
bool | isSecondNodeLeaf (int b) const |
Whether the BV node in the second BVH tree is leaf. More... | |
bool | firstOverSecond (int b1, int b2) const |
Determine the traversal order, is the first BVTT subtree better. More... | |
int | getFirstLeftChild (int b) const |
Obtain the left child of BV node in the first BVH. More... | |
int | getFirstRightChild (int b) const |
Obtain the right child of BV node in the first BVH. More... | |
int | getSecondLeftChild (int b) const |
Obtain the left child of BV node in the second BVH. More... | |
int | getSecondRightChild (int b) const |
Obtain the right child of BV node in the second BVH. More... | |
bool | BVTesting (int b1, int b2) const |
BV culling test in one BVTT node. More... | |
bool | BVTesting (int b1, int b2, FCL_REAL &sqrDistLowerBound) const |
BV test between b1 and b2. More... | |
![]() | |
CollisionTraversalNodeBase (bool enable_distance_lower_bound_=false) | |
virtual | ~CollisionTraversalNodeBase () |
virtual void | leafTesting (int b1, int b2, FCL_REAL &sqrDistLowerBound) const |
Leaf test between node b1 and b2, if they are both leafs. More... | |
virtual bool | canStop () const |
Check whether the traversal can stop. More... | |
void | enableStatistics (bool enable) |
Whether store some statistics information during traversal. More... | |
![]() | |
virtual | ~TraversalNodeBase () |
virtual void | preprocess () |
virtual void | postprocess () |
Public Attributes | |
const BVHModel< BV > * | model1 |
The first BVH model. More... | |
const BVHModel< BV > * | model2 |
The second BVH model. More... | |
int | num_bv_tests |
statistical information More... | |
int | num_leaf_tests |
FCL_REAL | query_time_seconds |
![]() | |
CollisionRequest | request |
request setting for collision More... | |
CollisionResult * | result |
collision result kept during the traversal iteration More... | |
bool | enable_statistics |
Whether stores statistics. More... | |
bool | enable_distance_lower_bound |
Whether to compute a lower bound on distance between bounding volumes. More... | |
![]() | |
Transform3f | tf1 |
configuation of first object More... | |
Transform3f | tf2 |
configuration of second object More... | |
Traversal node for collision between BVH models.
|
inline |
|
inlinevirtual |
BV culling test in one BVTT node.
Implements fcl::CollisionTraversalNodeBase.
|
inlinevirtual |
BV test between b1 and b2.
b1,b2 | Bounding volumes to test, |
sqrDistLowerBound | square of a lower bound of the minimal distance between bounding volumes. |
Implements fcl::CollisionTraversalNodeBase.
|
inlinevirtual |
Determine the traversal order, is the first BVTT subtree better.
Reimplemented from fcl::TraversalNodeBase.
|
inlinevirtual |
Obtain the left child of BV node in the first BVH.
Reimplemented from fcl::TraversalNodeBase.
|
inlinevirtual |
Obtain the right child of BV node in the first BVH.
Reimplemented from fcl::TraversalNodeBase.
|
inlinevirtual |
Obtain the left child of BV node in the second BVH.
Reimplemented from fcl::TraversalNodeBase.
|
inlinevirtual |
Obtain the right child of BV node in the second BVH.
Reimplemented from fcl::TraversalNodeBase.
|
inlinevirtual |
Whether the BV node in the first BVH tree is leaf.
Reimplemented from fcl::TraversalNodeBase.
|
inlinevirtual |
Whether the BV node in the second BVH tree is leaf.
Reimplemented from fcl::TraversalNodeBase.
const BVHModel<BV>* fcl::BVHCollisionTraversalNode< BV >::model1 |
The first BVH model.
Referenced by fcl::BVHCollisionTraversalNode< OBBRSS >::BVHCollisionTraversalNode(), fcl::BVHCollisionTraversalNode< OBBRSS >::BVTesting(), fcl::BVHCollisionTraversalNode< OBBRSS >::firstOverSecond(), fcl::BVHCollisionTraversalNode< OBBRSS >::getFirstLeftChild(), fcl::BVHCollisionTraversalNode< OBBRSS >::getFirstRightChild(), fcl::initialize(), fcl::BVHCollisionTraversalNode< OBBRSS >::isFirstNodeLeaf(), fcl::MeshCollisionTraversalNode< OBBRSS >::leafTesting(), and fcl::MeshContinuousCollisionTraversalNode< BV >::leafTesting().
const BVHModel<BV>* fcl::BVHCollisionTraversalNode< BV >::model2 |
The second BVH model.
Referenced by fcl::BVHCollisionTraversalNode< OBBRSS >::BVHCollisionTraversalNode(), fcl::BVHCollisionTraversalNode< OBBRSS >::BVTesting(), fcl::BVHCollisionTraversalNode< OBBRSS >::firstOverSecond(), fcl::BVHCollisionTraversalNode< OBBRSS >::getSecondLeftChild(), fcl::BVHCollisionTraversalNode< OBBRSS >::getSecondRightChild(), fcl::initialize(), fcl::BVHCollisionTraversalNode< OBBRSS >::isSecondNodeLeaf(), fcl::MeshCollisionTraversalNode< OBBRSS >::leafTesting(), and fcl::MeshContinuousCollisionTraversalNode< BV >::leafTesting().
|
mutable |
statistical information
Referenced by fcl::BVHCollisionTraversalNode< OBBRSS >::BVHCollisionTraversalNode(), and fcl::BVHCollisionTraversalNode< OBBRSS >::BVTesting().
|
mutable |
|
mutable |