1

我有这种情况:m 是一个 NxN 稀疏矩阵,而 p 是纯 C++ 向量,它包含一个 NxN 矩阵。我想制作产品 m*p 并将结果存储在一个普通的 C++ 数组中,当然,以密集的格式。

 
  SparseMatrix  m; 
  double*p;
  Map mp(p,dim1,dim2);
  SparseTimeDenseProduct< Eigen::SparseMatrix, Eigen::Map< Eigen::Matrix< double, -1, -1> > > r = m*mp;

我有这个代码,但我不知道是否正确。如果是正确的,我不知道如何“提取” SparseTimeDenseProduct 的普通数组。我该怎么做?

4

1 回答 1

4

无需处理 Eigen 的内部类。只需这样做:

SparseMatrix<double> A(dim1,dim2);
double* p, res;
Map<const MatrixXd> mp(p,dim2,dim3);
Map<MatrixXd> mres(res,dim1,dim3);
mres = A * mp;
于 2013-01-03T09:34:11.043 回答