1234567891011121314151617181920212223242526272829303132 |
- #include "parse_rhs.h"
- #include <algorithm>
- template <typename DerivedV>
- IGL_INLINE void igl::parse_rhs_double(
- const mxArray *prhs[],
- Eigen::PlainObjectBase<DerivedV> & V)
- {
- using namespace std;
- // set number of mesh vertices
- const int n = mxGetM(prhs[0]);
- // set vertex position pointers
- double * Vp = mxGetPr(prhs[0]);
- const int dim = mxGetN(prhs[0]);
- V.resize(n,dim);
- copy(Vp,Vp+n*dim,&V.data()[0]);
- }
- template <typename DerivedV>
- IGL_INLINE void igl::parse_rhs_index(
- const mxArray *prhs[],
- Eigen::PlainObjectBase<DerivedV> & V)
- {
- parse_rhs_double(prhs,V);
- V.array() -= 1;
- }
- #ifdef IGL_STATIC_LIBRARY
- template void igl::parse_rhs_index<Eigen::Matrix<int, -1, 1, 0, -1, 1> >(mxArray_tag const**, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1> >&);
- template void igl::parse_rhs_index<Eigen::Matrix<int, -1, -1, 0, -1, -1> >(mxArray_tag const**, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> >&);
- template void igl::parse_rhs_double<Eigen::Matrix<double, -1, -1, 0, -1, -1> >(mxArray_tag const**, Eigen::PlainObjectBase<Eigen::Matrix<double, -1, -1, 0, -1, -1> >&);
- #endif
|