prepare_lhs.h 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. // This file is part of libigl, a simple c++ geometry processing library.
  2. //
  3. // Copyright (C) 2015 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_MATLAB_PREPARE_LHS_H
  9. #define IGL_MATLAB_PREPARE_LHS_H
  10. #include <igl/igl_inline.h>
  11. #include <mex.h>
  12. #include <Eigen/Dense>
  13. #include <Eigen/Sparse>
  14. namespace igl
  15. {
  16. namespace matlab
  17. {
  18. // Writes out a matrix as a double
  19. //
  20. // Inputs:
  21. // prhs points to rhs argument
  22. // Outputs:
  23. // V M by N matrix
  24. template <typename DerivedV>
  25. IGL_INLINE void prepare_lhs_double(
  26. const Eigen::PlainObjectBase<DerivedV> & V,
  27. mxArray *plhs[]);
  28. // Casts to logical
  29. template <typename DerivedV>
  30. IGL_INLINE void prepare_lhs_logical(
  31. const Eigen::PlainObjectBase<DerivedV> & V,
  32. mxArray *plhs[]);
  33. // Writes out a matrix and adds 1
  34. template <typename DerivedV>
  35. IGL_INLINE void prepare_lhs_index(
  36. const Eigen::PlainObjectBase<DerivedV> & V,
  37. mxArray *plhs[]);
  38. // SparseMatrix
  39. template <typename Vtype>
  40. IGL_INLINE void prepare_lhs_double(
  41. const Eigen::SparseMatrix<Vtype> & V,
  42. mxArray *plhs[]);
  43. };
  44. }
  45. #ifndef IGL_STATIC_LIBRARY
  46. # include "prepare_lhs.cpp"
  47. #endif
  48. #endif