1// This file is part of Eigen, a lightweight C++ template library 2// for linear algebra. 3// 4// Copyright (C) 2008-2014 Gael Guennebaud <gael.guennebaud@inria.fr> 5// 6// This Source Code Form is subject to the terms of the Mozilla 7// Public License v. 2.0. If a copy of the MPL was not distributed 8// with this file, You can obtain one at http://mozilla.org/MPL/2.0/. 9 10#ifndef EIGEN_MAPPED_SPARSEMATRIX_H 11#define EIGEN_MAPPED_SPARSEMATRIX_H 12 13namespace Eigen { 14 15/** \deprecated Use Map<SparseMatrix<> > 16 * \class MappedSparseMatrix 17 * 18 * \brief Sparse matrix 19 * 20 * \param _Scalar the scalar type, i.e. the type of the coefficients 21 * 22 * See http://www.netlib.org/linalg/html_templates/node91.html for details on the storage scheme. 23 * 24 */ 25namespace internal { 26template<typename _Scalar, int _Flags, typename _StorageIndex> 27struct traits<MappedSparseMatrix<_Scalar, _Flags, _StorageIndex> > : traits<SparseMatrix<_Scalar, _Flags, _StorageIndex> > 28{}; 29} // end namespace internal 30 31template<typename _Scalar, int _Flags, typename _StorageIndex> 32class MappedSparseMatrix 33 : public Map<SparseMatrix<_Scalar, _Flags, _StorageIndex> > 34{ 35 typedef Map<SparseMatrix<_Scalar, _Flags, _StorageIndex> > Base; 36 37 public: 38 39 typedef typename Base::StorageIndex StorageIndex; 40 typedef typename Base::Scalar Scalar; 41 42 inline MappedSparseMatrix(Index rows, Index cols, Index nnz, StorageIndex* outerIndexPtr, StorageIndex* innerIndexPtr, Scalar* valuePtr, StorageIndex* innerNonZeroPtr = 0) 43 : Base(rows, cols, nnz, outerIndexPtr, innerIndexPtr, valuePtr, innerNonZeroPtr) 44 {} 45 46 /** Empty destructor */ 47 inline ~MappedSparseMatrix() {} 48}; 49 50namespace internal { 51 52template<typename _Scalar, int _Options, typename _StorageIndex> 53struct evaluator<MappedSparseMatrix<_Scalar,_Options,_StorageIndex> > 54 : evaluator<SparseCompressedBase<MappedSparseMatrix<_Scalar,_Options,_StorageIndex> > > 55{ 56 typedef MappedSparseMatrix<_Scalar,_Options,_StorageIndex> XprType; 57 typedef evaluator<SparseCompressedBase<XprType> > Base; 58 59 evaluator() : Base() {} 60 explicit evaluator(const XprType &mat) : Base(mat) {} 61}; 62 63} 64 65} // end namespace Eigen 66 67#endif // EIGEN_MAPPED_SPARSEMATRIX_H 68