- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当对numpy.ndarray
求和时,它会减少数组的维数,除非我们设置keepdims=True
。然而,这对于 Scipy 的稀疏矩阵来说似乎并非如此:
import scipy.sparse
matrix = scipy.sparse.coo_matrix([[0, 1], [2, 1]])
print(matrix.shape) # (2, 2) as expected.
print(matrix.sum().shape) # () as expected.
print(matrix.sum(axis=0).shape) # (1, 2) but expected (2,).
print(matrix.sum(axis=0)[0].shape) # (1, 2) but expected (2,).
如示例中最后一行所示,我什至无法选择结果向量。此外,尝试将总和的结果转换为密集 Numpy 数组会失败:
matrix.toarray() # This works.
matrix.sum(axis=0).toarray() # AttributeError: 'matrix' has no 'toarray'.
如何计算稀疏矩阵沿一维的总和并获得密集数组的结果?
最佳答案
稀疏矩阵虽然是一个不同的类(类取决于格式),但尝试表现得像 np.matrix
(而后者的表现又像老式的 MATLAB 矩阵)。它的形状始终是 2d,索引、求和和相关操作返回 2d。
In [172]: M = sparse.csr_matrix([[0,1],[2,1]])
In [173]: M
Out[173]:
<2x2 sparse matrix of type '<class 'numpy.int32'>'
with 3 stored elements in Compressed Sparse Row format>
总和生成标量或 0d 数组:
In [174]: M.sum()
Out[174]: 4
In [175]: _.shape
Out[175]: ()
In [176]: type(__)
Out[176]: numpy.int32
轴和产生二维列或行向量密集矩阵:
In [177]: M.sum(axis=0)
Out[177]: matrix([[2, 2]], dtype=int32)
In [178]: _.shape
Out[178]: (1, 2)
In [179]: M.sum(axis=1)
Out[179]:
matrix([[1],
[3]])
In [180]: _.shape
Out[180]: (2, 1)
这与从密集矩阵中获得的行为相同,例如M.todense()
。 keepdims=True
为数组提供了类似的功能(来自 MATLAB 的人提示 sum
减少了维度)。
稠密矩阵有一个方便的 .A1
属性,可以将其转换为一维数组:
In [181]: M.sum(axis=1).A1
Out[181]: array([1, 3])
In [182]: M.sum(axis=0).A1
Out[182]: array([2, 2], dtype=int32)
.A
适用于稀疏矩阵和稠密矩阵,但只有稀疏矩阵有 toarray
方法(和 todense
)。就像我说的,稀疏矩阵模仿稠密矩阵,但不是子类。
稀疏轴和实际上是进行矩阵乘法;稠密矩阵 * 稀疏矩阵产生稠密矩阵:
In [186]: M*np.matrix([[1],[1]])
Out[186]:
matrix([[1],
[3]], dtype=int32)
In [187]: np.matrix([[1,1]])*M
Out[187]: matrix([[2, 2]], dtype=int32)
关于数组总和没有留下这个“空”(单数是一个术语,1而不是0)维度的提示:
Why does the shape remains same when I sum a square numpy array along either directions?
关于python - 为什么对稀疏矩阵求和会留下空维度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47602925/
目前,我在单击我的正文时打开一个新选项卡,但它将焦点更改为子窗口。但我想通过留下窗口来做到这一点,这样弹出窗口就不会被阻止,并且我可以将焦点放在当前窗口上。 以下代码当前正在运行 /** * For
我有一个带有线性渐变的 css 背景图像。 CSS 代码: .footer-about { display: flex; align-items: center; justif
在服务中包含以下代码(假设在快速端点上): async function (res, req, next) { const fetch = require('node-fetch'); awa
我正在使用 IImageList 和 SHGetFileInfo 为任何给定路径提取巨型图标。一旦我有了它,然后我使用 DrawIconEx 将 HICON 渲染到 HBITMAP 中,最终使用 GD
我有图表并计算了网络密度,现在我应该只保留具有最大权重的分支(网络密度的前 10%,例如 200 中权重最大的 20 个分支)。我找不到该怎么做? 最佳答案 这个问题有点令人困惑,因此,如果稍后出现更
我一直在尝试使用 jquery 创建一种效果,当您将鼠标移到一个 div 上时,整个 body 都会移动,并沿着它经过的点留下一条轨迹。我创建了一个可以使整个 body 移动的功能,但我找不到离开轨迹
我想在桌面上显示放大和缩小图标(控件),而仅在移动设备上浏览时显示 gps 图标。我正在使用这个 css https://unpkg.com/leaflet@1.1.0/dist/leaflet.cs
相关代码(索引为数组大小): typedef struct elemento { unsigned long linha; unsigned long coluna; doub
我有一个 div,因此当我单击时,它会切换为展开或缩回。它在所有浏览器上都运行良好,尽管有一点让我很感兴趣。在谷歌浏览器上,当它缩回时,它会在运动中留下细线。 www.rezoluz.com/logi
每当我的应用程序尝试通过调用 CreateDIBSection() 或使用 LR_CREATEDIBSECTION 标志调用 LoadImage() 来创建 DIB 部分时,它似乎都会成功返回。它返回
我想在 Protractor 测试中脱离 Selenium 控制流。 以下是我迄今为止遇到的步骤和问题: 1。逐个测试禁用它 我的第一个想法是使用 SELENIUM_PROMISE_MANAGER 以
我正在构建一个部署在 CentOS 7.2 上的 ASP.Net Core (netcore 1.1) 应用程序。 我有一个通过 System.Diagnostics.Process 调用外部进程(也
我正在为我的网站创建一个聊天小部件。用户将能够输入纯文本 - 没有 html。 为了消除 HTML 标记并允许用户使用“”,我正在接受他们的输入并在用户屏幕的输入上使用 strip_tags() 和输
我是一名优秀的程序员,十分优秀!