circulation.cpp 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. #include <test_common.h>
  2. #include <igl/circulation.h>
  3. #include <igl/edge_flaps.h>
  4. #include <igl/unique_edge_map.h>
  5. #include <igl/matlab_format.h>
  6. TEST(circulation,single_edge)
  7. {
  8. // 7
  9. // /₆|₇\
  10. // 4 - 5 - 6
  11. // |₂/₃|₄\₅|
  12. // 1 - 2 - 3
  13. // \₀|₁/
  14. // 0
  15. const Eigen::MatrixXi F = (Eigen::MatrixXi(8,3)<<
  16. 0,2,1,
  17. 0,3,2,
  18. 1,5,4,
  19. 1,2,5,
  20. 2,3,5,
  21. 3,6,5,
  22. 4,5,7,
  23. 5,6,7).finished();
  24. Eigen::MatrixXi E,uE;
  25. Eigen::VectorXi EMAP;
  26. std::vector<std::vector<int> > uE2E;
  27. igl::unique_edge_map(F, E, uE, EMAP, uE2E);
  28. Eigen::MatrixXi EI,EF;
  29. {
  30. const auto & cuE = uE;
  31. const auto & cEMAP = EMAP;
  32. igl::edge_flaps(F,cuE,cEMAP,EF,EI);
  33. }
  34. // Find (2,5) in uE
  35. int ei = 0;
  36. bool flip = false;
  37. for(;ei<E.rows();ei++)
  38. {
  39. if(uE(ei,0) == 2 && uE(ei,1) == 5){flip=false;break;}
  40. if(uE(ei,1) == 2 && uE(ei,0) == 5){flip=true;break;}
  41. }
  42. Eigen::VectorXi Nccw;
  43. igl::circulation(ei,!flip,EMAP,EF,EI,Nccw);
  44. Eigen::VectorXi Nccwgt =
  45. (Eigen::VectorXi(6)<<
  46. 4,
  47. 5,
  48. 7,
  49. 6,
  50. 2,
  51. 3).finished();
  52. Eigen::VectorXi Ncwgt =
  53. (Eigen::VectorXi(4)<<
  54. 4,
  55. 1,
  56. 0,
  57. 3).finished();
  58. if(flip)
  59. {
  60. Nccwgt = Nccwgt.reverse().eval();
  61. Ncwgt = Ncwgt.reverse().eval();
  62. }
  63. test_common::assert_eq(Nccw,Nccwgt);
  64. Eigen::VectorXi Ncw;
  65. igl::circulation(ei, flip,EMAP,EF,EI,Ncw);
  66. test_common::assert_eq(Ncw,Ncwgt);
  67. }