Collision manager based on interval tree. More...
#include <broadphase_interval_tree.h>
Classes | |
struct | EndPoint |
SAP end point. More... | |
struct | SAPInterval |
Extention interval tree's interval to SAP interval, adding more information. More... | |
Public Member Functions | |
void | clear () |
clear the manager | |
void | collide (CollisionObject *obj, void *cdata, CollisionCallBack callback) const |
perform collision test between one object and all the objects belonging to the manager | |
void | collide (void *cdata, CollisionCallBack callback) const |
perform collision test for the objects belonging to the manager (i.e., N^2 self collision) | |
void | collide (BroadPhaseCollisionManager *other_manager, void *cdata, CollisionCallBack callback) const |
perform collision test with objects belonging to another manager | |
void | distance (CollisionObject *obj, void *cdata, DistanceCallBack callback) const |
perform distance computation between one object and all the objects belonging to the manager | |
void | distance (void *cdata, DistanceCallBack callback) const |
perform distance test for the objects belonging to the manager (i.e., N^2 self distance) | |
void | distance (BroadPhaseCollisionManager *other_manager, void *cdata, DistanceCallBack callback) const |
perform distance test with objects belonging to another manager | |
bool | empty () const |
whether the manager is empty | |
void | getObjects (std::vector< CollisionObject * > &objs) const |
return the objects managed by the manager | |
IntervalTreeCollisionManager () | |
void | registerObject (CollisionObject *obj) |
remove one object from the manager | |
void | setup () |
initialize the manager, related with the specific type of manager | |
size_t | size () const |
the number of objects managed by the manager | |
void | unregisterObject (CollisionObject *obj) |
add one object to the manager | |
void | update () |
update the condition of manager | |
void | update (CollisionObject *updated_obj) |
update the manager by explicitly given the object updated | |
void | update (const std::vector< CollisionObject * > &updated_objs) |
update the manager by explicitly given the set of objects update | |
~IntervalTreeCollisionManager () | |
Protected Member Functions | |
bool | checkColl (std::deque< SimpleInterval * >::const_iterator pos_start, std::deque< SimpleInterval * >::const_iterator pos_end, CollisionObject *obj, void *cdata, CollisionCallBack callback) const |
bool | checkDist (std::deque< SimpleInterval * >::const_iterator pos_start, std::deque< SimpleInterval * >::const_iterator pos_end, CollisionObject *obj, void *cdata, DistanceCallBack callback, FCL_REAL &min_dist) const |
bool | collide_ (CollisionObject *obj, void *cdata, CollisionCallBack callback) const |
bool | distance_ (CollisionObject *obj, void *cdata, DistanceCallBack callback, FCL_REAL &min_dist) const |
Protected Attributes | |
std::vector< EndPoint > | endpoints [3] |
vector stores all the end points | |
IntervalTree * | interval_trees [3] |
interval tree manages the intervals | |
std::map< CollisionObject *, SAPInterval * > | obj_interval_maps [3] |
bool | setup_ |
tag for whether the interval tree is maintained suitably |
Collision manager based on interval tree.
Definition at line 49 of file broadphase_interval_tree.h.
Definition at line 52 of file broadphase_interval_tree.h.
Definition at line 58 of file broadphase_interval_tree.h.
bool fcl::IntervalTreeCollisionManager::checkColl | ( | std::deque< SimpleInterval * >::const_iterator | pos_start, |
std::deque< SimpleInterval * >::const_iterator | pos_end, | ||
CollisionObject * | obj, | ||
void * | cdata, | ||
CollisionCallBack | callback | ||
) | const [protected] |
Definition at line 598 of file broadphase_interval_tree.cpp.
bool fcl::IntervalTreeCollisionManager::checkDist | ( | std::deque< SimpleInterval * >::const_iterator | pos_start, |
std::deque< SimpleInterval * >::const_iterator | pos_end, | ||
CollisionObject * | obj, | ||
void * | cdata, | ||
DistanceCallBack | callback, | ||
FCL_REAL & | min_dist | ||
) | const [protected] |
Definition at line 618 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::clear | ( | ) | [virtual] |
clear the manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 298 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::collide | ( | CollisionObject * | obj, |
void * | cdata, | ||
CollisionCallBack | callback | ||
) | const [virtual] |
perform collision test between one object and all the objects belonging to the manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 336 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::collide | ( | void * | cdata, |
CollisionCallBack | callback | ||
) | const [virtual] |
perform collision test for the objects belonging to the manager (i.e., N^2 self collision)
Implements fcl::BroadPhaseCollisionManager.
Definition at line 471 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::collide | ( | BroadPhaseCollisionManager * | other_manager, |
void * | cdata, | ||
CollisionCallBack | callback | ||
) | const [virtual] |
perform collision test with objects belonging to another manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 543 of file broadphase_interval_tree.cpp.
bool fcl::IntervalTreeCollisionManager::collide_ | ( | CollisionObject * | obj, |
void * | cdata, | ||
CollisionCallBack | callback | ||
) | const [protected] |
Definition at line 342 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::distance | ( | CollisionObject * | obj, |
void * | cdata, | ||
DistanceCallBack | callback | ||
) | const [virtual] |
perform distance computation between one object and all the objects belonging to the manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 378 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::distance | ( | void * | cdata, |
DistanceCallBack | callback | ||
) | const [virtual] |
perform distance test for the objects belonging to the manager (i.e., N^2 self distance)
Implements fcl::BroadPhaseCollisionManager.
Definition at line 528 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::distance | ( | BroadPhaseCollisionManager * | other_manager, |
void * | cdata, | ||
DistanceCallBack | callback | ||
) | const [virtual] |
perform distance test with objects belonging to another manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 567 of file broadphase_interval_tree.cpp.
bool fcl::IntervalTreeCollisionManager::distance_ | ( | CollisionObject * | obj, |
void * | cdata, | ||
DistanceCallBack | callback, | ||
FCL_REAL & | min_dist | ||
) | const [protected] |
Definition at line 385 of file broadphase_interval_tree.cpp.
bool fcl::IntervalTreeCollisionManager::empty | ( | ) | const [virtual] |
whether the manager is empty
Implements fcl::BroadPhaseCollisionManager.
Definition at line 593 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::getObjects | ( | std::vector< CollisionObject * > & | objs | ) | const [virtual] |
return the objects managed by the manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 323 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::registerObject | ( | CollisionObject * | obj | ) | [virtual] |
remove one object from the manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 151 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::setup | ( | ) | [virtual] |
initialize the manager, related with the specific type of manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 176 of file broadphase_interval_tree.cpp.
size_t fcl::IntervalTreeCollisionManager::size | ( | ) | const [inline, virtual] |
the number of objects managed by the manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 109 of file broadphase_interval_tree.h.
void fcl::IntervalTreeCollisionManager::unregisterObject | ( | CollisionObject * | obj | ) | [virtual] |
add one object to the manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 45 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::update | ( | ) | [virtual] |
update the condition of manager
Implements fcl::BroadPhaseCollisionManager.
Definition at line 214 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::update | ( | CollisionObject * | updated_obj | ) | [virtual] |
update the manager by explicitly given the object updated
Reimplemented from fcl::BroadPhaseCollisionManager.
Definition at line 247 of file broadphase_interval_tree.cpp.
void fcl::IntervalTreeCollisionManager::update | ( | const std::vector< CollisionObject * > & | updated_objs | ) | [virtual] |
update the manager by explicitly given the set of objects update
Reimplemented from fcl::BroadPhaseCollisionManager.
Definition at line 292 of file broadphase_interval_tree.cpp.
std::vector<EndPoint> fcl::IntervalTreeCollisionManager::endpoints[3] [protected] |
vector stores all the end points
Definition at line 149 of file broadphase_interval_tree.h.
IntervalTree* fcl::IntervalTreeCollisionManager::interval_trees[3] [protected] |
interval tree manages the intervals
Definition at line 152 of file broadphase_interval_tree.h.
std::map<CollisionObject*, SAPInterval*> fcl::IntervalTreeCollisionManager::obj_interval_maps[3] [protected] |
Definition at line 154 of file broadphase_interval_tree.h.
bool fcl::IntervalTreeCollisionManager::setup_ [protected] |
tag for whether the interval tree is maintained suitably
Definition at line 157 of file broadphase_interval_tree.h.