|
@@ -12,15 +12,15 @@
|
|
|
#include <unsupported/Eigen/SparseExtra>
|
|
#include <unsupported/Eigen/SparseExtra>
|
|
|
|
|
|
|
|
template <
|
|
template <
|
|
|
- typename TX,
|
|
|
|
|
- typename TY,
|
|
|
|
|
- typename DerivedR,
|
|
|
|
|
- typename DerivedC>
|
|
|
|
|
- IGL_INLINE void igl::slice(
|
|
|
|
|
- const Eigen::SparseMatrix<TX>& X,
|
|
|
|
|
- const Eigen::MatrixBase<DerivedR> & R,
|
|
|
|
|
- const Eigen::MatrixBase<DerivedC> & C,
|
|
|
|
|
- Eigen::SparseMatrix<TY>& Y)
|
|
|
|
|
|
|
+ typename TX,
|
|
|
|
|
+ typename TY,
|
|
|
|
|
+ typename DerivedR,
|
|
|
|
|
+ typename DerivedC>
|
|
|
|
|
+IGL_INLINE void igl::slice(
|
|
|
|
|
+ const Eigen::SparseMatrix<TX> &X,
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedR> &R,
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedC> &C,
|
|
|
|
|
+ Eigen::SparseMatrix<TY> &Y)
|
|
|
{
|
|
{
|
|
|
#if 1
|
|
#if 1
|
|
|
int xm = X.rows();
|
|
int xm = X.rows();
|
|
@@ -29,9 +29,9 @@ template <
|
|
|
int yn = C.size();
|
|
int yn = C.size();
|
|
|
|
|
|
|
|
// special case when R or C is empty
|
|
// special case when R or C is empty
|
|
|
- if(ym == 0 || yn == 0)
|
|
|
|
|
|
|
+ if (ym == 0 || yn == 0)
|
|
|
{
|
|
{
|
|
|
- Y.resize(ym,yn);
|
|
|
|
|
|
|
+ Y.resize(ym, yn);
|
|
|
return;
|
|
return;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
@@ -41,37 +41,37 @@ template <
|
|
|
assert(C.maxCoeff() < xn);
|
|
assert(C.maxCoeff() < xn);
|
|
|
|
|
|
|
|
// Build reindexing maps for columns and rows, -1 means not in map
|
|
// Build reindexing maps for columns and rows, -1 means not in map
|
|
|
- std::vector<std::vector<typename DerivedR::Scalar> > RI;
|
|
|
|
|
|
|
+ std::vector<std::vector<typename DerivedR::Scalar>> RI;
|
|
|
RI.resize(xm);
|
|
RI.resize(xm);
|
|
|
- for(int i = 0;i<ym;i++)
|
|
|
|
|
|
|
+ for (int i = 0; i < ym; i++)
|
|
|
{
|
|
{
|
|
|
RI[R(i)].push_back(i);
|
|
RI[R(i)].push_back(i);
|
|
|
}
|
|
}
|
|
|
- std::vector<std::vector<typename DerivedC::Scalar> > CI;
|
|
|
|
|
|
|
+ std::vector<std::vector<typename DerivedC::Scalar>> CI;
|
|
|
CI.resize(xn);
|
|
CI.resize(xn);
|
|
|
// initialize to -1
|
|
// initialize to -1
|
|
|
- for(int i = 0;i<yn;i++)
|
|
|
|
|
|
|
+ for (int i = 0; i < yn; i++)
|
|
|
{
|
|
{
|
|
|
CI[C(i)].push_back(i);
|
|
CI[C(i)].push_back(i);
|
|
|
}
|
|
}
|
|
|
// Resize output
|
|
// Resize output
|
|
|
- Eigen::DynamicSparseMatrix<TY, Eigen::RowMajor> dyn_Y(ym,yn);
|
|
|
|
|
|
|
+ Eigen::DynamicSparseMatrix<TY, Eigen::RowMajor> dyn_Y(ym, yn);
|
|
|
// Take a guess at the number of nonzeros (this assumes uniform distribution
|
|
// Take a guess at the number of nonzeros (this assumes uniform distribution
|
|
|
// not banded or heavily diagonal)
|
|
// not banded or heavily diagonal)
|
|
|
- dyn_Y.reserve((X.nonZeros()/(X.rows()*X.cols())) * (ym*yn));
|
|
|
|
|
|
|
+ dyn_Y.reserve((X.nonZeros() / (X.rows() * X.cols())) * (ym * yn));
|
|
|
// Iterate over outside
|
|
// Iterate over outside
|
|
|
- for(int k=0; k<X.outerSize(); ++k)
|
|
|
|
|
|
|
+ for (int k = 0; k < X.outerSize(); ++k)
|
|
|
{
|
|
{
|
|
|
// Iterate over inside
|
|
// Iterate over inside
|
|
|
- for(typename Eigen::SparseMatrix<TX>::InnerIterator it (X,k); it; ++it)
|
|
|
|
|
|
|
+ for (typename Eigen::SparseMatrix<TX>::InnerIterator it(X, k); it; ++it)
|
|
|
{
|
|
{
|
|
|
typename std::vector<typename DerivedR::Scalar>::iterator rit;
|
|
typename std::vector<typename DerivedR::Scalar>::iterator rit;
|
|
|
typename std::vector<typename DerivedC::Scalar>::iterator cit;
|
|
typename std::vector<typename DerivedC::Scalar>::iterator cit;
|
|
|
- for(rit = RI[it.row()].begin();rit != RI[it.row()].end(); rit++)
|
|
|
|
|
|
|
+ for (rit = RI[it.row()].begin(); rit != RI[it.row()].end(); rit++)
|
|
|
{
|
|
{
|
|
|
- for(cit = CI[it.col()].begin();cit != CI[it.col()].end(); cit++)
|
|
|
|
|
|
|
+ for (cit = CI[it.col()].begin(); cit != CI[it.col()].end(); cit++)
|
|
|
{
|
|
{
|
|
|
- dyn_Y.coeffRef(*rit,*cit) = it.value();
|
|
|
|
|
|
|
+ dyn_Y.coeffRef(*rit, *cit) = it.value();
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
@@ -94,9 +94,9 @@ template <
|
|
|
int yn = C.size();
|
|
int yn = C.size();
|
|
|
|
|
|
|
|
// special case when R or C is empty
|
|
// special case when R or C is empty
|
|
|
- if(ym == 0 || yn == 0)
|
|
|
|
|
|
|
+ if (ym == 0 || yn == 0)
|
|
|
{
|
|
{
|
|
|
- Y.resize(ym,yn);
|
|
|
|
|
|
|
+ Y.resize(ym, yn);
|
|
|
return;
|
|
return;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
@@ -106,83 +106,83 @@ template <
|
|
|
assert(C.maxCoeff() < xn);
|
|
assert(C.maxCoeff() < xn);
|
|
|
|
|
|
|
|
// initialize row and col permutation vectors
|
|
// initialize row and col permutation vectors
|
|
|
- Eigen::VectorXi rowIndexVec = igl::LinSpaced<Eigen::VectorXi >(xm,0,xm-1);
|
|
|
|
|
- Eigen::VectorXi rowPermVec = igl::LinSpaced<Eigen::VectorXi >(xm,0,xm-1);
|
|
|
|
|
- for(int i=0;i<ym;i++)
|
|
|
|
|
|
|
+ Eigen::VectorXi rowIndexVec = igl::LinSpaced<Eigen::VectorXi>(xm, 0, xm - 1);
|
|
|
|
|
+ Eigen::VectorXi rowPermVec = igl::LinSpaced<Eigen::VectorXi>(xm, 0, xm - 1);
|
|
|
|
|
+ for (int i = 0; i < ym; i++)
|
|
|
{
|
|
{
|
|
|
int pos = rowIndexVec.coeffRef(R(i));
|
|
int pos = rowIndexVec.coeffRef(R(i));
|
|
|
- if(pos != i)
|
|
|
|
|
|
|
+ if (pos != i)
|
|
|
{
|
|
{
|
|
|
- int& val = rowPermVec.coeffRef(i);
|
|
|
|
|
- std::swap(rowIndexVec.coeffRef(val),rowIndexVec.coeffRef(R(i)));
|
|
|
|
|
- std::swap(rowPermVec.coeffRef(i),rowPermVec.coeffRef(pos));
|
|
|
|
|
|
|
+ int &val = rowPermVec.coeffRef(i);
|
|
|
|
|
+ std::swap(rowIndexVec.coeffRef(val), rowIndexVec.coeffRef(R(i)));
|
|
|
|
|
+ std::swap(rowPermVec.coeffRef(i), rowPermVec.coeffRef(pos));
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
- Eigen::PermutationMatrix<Eigen::Dynamic,Eigen::Dynamic,int> rowPerm(rowIndexVec);
|
|
|
|
|
|
|
+ Eigen::PermutationMatrix<Eigen::Dynamic, Eigen::Dynamic, int> rowPerm(rowIndexVec);
|
|
|
|
|
|
|
|
- Eigen::VectorXi colIndexVec = igl::LinSpaced<Eigen::VectorXi >(xn,0,xn-1);
|
|
|
|
|
- Eigen::VectorXi colPermVec = igl::LinSpaced<Eigen::VectorXi >(xn,0,xn-1);
|
|
|
|
|
- for(int i=0;i<yn;i++)
|
|
|
|
|
|
|
+ Eigen::VectorXi colIndexVec = igl::LinSpaced<Eigen::VectorXi>(xn, 0, xn - 1);
|
|
|
|
|
+ Eigen::VectorXi colPermVec = igl::LinSpaced<Eigen::VectorXi>(xn, 0, xn - 1);
|
|
|
|
|
+ for (int i = 0; i < yn; i++)
|
|
|
{
|
|
{
|
|
|
int pos = colIndexVec.coeffRef(C(i));
|
|
int pos = colIndexVec.coeffRef(C(i));
|
|
|
- if(pos != i)
|
|
|
|
|
|
|
+ if (pos != i)
|
|
|
{
|
|
{
|
|
|
- int& val = colPermVec.coeffRef(i);
|
|
|
|
|
- std::swap(colIndexVec.coeffRef(val),colIndexVec.coeffRef(C(i)));
|
|
|
|
|
- std::swap(colPermVec.coeffRef(i),colPermVec.coeffRef(pos));
|
|
|
|
|
|
|
+ int &val = colPermVec.coeffRef(i);
|
|
|
|
|
+ std::swap(colIndexVec.coeffRef(val), colIndexVec.coeffRef(C(i)));
|
|
|
|
|
+ std::swap(colPermVec.coeffRef(i), colPermVec.coeffRef(pos));
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
- Eigen::PermutationMatrix<Eigen::Dynamic,Eigen::Dynamic,int> colPerm(colPermVec);
|
|
|
|
|
|
|
+ Eigen::PermutationMatrix<Eigen::Dynamic, Eigen::Dynamic, int> colPerm(colPermVec);
|
|
|
|
|
|
|
|
Eigen::SparseMatrix<T> M = (rowPerm * X);
|
|
Eigen::SparseMatrix<T> M = (rowPerm * X);
|
|
|
- Y = (M * colPerm).block(0,0,ym,yn);
|
|
|
|
|
|
|
+ Y = (M * colPerm).block(0, 0, ym, yn);
|
|
|
#endif
|
|
#endif
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
template <typename MatX, typename DerivedR, typename MatY>
|
|
template <typename MatX, typename DerivedR, typename MatY>
|
|
|
IGL_INLINE void igl::slice(
|
|
IGL_INLINE void igl::slice(
|
|
|
- const MatX& X,
|
|
|
|
|
- const Eigen::MatrixBase<DerivedR> & R,
|
|
|
|
|
- const int dim,
|
|
|
|
|
- MatY& Y)
|
|
|
|
|
|
|
+ const MatX &X,
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedR> &R,
|
|
|
|
|
+ const int dim,
|
|
|
|
|
+ MatY &Y)
|
|
|
{
|
|
{
|
|
|
- Eigen::Matrix<typename DerivedR::Scalar,Eigen::Dynamic,1> C;
|
|
|
|
|
- switch(dim)
|
|
|
|
|
|
|
+ Eigen::Matrix<typename DerivedR::Scalar, Eigen::Dynamic, 1> C;
|
|
|
|
|
+ switch (dim)
|
|
|
{
|
|
{
|
|
|
- case 1:
|
|
|
|
|
- // boring base case
|
|
|
|
|
- if(X.cols() == 0)
|
|
|
|
|
- {
|
|
|
|
|
- Y.resize(R.size(),0);
|
|
|
|
|
- return;
|
|
|
|
|
- }
|
|
|
|
|
- igl::colon(0,X.cols()-1,C);
|
|
|
|
|
- return slice(X,R,C,Y);
|
|
|
|
|
- case 2:
|
|
|
|
|
- // boring base case
|
|
|
|
|
- if(X.rows() == 0)
|
|
|
|
|
- {
|
|
|
|
|
- Y.resize(0,R.size());
|
|
|
|
|
- return;
|
|
|
|
|
- }
|
|
|
|
|
- igl::colon(0,X.rows()-1,C);
|
|
|
|
|
- return slice(X,C,R,Y);
|
|
|
|
|
- default:
|
|
|
|
|
- assert(false && "Unsupported dimension");
|
|
|
|
|
|
|
+ case 1:
|
|
|
|
|
+ // boring base case
|
|
|
|
|
+ if (X.cols() == 0)
|
|
|
|
|
+ {
|
|
|
|
|
+ Y.resize(R.size(), 0);
|
|
|
return;
|
|
return;
|
|
|
|
|
+ }
|
|
|
|
|
+ igl::colon(0, X.cols() - 1, C);
|
|
|
|
|
+ return slice(X, R, C, Y);
|
|
|
|
|
+ case 2:
|
|
|
|
|
+ // boring base case
|
|
|
|
|
+ if (X.rows() == 0)
|
|
|
|
|
+ {
|
|
|
|
|
+ Y.resize(0, R.size());
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+ igl::colon(0, X.rows() - 1, C);
|
|
|
|
|
+ return slice(X, C, R, Y);
|
|
|
|
|
+ default:
|
|
|
|
|
+ assert(false && "Unsupported dimension");
|
|
|
|
|
+ return;
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
template <
|
|
template <
|
|
|
- typename DerivedX,
|
|
|
|
|
- typename DerivedR,
|
|
|
|
|
- typename DerivedC,
|
|
|
|
|
- typename DerivedY>
|
|
|
|
|
|
|
+ typename DerivedX,
|
|
|
|
|
+ typename DerivedR,
|
|
|
|
|
+ typename DerivedC,
|
|
|
|
|
+ typename DerivedY>
|
|
|
IGL_INLINE void igl::slice(
|
|
IGL_INLINE void igl::slice(
|
|
|
- const Eigen::MatrixBase<DerivedX> & X,
|
|
|
|
|
- const Eigen::MatrixBase<DerivedR> & R,
|
|
|
|
|
- const Eigen::MatrixBase<DerivedC> & C,
|
|
|
|
|
- Eigen::PlainObjectBase<DerivedY> & Y)
|
|
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedX> &X,
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedR> &R,
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedC> &C,
|
|
|
|
|
+ Eigen::PlainObjectBase<DerivedY> &Y)
|
|
|
{
|
|
{
|
|
|
#ifndef NDEBUG
|
|
#ifndef NDEBUG
|
|
|
int xm = X.rows();
|
|
int xm = X.rows();
|
|
@@ -192,9 +192,9 @@ IGL_INLINE void igl::slice(
|
|
|
int yn = C.size();
|
|
int yn = C.size();
|
|
|
|
|
|
|
|
// special case when R or C is empty
|
|
// special case when R or C is empty
|
|
|
- if(ym == 0 || yn == 0)
|
|
|
|
|
|
|
+ if (ym == 0 || yn == 0)
|
|
|
{
|
|
{
|
|
|
- Y.resize(ym,yn);
|
|
|
|
|
|
|
+ Y.resize(ym, yn);
|
|
|
return;
|
|
return;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
@@ -204,53 +204,53 @@ IGL_INLINE void igl::slice(
|
|
|
assert(C.maxCoeff() < xn);
|
|
assert(C.maxCoeff() < xn);
|
|
|
|
|
|
|
|
// Resize output
|
|
// Resize output
|
|
|
- Y.resize(ym,yn);
|
|
|
|
|
|
|
+ Y.resize(ym, yn);
|
|
|
// loop over output rows, then columns
|
|
// loop over output rows, then columns
|
|
|
- for(int i = 0;i<ym;i++)
|
|
|
|
|
|
|
+ for (int i = 0; i < ym; i++)
|
|
|
{
|
|
{
|
|
|
- for(int j = 0;j<yn;j++)
|
|
|
|
|
|
|
+ for (int j = 0; j < yn; j++)
|
|
|
{
|
|
{
|
|
|
- Y(i,j) = X(R(i),C(j));
|
|
|
|
|
|
|
+ Y(i, j) = X(R(i), C(j));
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
-
|
|
|
|
|
template <typename DerivedX, typename DerivedY, typename DerivedR>
|
|
template <typename DerivedX, typename DerivedY, typename DerivedR>
|
|
|
IGL_INLINE void igl::slice(
|
|
IGL_INLINE void igl::slice(
|
|
|
- const Eigen::MatrixBase<DerivedX> & X,
|
|
|
|
|
- const Eigen::MatrixBase<DerivedR> & R,
|
|
|
|
|
- Eigen::PlainObjectBase<DerivedY> & Y)
|
|
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedX> &X,
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedR> &R,
|
|
|
|
|
+ Eigen::PlainObjectBase<DerivedY> &Y)
|
|
|
{
|
|
{
|
|
|
// phony column indices
|
|
// phony column indices
|
|
|
- Eigen::Matrix<typename DerivedR::Scalar,Eigen::Dynamic,1> C;
|
|
|
|
|
|
|
+ Eigen::Matrix<typename DerivedR::Scalar, Eigen::Dynamic, 1> C;
|
|
|
C.resize(1);
|
|
C.resize(1);
|
|
|
C(0) = 0;
|
|
C(0) = 0;
|
|
|
- return igl::slice(X,R,C,Y);
|
|
|
|
|
|
|
+ return igl::slice(X, R, C, Y);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
template <typename DerivedX, typename DerivedR>
|
|
template <typename DerivedX, typename DerivedR>
|
|
|
IGL_INLINE DerivedX igl::slice(
|
|
IGL_INLINE DerivedX igl::slice(
|
|
|
- const Eigen::MatrixBase<DerivedX> & X,
|
|
|
|
|
- const Eigen::MatrixBase<DerivedR> & R)
|
|
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedX> &X,
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedR> &R)
|
|
|
{
|
|
{
|
|
|
DerivedX Y;
|
|
DerivedX Y;
|
|
|
- igl::slice(X,R,Y);
|
|
|
|
|
|
|
+ igl::slice(X, R, Y);
|
|
|
return Y;
|
|
return Y;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
template <typename DerivedX, typename DerivedR>
|
|
template <typename DerivedX, typename DerivedR>
|
|
|
IGL_INLINE DerivedX igl::slice(
|
|
IGL_INLINE DerivedX igl::slice(
|
|
|
- const Eigen::MatrixBase<DerivedX>& X,
|
|
|
|
|
- const Eigen::MatrixBase<DerivedR> & R,
|
|
|
|
|
- const int dim)
|
|
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedX> &X,
|
|
|
|
|
+ const Eigen::MatrixBase<DerivedR> &R,
|
|
|
|
|
+ const int dim)
|
|
|
{
|
|
{
|
|
|
DerivedX Y;
|
|
DerivedX Y;
|
|
|
- igl::slice(X,R,dim,Y);
|
|
|
|
|
|
|
+ igl::slice(X, R, dim, Y);
|
|
|
return Y;
|
|
return Y;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
#ifdef IGL_STATIC_LIBRARY
|
|
#ifdef IGL_STATIC_LIBRARY
|
|
|
|
|
+template void igl::slice<Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::Matrix<int, -1, 1, 0, -1, 1>>(Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> &);
|
|
|
template void igl::slice<Eigen::MatrixBase<Eigen::Matrix<double, -1, 1, 0, -1, 1>>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::Matrix<double, -1, -1, 0, -1, -1>>(Eigen::MatrixBase<Eigen::Matrix<double, -1, 1, 0, -1, 1>> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, int, Eigen::Matrix<double, -1, -1, 0, -1, -1> &);
|
|
template void igl::slice<Eigen::MatrixBase<Eigen::Matrix<double, -1, 1, 0, -1, 1>>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::Matrix<double, -1, -1, 0, -1, -1>>(Eigen::MatrixBase<Eigen::Matrix<double, -1, 1, 0, -1, 1>> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, int, Eigen::Matrix<double, -1, -1, 0, -1, -1> &);
|
|
|
template void igl::slice<Eigen::MatrixBase<Eigen::Matrix<double, -1, -1, 0, -1, -1>>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::Matrix<double, -1, -1, 0, -1, -1>>(Eigen::MatrixBase<Eigen::Matrix<double, -1, -1, 0, -1, -1>> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, int, Eigen::Matrix<double, -1, -1, 0, -1, -1> &);
|
|
template void igl::slice<Eigen::MatrixBase<Eigen::Matrix<double, -1, -1, 0, -1, -1>>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::Matrix<double, -1, -1, 0, -1, -1>>(Eigen::MatrixBase<Eigen::Matrix<double, -1, -1, 0, -1, -1>> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, int, Eigen::Matrix<double, -1, -1, 0, -1, -1> &);
|
|
|
template void igl::slice<Eigen::SparseMatrix<double, 0, int>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::SparseMatrix<double, 0, int>>(Eigen::SparseMatrix<double, 0, int> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, int, Eigen::SparseMatrix<double, 0, int> &);
|
|
template void igl::slice<Eigen::SparseMatrix<double, 0, int>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::SparseMatrix<double, 0, int>>(Eigen::SparseMatrix<double, 0, int> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, int, Eigen::SparseMatrix<double, 0, int> &);
|
|
@@ -287,3 +287,15 @@ template void igl::slice<Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::Matrix<int,
|
|
|
template void igl::slice<Eigen::Matrix<long, -1, 1, 0, -1, 1>, Eigen::Matrix<long, -1, 1, 0, -1, 1>, Eigen::PlainObjectBase<Eigen::Matrix<long, -1, 1, 0, -1, 1>>>(Eigen::Matrix<long, -1, 1, 0, -1, 1> const &, Eigen::MatrixBase<Eigen::Matrix<long, -1, 1, 0, -1, 1>> const &, int, Eigen::PlainObjectBase<Eigen::Matrix<long, -1, 1, 0, -1, 1>> &);
|
|
template void igl::slice<Eigen::Matrix<long, -1, 1, 0, -1, 1>, Eigen::Matrix<long, -1, 1, 0, -1, 1>, Eigen::PlainObjectBase<Eigen::Matrix<long, -1, 1, 0, -1, 1>>>(Eigen::Matrix<long, -1, 1, 0, -1, 1> const &, Eigen::MatrixBase<Eigen::Matrix<long, -1, 1, 0, -1, 1>> const &, int, Eigen::PlainObjectBase<Eigen::Matrix<long, -1, 1, 0, -1, 1>> &);
|
|
|
template void igl::slice<Eigen::Matrix<int, -1, -1, 0, -1, -1>, Eigen::Matrix<int, -1, -1, 0, -1, -1>, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>>>(Eigen::Matrix<int, -1, -1, 0, -1, -1> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>> const &, int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>> &);
|
|
template void igl::slice<Eigen::Matrix<int, -1, -1, 0, -1, -1>, Eigen::Matrix<int, -1, -1, 0, -1, -1>, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>>>(Eigen::Matrix<int, -1, -1, 0, -1, -1> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>> const &, int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>> &);
|
|
|
#ifdef WIN32
|
|
#ifdef WIN32
|
|
|
|
|
+template void igl::slice<Eigen::Matrix<__int64, -1, 1, 0, -1, 1>, Eigen::Matrix<__int64, -1, 1, 0, -1, 1>, Eigen::PlainObjectBase<Eigen::Matrix<__int64, -1, 1, 0, -1, 1>>>(Eigen::Matrix<__int64, -1, 1, 0, -1, 1> const &, Eigen::MatrixBase<Eigen::Matrix<__int64, -1, 1, 0, -1, 1>> const &, int, Eigen::PlainObjectBase<Eigen::Matrix<__int64, -1, 1, 0, -1, 1>> &);
|
|
|
|
|
+template void igl::slice<Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>>, Eigen::Matrix<__int64, -1, 1, 0, -1, 1>, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>>>(Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>> const &, Eigen::MatrixBase<Eigen::Matrix<__int64, -1, 1, 0, -1, 1>> const &, int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>> &);
|
|
|
|
|
+#endif
|
|
|
|
|
+#if EIGEN_VERSION_AT_LEAST(3, 3, 7)
|
|
|
|
|
+#else
|
|
|
|
|
+template void igl::slice<Eigen::MatrixBase<Eigen::CwiseUnaryOp<Eigen::internal::scalar_multiple_op<double>, Eigen::Matrix<double, -1, 1, 0, -1, 1> const>>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::Matrix<double, -1, -1, 0, -1, -1>>(Eigen::MatrixBase<Eigen::CwiseUnaryOp<Eigen::internal::scalar_multiple_op<double>, Eigen::Matrix<double, -1, 1, 0, -1, 1> const>> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, int, Eigen::Matrix<double, -1, -1, 0, -1, -1> &);
|
|
|
|
|
+#endif
|
|
|
|
|
+template void igl::slice<Eigen::MatrixBase<Eigen::Matrix<double, -1, -1, 0, -1, -1> >, Eigen::Matrix<int, -1, -1, 0, -1, -1>, Eigen::PlainObjectBase<Eigen::Matrix<double, -1, -1, 0, -1, -1> > >(Eigen::MatrixBase<Eigen::Matrix<double, -1, -1, 0, -1, -1> > const&, Eigen::MatrixBase<Eigen::Matrix<int, -1, -1, 0, -1, -1> > const&, int, Eigen::PlainObjectBase<Eigen::Matrix<double, -1, -1, 0, -1, -1> >&);
|
|
|
|
|
+template void igl::slice<Eigen::Matrix<double, -1, -1, 0, -1, -1>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::Matrix<double, -1, -1, 0, -1, -1>>(Eigen::MatrixBase<Eigen::Matrix<double, -1, -1, 0, -1, -1>> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, Eigen::PlainObjectBase<Eigen::Matrix<double, -1, -1, 0, -1, -1>> &);
|
|
|
|
|
+template void igl::slice<Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>>, Eigen::Matrix<int, -1, -1, 0, -1, -1>, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>>>(Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>> const &, int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, -1, 0, -1, -1>> &);
|
|
|
|
|
+template void igl::slice<Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 3, 1, -1, 3>>, Eigen::Matrix<int, -1, 1, 0, -1, 1>, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 3, 1, -1, 3>>>(Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 3, 1, -1, 3>> const &, Eigen::MatrixBase<Eigen::Matrix<int, -1, 1, 0, -1, 1>> const &, int, Eigen::PlainObjectBase<Eigen::Matrix<int, -1, 3, 1, -1, 3>> &);
|
|
|
|
|
+#endif
|