#include "diag.h" #include "verbose.h" // Bug in unsupported/Eigen/SparseExtra needs iostream first #include #include template IGL_INLINE void igl::diag( const Eigen::SparseMatrix& X, Eigen::SparseVector& V) { // Get size of input int m = X.rows(); int n = X.cols(); V = Eigen::SparseVector((m>n?n:m)); V.reserve(V.size()); // Iterate over outside for(int k=0; k::InnerIterator it (X,k); it; ++it) { if(it.col() == it.row()) { V.coeffRef(it.col()) += it.value(); } } } } template IGL_INLINE void igl::diag( const Eigen::SparseMatrix& X, Eigen::MatrixBase & V) { // Get size of input int m = X.rows(); int n = X.cols(); V.derived().resize((m>n?n:m),1); // Iterate over outside for(int k=0; k::InnerIterator it (X,k); it; ++it) { if(it.col() == it.row()) { V(it.col()) = it.value(); } } } } template IGL_INLINE void igl::diag( const Eigen::SparseVector& V, Eigen::SparseMatrix& X) { // clear and resize output Eigen::DynamicSparseMatrix dyn_X(V.size(),V.size()); dyn_X.reserve(V.size()); // loop over non-zeros for(typename Eigen::SparseVector::InnerIterator it(V); it; ++it) { dyn_X.coeffRef(it.index(),it.index()) += it.value(); } X = Eigen::SparseMatrix(dyn_X); } template IGL_INLINE void igl::diag( const Eigen::MatrixBase & V, Eigen::SparseMatrix& X) { assert(V.rows() == 1 || V.cols() == 1); // clear and resize output Eigen::DynamicSparseMatrix dyn_X(V.size(),V.size()); dyn_X.reserve(V.size()); // loop over non-zeros for(int i = 0;i(dyn_X); } #ifndef IGL_HEADER_ONLY // Explicit template specialization template void igl::diag >(Eigen::SparseMatrix const&, Eigen::MatrixBase >&); template void igl::diag(Eigen::SparseMatrix const&, Eigen::SparseVector&); #endif