comb_line_field.cpp 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. // This file is part of libigl, a simple c++ geometry processing library.
  2. //
  3. // Copyright (C) 2014 Nico Pietroni <nico.pietroni@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. #include "comb_line_field.h"
  9. #include <vector>
  10. #include <deque>
  11. #include "per_face_normals.h"
  12. #include "is_border_vertex.h"
  13. #include "rotation_matrix_from_directions.h"
  14. #include "triangle_triangle_adjacency.h"
  15. namespace igl {
  16. template <typename DerivedV, typename DerivedF>
  17. class CombLine
  18. {
  19. public:
  20. const Eigen::PlainObjectBase<DerivedV> &V;
  21. const Eigen::PlainObjectBase<DerivedF> &F;
  22. const Eigen::PlainObjectBase<DerivedV> &PD1;
  23. #warning "Constructing Eigen::PlainObjectBase directly is deprecated"
  24. Eigen::PlainObjectBase<DerivedV> N;
  25. private:
  26. // internal
  27. #warning "Constructing Eigen::PlainObjectBase directly is deprecated"
  28. Eigen::PlainObjectBase<DerivedF> TT;
  29. Eigen::PlainObjectBase<DerivedF> TTi;
  30. private:
  31. static inline double Sign(double a){return (double)((a>0)?+1:-1);}
  32. private:
  33. // returns the 180 deg rotation of a (around n) most similar to target b
  34. // a and b should be in the same plane orthogonal to N
  35. static inline Eigen::Matrix<typename DerivedV::Scalar, 3, 1> K_PI_line(const Eigen::Matrix<typename DerivedV::Scalar, 3, 1>& a,
  36. const Eigen::Matrix<typename DerivedV::Scalar, 3, 1>& b)
  37. {
  38. typename DerivedV::Scalar scorea = a.dot(b);
  39. if (scorea<0)
  40. return -a;
  41. else
  42. return a;
  43. }
  44. public:
  45. inline CombLine(const Eigen::PlainObjectBase<DerivedV> &_V,
  46. const Eigen::PlainObjectBase<DerivedF> &_F,
  47. const Eigen::PlainObjectBase<DerivedV> &_PD1):
  48. V(_V),
  49. F(_F),
  50. PD1(_PD1)
  51. {
  52. igl::per_face_normals(V,F,N);
  53. igl::triangle_triangle_adjacency(F,TT,TTi);
  54. }
  55. inline void comb(Eigen::PlainObjectBase<DerivedV> &PD1out)
  56. {
  57. PD1out.setZero(F.rows(),3);PD1out<<PD1;
  58. Eigen::VectorXi mark = Eigen::VectorXi::Constant(F.rows(),false);
  59. std::deque<int> d;
  60. d.push_back(0);
  61. mark(0) = true;
  62. while (!d.empty())
  63. {
  64. int f0 = d.at(0);
  65. d.pop_front();
  66. for (int k=0; k<3; k++)
  67. {
  68. int f1 = TT(f0,k);
  69. if (f1==-1) continue;
  70. if (mark(f1)) continue;
  71. Eigen::Matrix<typename DerivedV::Scalar, 3, 1> dir0 = PD1out.row(f0);
  72. Eigen::Matrix<typename DerivedV::Scalar, 3, 1> dir1 = PD1out.row(f1);
  73. Eigen::Matrix<typename DerivedV::Scalar, 3, 1> n0 = N.row(f0);
  74. Eigen::Matrix<typename DerivedV::Scalar, 3, 1> n1 = N.row(f1);
  75. Eigen::Matrix<typename DerivedV::Scalar, 3, 1> dir0Rot = igl::rotation_matrix_from_directions(n0, n1)*dir0;
  76. dir0Rot.normalize();
  77. Eigen::Matrix<typename DerivedV::Scalar, 3, 1> targD = K_PI_line(dir1,dir0Rot);
  78. PD1out.row(f1) = targD;
  79. //PD2out.row(f1) = n1.cross(targD).normalized();
  80. mark(f1) = true;
  81. d.push_back(f1);
  82. }
  83. }
  84. // everything should be marked
  85. for (int i=0; i<F.rows(); i++)
  86. {
  87. assert(mark(i));
  88. }
  89. }
  90. };
  91. }
  92. template <typename DerivedV, typename DerivedF>
  93. IGL_INLINE void igl::comb_line_field(const Eigen::PlainObjectBase<DerivedV> &V,
  94. const Eigen::PlainObjectBase<DerivedF> &F,
  95. const Eigen::PlainObjectBase<DerivedV> &PD1,
  96. Eigen::PlainObjectBase<DerivedV> &PD1out)
  97. {
  98. igl::CombLine<DerivedV, DerivedF> cmb(V, F, PD1);
  99. cmb.comb(PD1out);
  100. }
  101. #ifdef IGL_STATIC_LIBRARY
  102. // Explicit template specialization
  103. #endif