edge_topology.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. // This file is part of libigl, a simple c++ geometry processing library.
  2. //
  3. // Copyright (C) 2013 Alec Jacobson <alecjacobson@gmail.com>
  4. //
  5. // This Source Code Form is subject to the terms of the Mozilla Public License
  6. // v. 2.0. If a copy of the MPL was not distributed with this file, You can
  7. // obtain one at http://mozilla.org/MPL/2.0/.
  8. #ifndef IGL_EDGE_TOPOLOGY_H
  9. #define IGL_EDGE_TOPOLOGY_H
  10. #include "igl_inline.h"
  11. #include <Eigen/Core>
  12. #include <vector>
  13. namespace igl
  14. {
  15. // Initialize Edges and their topological relations (assumes an edge-manifold
  16. // mesh)
  17. //
  18. // Inputs:
  19. // V #V by dim list of mesh vertex positions (unused)
  20. // F #F by 3 list of triangle indices into V
  21. // Outputs:
  22. // EV #Ex2 matrix storing the edge description as pair of indices to
  23. // vertices
  24. // FE #Fx3 matrix storing the Triangle-Edge relation
  25. // EF #Ex2 matrix storing the Edge-Triangle relation
  26. //
  27. // TODO: This seems to be a inferior duplicate of edge_flaps.h:
  28. // - unused input parameter V
  29. // - roughly 2x slower than edge_flaps
  30. // - outputs less information: edge_flaps reveals corner opposite edge
  31. // - FE uses non-standard and ambiguous order: FE(f,c) is merely an edge
  32. // incident on corner c of face f. In contrast, edge_flaps's EMAP(f,c)
  33. // reveals the edge _opposite_ corner c of face f
  34. template <typename DerivedV, typename DerivedF>
  35. IGL_INLINE void edge_topology(
  36. const Eigen::PlainObjectBase<DerivedV>& V,
  37. const Eigen::PlainObjectBase<DerivedF>& F,
  38. Eigen::MatrixXi& EV,
  39. Eigen::MatrixXi& FE,
  40. Eigen::MatrixXi& EF);
  41. }
  42. #ifndef IGL_STATIC_LIBRARY
  43. # include "edge_topology.cpp"
  44. #endif
  45. #endif