list_to_matrix.cpp 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. #include "list_to_matrix.h"
  2. #include <cassert>
  3. #include <cstdio>
  4. #include <Eigen/Dense>
  5. #include "max_size.h"
  6. #include "min_size.h"
  7. #define VERBOSE
  8. #include "verbose.h"
  9. template <typename T, class Mat>
  10. IGL_INLINE bool igl::list_to_matrix(const std::vector<std::vector<T > > & V,Mat & M)
  11. {
  12. // number of columns
  13. int m = V.size();
  14. if(m == 0)
  15. {
  16. fprintf(stderr,"Error: list_to_matrix() list is empty()\n");
  17. return false;
  18. }
  19. // number of rows
  20. int n = igl::min_size(V);
  21. if(n != igl::max_size(V))
  22. {
  23. fprintf(stderr,"Error: list_to_matrix()"
  24. " list elements are not all the same size\n");
  25. return false;
  26. }
  27. assert(n != -1);
  28. // Resize output
  29. M.resize(m,n);
  30. // Loop over rows
  31. for(int i = 0;i<m;i++)
  32. {
  33. // Loop over cols
  34. for(int j = 0;j<n;j++)
  35. {
  36. M(i,j) = V[i][j];
  37. }
  38. }
  39. return true;
  40. }
  41. #ifndef IGL_HEADER_ONLY
  42. // Explicit template specialization
  43. // generated by autoexplicit.sh
  44. template bool igl::list_to_matrix<int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> > >(std::vector<std::vector<int, std::allocator<int> >, std::allocator<std::vector<int, std::allocator<int> > > > const&, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&);
  45. // generated by autoexplicit.sh
  46. template bool igl::list_to_matrix<double, Eigen::PlainObjectBase<Eigen::Matrix<double, -1, -1, 0, -1, -1> > >(std::vector<std::vector<double, std::allocator<double> >, std::allocator<std::vector<double, std::allocator<double> > > > const&, Eigen::PlainObjectBase<Eigen::Matrix<double, -1, -1, 0, -1, -1> >&);
  47. // generated by autoexplicit.sh
  48. template bool igl::list_to_matrix<double, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> > >(std::vector<std::vector<double, std::allocator<double> >, std::allocator<std::vector<double, std::allocator<double> > > > const&, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&);
  49. // generated by autoexplicit.sh
  50. template bool igl::list_to_matrix<int, Eigen::Matrix<int, -1, -1, 0, -1, -1> >(std::vector<std::vector<int, std::allocator<int> >, std::allocator<std::vector<int, std::allocator<int> > > > const&, Eigen::Matrix<int, -1, -1, 0, -1, -1>&);
  51. // generated by autoexplicit.sh
  52. template bool igl::list_to_matrix<double, Eigen::Matrix<double, -1, -1, 0, -1, -1> >(std::vector<std::vector<double, std::allocator<double> >, std::allocator<std::vector<double, std::allocator<double> > > > const&, Eigen::Matrix<double, -1, -1, 0, -1, -1>&);
  53. // generated by autoexplicit.sh
  54. template bool igl::list_to_matrix<double, Eigen::Matrix<int, -1, -1, 0, -1, -1> >(std::vector<std::vector<double, std::allocator<double> >, std::allocator<std::vector<double, std::allocator<double> > > > const&, Eigen::Matrix<int, -1, -1, 0, -1, -1>&);
  55. #endif