scipy.io.
mmread#
- scipy.io.mmread(source, *, spmatrix=True)[source]#
Reads the contents of a Matrix Market file-like ‘source’ into a matrix.
- Parameters:
- sourcestr or file-like
Matrix Market filename (extensions .mtx, .mtz.gz) or open file-like object.
- spmatrixbool, optional (default: True)
If
True
, return sparsecoo_matrix
. Otherwise returncoo_array
.
- Returns:
- andarray or coo_array
Dense or sparse array depending on the matrix format in the Matrix Market file.
Notes
Changed in version 1.12.0: C++ implementation.
Examples
>>> from io import StringIO >>> from scipy.io import mmread
>>> text = '''%%MatrixMarket matrix coordinate real general ... 5 5 7 ... 2 3 1.0 ... 3 4 2.0 ... 3 5 3.0 ... 4 1 4.0 ... 4 2 5.0 ... 4 3 6.0 ... 4 4 7.0 ... '''
mmread(source)
returns the data as sparse array in COO format.>>> m = mmread(StringIO(text), spmatrix=False) >>> m <COOrdinate sparse array of dtype 'float64' with 7 stored elements and shape (5, 5)> >>> m.toarray() array([[0., 0., 0., 0., 0.], [0., 0., 1., 0., 0.], [0., 0., 0., 2., 3.], [4., 5., 6., 7., 0.], [0., 0., 0., 0., 0.]])
This method is threaded. The default number of threads is equal to the number of CPUs in the system. Use threadpoolctl to override:
>>> import threadpoolctl >>> >>> with threadpoolctl.threadpool_limits(limits=2): ... m = mmread(StringIO(text), spmatrix=False)