В Python 3 я пытаюсь запустить следующую строку кода, чтобы получить конкретную разреженную матрицу.
sparse.spdiags(np.concatenate((-np.ones((9,1)), np.ones((9,1))), axis=1), [0, 1], 9, 10)
Это дает следующее сообщение об ошибке:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python3/dist-packages/scipy/sparse/construct.py", line 61, in spdiags
return dia_matrix((data, diags), shape=(m,n)).asformat(format)
File "/usr/lib/python3/dist-packages/scipy/sparse/dia.py", line 138, in __init__
% (self.data.shape[0], len(self.offsets)))
ValueError: number of diagonals (9) does not match the number of offsets (2)
Выполнение того, что я понимаю как эквивалентный код в Octave, похоже, дает мне разреженную матрицу.
spdiags([-ones(9,1) ones(9,1)],[0 1],9,10)
Compressed Column Sparse (rows = 9, cols = 10, nnz = 18 [20%])
(1, 1) -> -1
(1, 2) -> 1
(2, 2) -> -1
(2, 3) -> 1
(3, 3) -> -1
(3, 4) -> 1
(4, 4) -> -1
(4, 5) -> 1
(5, 5) -> -1
(5, 6) -> 1
(6, 6) -> -1
(6, 7) -> 1
(7, 7) -> -1
(7, 8) -> 1
(8, 8) -> -1
(8, 9) -> 1
(9, 9) -> -1
(9, 10) -> 1
Любые идеи о том, почему они ведут себя по-разному, и как это исправить?
ДОПОЛНЕНИЕ
У меня есть дополнительная проблема с выводом Scipy.sparse по сравнению с Octave.
ПИТОН
>>> sparse.spdiags(np.concatenate((-np.ones((9,1)),np.ones((9,1))), axis=1).T, [0,1],9,10).A
array([[-1., 1., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., -1., 1., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., -1., 1., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., -1., 1., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., -1., 1., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., -1., 1., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., -1., 1., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., -1., 1., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., -1., 0.]])
>>> sparse.spdiags(np.concatenate((-np.ones((9,1)),np.ones((9,1))), axis=1).T, [0,1],9,10).A.shape
(9, 10)
>>> sparse.spdiags(np.vstack([-np.ones(9),np.ones(9)]), [0,1],9,10).A
array([[-1., 1., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., -1., 1., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., -1., 1., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., -1., 1., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., -1., 1., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., -1., 1., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., -1., 1., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., -1., 1., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., -1., 0.]])
>>> sparse.spdiags(np.vstack([-np.ones(9),np.ones(9)]), [0,1],9,10).A.shape
(9, 10)
>>> sparse.spdiags(np.ones(9)*[[-1],[1]], [0,1],9,10).A
array([[-1., 1., 0., 0., 0., 0., 0., 0., 0., 0.],
[ 0., -1., 1., 0., 0., 0., 0., 0., 0., 0.],
[ 0., 0., -1., 1., 0., 0., 0., 0., 0., 0.],
[ 0., 0., 0., -1., 1., 0., 0., 0., 0., 0.],
[ 0., 0., 0., 0., -1., 1., 0., 0., 0., 0.],
[ 0., 0., 0., 0., 0., -1., 1., 0., 0., 0.],
[ 0., 0., 0., 0., 0., 0., -1., 1., 0., 0.],
[ 0., 0., 0., 0., 0., 0., 0., -1., 1., 0.],
[ 0., 0., 0., 0., 0., 0., 0., 0., -1., 0.]])
>>> sparse.spdiags(np.ones(9)*[[-1],[1]], [0,1],9,10).A.shape
(9, 10)
ОКТАВА
>full(spdiags([-ones(9,1) ones(9,1)],[0 1],9,10))
ans =
-1 1 0 0 0 0 0 0 0 0
0 -1 1 0 0 0 0 0 0 0
0 0 -1 1 0 0 0 0 0 0
0 0 0 -1 1 0 0 0 0 0
0 0 0 0 -1 1 0 0 0 0
0 0 0 0 0 -1 1 0 0 0
0 0 0 0 0 0 -1 1 0 0
0 0 0 0 0 0 0 -1 1 0
0 0 0 0 0 0 0 0 -1 1
>size(full(spdiags([-ones(9,1) ones(9,1)],[0 1],9,10)))
ans =
9 10
Почему scipy и Octave не дают одинакового значения в последнем столбце последней строки?