Для розрідженої матриці SciPy можна використовувати todense()
або toarray()
перетворити на матрицю чи масив NumPy. Які функції виконувати обернено?
Я шукав, але не уявляв, які ключові слова повинні бути правильним.
Відповіді:
Ви можете передавати масив чи матрицю numpy як аргумент при ініціалізації розрідженої матриці. Наприклад, для матриці КСВ ви можете зробити наступне.
>>> import numpy as np
>>> from scipy import sparse
>>> A = np.array([[1,2,0],[0,0,3],[1,0,4]])
>>> B = np.matrix([[1,2,0],[0,0,3],[1,0,4]])
>>> A
array([[1, 2, 0],
[0, 0, 3],
[1, 0, 4]])
>>> sA = sparse.csr_matrix(A) # Here's the initialization of the sparse matrix.
>>> sB = sparse.csr_matrix(B)
>>> sA
<3x3 sparse matrix of type '<type 'numpy.int32'>'
with 5 stored elements in Compressed Sparse Row format>
>>> print sA
(0, 0) 1
(0, 1) 2
(1, 2) 3
(2, 0) 1
(2, 2) 4
sparse.csr_matrix
Існує кілька розріджених матричних класів у scipy.
bsr_matrix (arg1 [, фігура, dtype, копія, розмір блоку]) Блок матриці
розрідженого рядка coo_matrix (arg1 [, фігура, dtype, копія]) Розріджена матриця у форматі COOrdinate.
csc_matrix (arg1 [, shape, dtype, copy])
Стиснута розріджена матриця стовпця csr_matrix (arg1 [, shape, dtype, copy])
Стиснута розріджена матриця dia_matrix (arg1 [, shape, dtype, copy]) Розріджена матриця з DIAgonal зберіганням
dok_matrix (arg1 [, фігура, dtype, копія]) Розрядна матриця на основі словника ключів.
lil_matrix (arg1 [, shape, dtype, copy]) Розріджена матриця на основі рядків
Будь-який з них може зробити перетворення.
import numpy as np
from scipy import sparse
a=np.array([[1,0,1],[0,0,1]])
b=sparse.csr_matrix(a)
print(b)
(0, 0) 1
(0, 2) 1
(1, 2) 1
Див. Http://docs.scipy.org/doc/scipy/reference/sparse.html#usage-information .
Що стосується зворотного, функція є inv(A)
, але я не рекомендуватиму її використовувати, оскільки для величезних матриць вона дуже обчислювально затратна і нестабільна. Натомість вам слід використовувати наближення до оберненого, або якщо ви хочете вирішити Ax = b, вам насправді не потрібно A -1 .