grid.h 1018 B

123456789101112131415161718192021222324252627282930313233
  1. // This file is part of libigl, a simple c++ geometry processing library.
  2. //
  3. // Copyright (C) 2016 Alec Jacobson <alecjacobson@gmail.com>
  4. // Copyright (C) 2018 Alec Jacobson <alecjacobson@gmail.com>
  5. //
  6. // This Source Code Form is subject to the terms of the Mozilla Public License
  7. // v. 2.0. If a copy of the MPL was not distributed with this file, You can
  8. // obtain one at http://mozilla.org/MPL/2.0/.
  9. #ifndef IGL_GRID_H
  10. #define IGL_GRID_H
  11. #include "igl_inline.h"
  12. #include <Eigen/Core>
  13. namespace igl
  14. {
  15. // Construct vertices of a regular grid, suitable for input to
  16. // `igl::marching_cubes`
  17. //
  18. // Inputs:
  19. // res #res list of number of vertices along each dimension
  20. // Outputs:
  21. // GV res.array().prod() by #res list of mesh vertex positions.
  22. //
  23. template <
  24. typename Derivedres,
  25. typename DerivedGV>
  26. IGL_INLINE void grid(
  27. const Eigen::MatrixBase<Derivedres> & res,
  28. Eigen::PlainObjectBase<DerivedGV> & GV);
  29. }
  30. #ifndef IGL_STATIC_LIBRARY
  31. # include "grid.cpp"
  32. #endif
  33. #endif