| Directory: | ./ | 
|---|---|
| File: | include/pinocchio/collision/broadphase.hpp | 
| Date: | 2025-02-12 21:03:38 | 
| Exec | Total | Coverage | |
|---|---|---|---|
| Lines: | 13 | 17 | 76.5% | 
| Branches: | 5 | 12 | 41.7% | 
| Line | Branch | Exec | Source | 
|---|---|---|---|
| 1 | // | ||
| 2 | // Copyright (c) 2022 INRIA | ||
| 3 | // | ||
| 4 | |||
| 5 | #ifndef __pinocchio_collision_broadphase_hpp__ | ||
| 6 | #define __pinocchio_collision_broadphase_hpp__ | ||
| 7 | |||
| 8 | #include <hpp/fcl/broadphase/broadphase_collision_manager.h> | ||
| 9 | |||
| 10 | #include "pinocchio/multibody/fcl.hpp" | ||
| 11 | |||
| 12 | #include "pinocchio/algorithm/geometry.hpp" | ||
| 13 | |||
| 14 | #include "pinocchio/collision/broadphase-manager.hpp" | ||
| 15 | #include "pinocchio/collision/broadphase-callbacks.hpp" | ||
| 16 | |||
| 17 | namespace pinocchio | ||
| 18 | { | ||
| 19 | |||
| 20 | /// | ||
| 21 | /// \brief Calls computeCollision for every active pairs of GeometryData. | ||
| 22 | /// This function assumes that \ref updateGeometryPlacements and broadphase_manager.update() have | ||
| 23 | /// been called first. | ||
| 24 | /// | ||
| 25 | /// \param[in] broadphase_manager broadphase instance for collision detection. | ||
| 26 | /// \param[in] callback callback pointer used for collision detection. | ||
| 27 | /// \param[in] stopAtFirstCollision if true, stop the loop over the collision pairs when the first | ||
| 28 | /// collision is detected. | ||
| 29 | /// | ||
| 30 | /// \warning if stopAtFirstcollision = true, then the collisions vector will | ||
| 31 | /// not be entirely fulfilled (of course). | ||
| 32 | /// | ||
| 33 | template<typename BroadPhaseManagerDerived> | ||
| 34 | 2008 | bool computeCollisions( | |
| 35 | BroadPhaseManagerBase<BroadPhaseManagerDerived> & broadphase_manager, | ||
| 36 | CollisionCallBackBase * callback) | ||
| 37 | { | ||
| 38 | 1/4✗ Branch 1 not taken. ✓ Branch 2 taken 2008 times. ✗ Branch 5 not taken. ✗ Branch 6 not taken. | 2008 | PINOCCHIO_CHECK_INPUT_ARGUMENT(broadphase_manager.check(callback)); | 
| 39 | 2008 | broadphase_manager.collide(callback); | |
| 40 | 2008 | callback->done(); | |
| 41 | 2008 | return callback->collision; | |
| 42 | } | ||
| 43 | |||
| 44 | /// | ||
| 45 | /// \brief Calls computeCollision for every active pairs of GeometryData. | ||
| 46 | /// This function assumes that \ref updateGeometryPlacements and broadphase_manager.update() have | ||
| 47 | /// been called first. | ||
| 48 | /// | ||
| 49 | /// \param[in] broadphase_manager broadphase instance for collision detection. | ||
| 50 | /// \param[in] stopAtFirstCollision if true, stop the loop over the collision pairs when the first | ||
| 51 | /// collision is detected. | ||
| 52 | /// | ||
| 53 | /// \warning if stopAtFirstcollision = true, then the collisions vector will | ||
| 54 | /// not be entirely fulfilled (of course). | ||
| 55 | /// | ||
| 56 | template<typename BroadPhaseManagerDerived> | ||
| 57 | 4 | bool computeCollisions( | |
| 58 | BroadPhaseManagerBase<BroadPhaseManagerDerived> & broadphase_manager, | ||
| 59 | const bool stopAtFirstCollision = false) | ||
| 60 | { | ||
| 61 | 4 | CollisionCallBackDefault callback( | |
| 62 | broadphase_manager.getGeometryModel(), broadphase_manager.getGeometryData(), | ||
| 63 | stopAtFirstCollision); | ||
| 64 | |||
| 65 | 1/2✓ Branch 1 taken 4 times. ✗ Branch 2 not taken. | 8 | return computeCollisions(broadphase_manager, &callback); | 
| 66 | } | ||
| 67 | |||
| 68 | /// | ||
| 69 | /// Compute the forward kinematics, update the geometry placements and run the collision detection | ||
| 70 | /// using the broadphase manager. | ||
| 71 | /// | ||
| 72 | /// \tparam JointCollection Collection of Joint types. | ||
| 73 | /// \tparam ConfigVectorType Type of the joint configuration vector. | ||
| 74 | /// | ||
| 75 | /// \param[in] model robot model (const) | ||
| 76 | /// \param[out] data corresponding data (nonconst) where the forward kinematics results are stored | ||
| 77 | /// \param[in] broadphase_manager broadphase manager for collision detection. | ||
| 78 | /// \param[in] callback callback pointer used for collision detection./// | ||
| 79 | /// \param[in] q robot configuration. | ||
| 80 | /// \param[in] stopAtFirstCollision if true, stop the loop over the collision pairs when the first | ||
| 81 | /// collision is detected. | ||
| 82 | /// | ||
| 83 | /// \warning if stopAtFirstcollision = true, then the collisions vector will | ||
| 84 | /// not be entirely fulfilled (of course). | ||
| 85 | /// \note A similar function is available without model, data and q, not recomputing the forward | ||
| 86 | /// kinematics. | ||
| 87 | /// | ||
| 88 | template< | ||
| 89 | typename Scalar, | ||
| 90 | int Options, | ||
| 91 | template<typename, int> class JointCollectionTpl, | ||
| 92 | typename BroadPhaseManagerDerived, | ||
| 93 | typename ConfigVectorType> | ||
| 94 | ✗ | inline bool computeCollisions( | |
| 95 | const ModelTpl<Scalar, Options, JointCollectionTpl> & model, | ||
| 96 | DataTpl<Scalar, Options, JointCollectionTpl> & data, | ||
| 97 | BroadPhaseManagerBase<BroadPhaseManagerDerived> & broadphase_manager, | ||
| 98 | CollisionCallBackBase * callback, | ||
| 99 | const Eigen::MatrixBase<ConfigVectorType> & q) | ||
| 100 | { | ||
| 101 | ✗ | updateGeometryPlacements( | |
| 102 | model, data, broadphase_manager.getGeometryModel(), broadphase_manager.getGeometryData(), q); | ||
| 103 | |||
| 104 | ✗ | broadphase_manager.update(false); | |
| 105 | ✗ | return computeCollisions(broadphase_manager, &callback); | |
| 106 | } | ||
| 107 | |||
| 108 | /// | ||
| 109 | /// Compute the forward kinematics, update the geometry placements and run the collision detection | ||
| 110 | /// using the broadphase manager. | ||
| 111 | /// | ||
| 112 | /// \tparam JointCollection Collection of Joint types. | ||
| 113 | /// \tparam ConfigVectorType Type of the joint configuration vector. | ||
| 114 | /// | ||
| 115 | /// \param[in] model robot model (const) | ||
| 116 | /// \param[out] data corresponding data (nonconst) where the forward kinematics results are stored | ||
| 117 | /// \param[in] broadphase_manager broadphase manager for collision detection. | ||
| 118 | /// \param[in] q robot configuration. | ||
| 119 | /// \param[in] stopAtFirstCollision if true, stop the loop over the collision pairs when the first | ||
| 120 | /// collision is detected. | ||
| 121 | /// | ||
| 122 | /// \warning if stopAtFirstcollision = true, then the collisions vector will | ||
| 123 | /// not be entirely fulfilled (of course). | ||
| 124 | /// \note A similar function is available without model, data and q, not recomputing the forward | ||
| 125 | /// kinematics. | ||
| 126 | /// | ||
| 127 | template< | ||
| 128 | typename Scalar, | ||
| 129 | int Options, | ||
| 130 | template<typename, int> class JointCollectionTpl, | ||
| 131 | typename BroadPhaseManagerDerived, | ||
| 132 | typename ConfigVectorType> | ||
| 133 | 2004 | inline bool computeCollisions( | |
| 134 | const ModelTpl<Scalar, Options, JointCollectionTpl> & model, | ||
| 135 | DataTpl<Scalar, Options, JointCollectionTpl> & data, | ||
| 136 | BroadPhaseManagerBase<BroadPhaseManagerDerived> & broadphase_manager, | ||
| 137 | const Eigen::MatrixBase<ConfigVectorType> & q, | ||
| 138 | const bool stopAtFirstCollision = false) | ||
| 139 | { | ||
| 140 | 1/2✓ Branch 3 taken 2004 times. ✗ Branch 4 not taken. | 2004 | updateGeometryPlacements( | 
| 141 | model, data, broadphase_manager.getGeometryModel(), broadphase_manager.getGeometryData(), q); | ||
| 142 | |||
| 143 | 1/2✓ Branch 1 taken 2004 times. ✗ Branch 2 not taken. | 2004 | broadphase_manager.update(false); | 
| 144 | |||
| 145 | 2004 | CollisionCallBackDefault callback( | |
| 146 | broadphase_manager.getGeometryModel(), broadphase_manager.getGeometryData(), | ||
| 147 | stopAtFirstCollision); | ||
| 148 | 1/2✓ Branch 1 taken 2004 times. ✗ Branch 2 not taken. | 4008 | return computeCollisions(broadphase_manager, &callback); | 
| 149 | } | ||
| 150 | |||
| 151 | } // namespace pinocchio | ||
| 152 | |||
| 153 | /* --- Details -------------------------------------------------------------------- */ | ||
| 154 | #include "pinocchio/collision/broadphase.hxx" | ||
| 155 | |||
| 156 | #endif // ifndef __pinocchio_collision_broadphase_hpp__ | ||
| 157 |