print_ijv.h 1.1 KB

1234567891011121314151617181920212223242526272829303132333435
  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_PRINT_IJV_H
  9. #define IGL_PRINT_IJV_H
  10. #include "igl_inline.h"
  11. #define EIGEN_YES_I_KNOW_SPARSE_MODULE_IS_NOT_STABLE_YET
  12. #include <Eigen/Dense>
  13. #include <Eigen/Sparse>
  14. namespace igl
  15. {
  16. // Prints a 3 column matrix representing [I,J,V] = find(X). That is, each
  17. // row is the row index, column index and value for each non zero entry. Each
  18. // row is printed on a new line
  19. //
  20. // Templates:
  21. // T should be a eigen sparse matrix primitive type like int or double
  22. // Input:
  23. // X m by n matrix whose entries are to be sorted
  24. // offset optional offset for I and J indices {0}
  25. template <typename T>
  26. IGL_INLINE void print_ijv(
  27. const Eigen::SparseMatrix<T>& X,
  28. const int offset=0);
  29. }
  30. #ifndef IGL_STATIC_LIBRARY
  31. # include "print_ijv.cpp"
  32. #endif
  33. #endif