User2InternalIndex.hpp 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. #ifndef USER2INTERNALINDEX_HPP
  2. #define USER2INTERNALINDEX_HPP
  3. #include <map>
  4. #include <vector>
  5. #include "BulletInverseDynamics/IDConfig.hpp"
  6. namespace btInverseDynamics
  7. {
  8. /// Convert arbitrary indexing scheme to internal indexing
  9. /// used for MultiBodyTree
  10. class User2InternalIndex
  11. {
  12. public:
  13. /// Ctor
  14. User2InternalIndex();
  15. /// add body to index maps
  16. /// @param body index of body to add (external)
  17. /// @param parent index of parent body (external)
  18. void addBody(const int body, const int parent);
  19. /// build mapping from external to internal indexing
  20. /// @return 0 on success, -1 on failure
  21. int buildMapping();
  22. /// get internal index from external index
  23. /// @param user external (user) index
  24. /// @param internal pointer for storage of corresponding internal index
  25. /// @return 0 on success, -1 on failure
  26. int user2internal(const int user, int *internal) const;
  27. /// get internal index from external index
  28. /// @param user external (user) index
  29. /// @param internal pointer for storage of corresponding internal index
  30. /// @return 0 on success, -1 on failure
  31. int internal2user(const int internal, int *user) const;
  32. private:
  33. int findRoot(int index);
  34. void recurseIndexSets(const int user_body_index);
  35. bool m_map_built;
  36. std::map<int, int> m_user_parent_index_map;
  37. std::map<int, int> m_user_to_internal;
  38. std::map<int, int> m_internal_to_user;
  39. std::map<int, std::vector<int> > m_user_child_indices;
  40. int m_current_index;
  41. };
  42. } // namespace btInverseDynamics
  43. #endif // USER2INTERNALINDEX_HPP