scipy.sparse.

diags_array#

scipy.sparse.diags_array(diagonals, /, *, offsets=0, shape=None, format=None, dtype=None)[源代码][源代码]#

从对角线构建稀疏数组。

参数:
对角线类似数组的序列

包含数组对角线的数组序列,对应于 offsets

偏移量整数序列或单个整数,可选
要设置的对角线:
  • k = 0 主对角线(默认)

  • k > 0 第 k 条上对角线

  • k < 0 第 k 条下对角线

形状整数元组,可选

结果的形状。如果省略,将返回一个足够大的方形数组以包含对角线。

格式{“dia”, “csr”, “csc”, “lil”, …}, 可选

结果的矩阵格式。默认情况下(format=None),将返回适当的稀疏数组格式。此选择可能会更改。

dtypedtype, 可选

数组的类型。

注释

diags_array 的结果是以下内容的稀疏等价物:

np.diag(diagonals[0], offsets[0])
+ ...
+ np.diag(diagonals[k], offsets[k])

不允许重复的对角偏移。

Added in version 1.11.

示例

>>> from scipy.sparse import diags_array
>>> diagonals = [[1, 2, 3, 4], [1, 2, 3], [1, 2]]
>>> diags_array(diagonals, offsets=[0, -1, 2]).toarray()
array([[1, 0, 1, 0],
       [1, 2, 0, 2],
       [0, 2, 3, 0],
       [0, 0, 3, 4]])

标量的广播是被支持的(但需要指定形状):

>>> diags_array([1, -2, 1], offsets=[-1, 0, 1], shape=(4, 4)).toarray()
array([[-2.,  1.,  0.,  0.],
       [ 1., -2.,  1.,  0.],
       [ 0.,  1., -2.,  1.],
       [ 0.,  0.,  1., -2.]])

如果只需要一条对角线(如 numpy.diag 中),以下方法同样适用:

>>> diags_array([1, 2, 3], offsets=1).toarray()
array([[ 0.,  1.,  0.,  0.],
       [ 0.,  0.,  2.,  0.],
       [ 0.,  0.,  0.,  3.],
       [ 0.,  0.,  0.,  0.]])