12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- // This file is part of libigl, a simple c++ geometry processing library.
- //
- // Copyright (C) 2015 Alec Jacobson <alecjacobson@gmail.com>
- //
- // This Source Code Form is subject to the terms of the Mozilla Public License
- // v. 2.0. If a copy of the MPL was not distributed with this file, You can
- // obtain one at http://mozilla.org/MPL/2.0/.
- #include "parse_rhs.h"
- #include <algorithm>
- template <typename DerivedV>
- IGL_INLINE void igl::matlab::parse_rhs_double(
- const mxArray *prhs[],
- Eigen::PlainObjectBase<DerivedV> & V)
- {
- using namespace std;
- using namespace Eigen;
- // 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]);
- typedef typename DerivedV::Scalar Scalar;
- Matrix<Scalar, DerivedV::ColsAtCompileTime, DerivedV::RowsAtCompileTime, RowMajor> VT;
- Scalar * V_data;
- if(DerivedV::IsRowMajor)
- {
- VT.resize(dim,n);
- V_data = VT.data();
- }else
- {
- V.resize(n,dim);
- V_data = V.data();
- }
- copy(Vp,Vp+n*dim,V_data);
- if(DerivedV::IsRowMajor)
- {
- V = VT.transpose();
- }
- }
- template <typename DerivedV>
- IGL_INLINE void igl::matlab::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::matlab::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::matlab::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::matlab::parse_rhs_double<Eigen::Matrix<double, -1, -1, 0, -1, -1> >(mxArray_tag const**, Eigen::PlainObjectBase<Eigen::Matrix<double, -1, -1, 0, -1, -1> >&);
- template void igl::matlab::parse_rhs_index<Eigen::Matrix<int, -1, 3, 1, -1, 3> >(mxArray_tag const**, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 3, 1, -1, 3> >&);
- template void igl::matlab::parse_rhs_double<Eigen::Matrix<double, -1, 3, 1, -1, 3> >(mxArray_tag const**, Eigen::PlainObjectBase<Eigen::Matrix<double, -1, 3, 1, -1, 3> >&);
- #endif
|