- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我看到了我无法理解的 numpy bincount 行为。我想按行方式将二维数组中的值装箱,并查看下面的行为。为什么它可以与 dbArray 一起工作但与 simarray 一起失败?
>>> dbArray
array([[1, 0, 1, 0, 1],
[1, 1, 1, 1, 1],
[1, 1, 0, 1, 1],
[1, 0, 0, 0, 0],
[0, 0, 0, 1, 1],
[0, 1, 0, 1, 0]])
>>> N.apply_along_axis(N.bincount,1,dbArray)
array([[2, 3],
[0, 5],
[1, 4],
[4, 1],
[3, 2],
[3, 2]], dtype=int64)
>>> simarray
array([[2, 0, 2, 0, 2],
[2, 1, 2, 1, 2],
[2, 1, 1, 1, 2],
[2, 0, 1, 0, 1],
[1, 0, 1, 1, 2],
[1, 1, 1, 1, 1]])
>>> N.apply_along_axis(N.bincount,1,simarray)
Traceback (most recent call last):
File "<pyshell#31>", line 1, in <module>
N.apply_along_axis(N.bincount,1,simarray)
File "C:\Python27\lib\site-packages\numpy\lib\shape_base.py", line 118, in apply_along_axis
outarr[tuple(i.tolist())] = res
ValueError: could not broadcast input array from shape (2) into shape (3)
最佳答案
问题是 bincount
并不总是返回相同形状的对象,尤其是在缺少值时。例如:
>>> m = np.array([[0,0,1],[1,1,0],[1,1,1]])
>>> np.apply_along_axis(np.bincount, 1, m)
array([[2, 1],
[1, 2],
[0, 3]])
>>> [np.bincount(m[i]) for i in range(m.shape[1])]
[array([2, 1]), array([1, 2]), array([0, 3])]
有效,但是:
>>> m = np.array([[0,0,0],[1,1,0],[1,1,0]])
>>> m
array([[0, 0, 0],
[1, 1, 0],
[1, 1, 0]])
>>> [np.bincount(m[i]) for i in range(m.shape[1])]
[array([3]), array([1, 2]), array([1, 2])]
>>> np.apply_along_axis(np.bincount, 1, m)
Traceback (most recent call last):
File "<ipython-input-49-72e06e26a718>", line 1, in <module>
np.apply_along_axis(np.bincount, 1, m)
File "/usr/local/lib/python2.7/dist-packages/numpy/lib/shape_base.py", line 117, in apply_along_axis
outarr[tuple(i.tolist())] = res
ValueError: could not broadcast input array from shape (2) into shape (1)
不会。
您可以使用 minlength
参数并使用 lambda
或 partial
或其他方式传递它:
>>> np.apply_along_axis(lambda x: np.bincount(x, minlength=2), axis=1, arr=m)
array([[3, 0],
[1, 2],
[1, 2]])
关于python - numpy bincount 可以处理二维数组吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19201972/
我有一个包含字符串值的 NumPy 数组。 例如:["bus", "bar", "bar", "café".....] 计算数组中每个元素出现次数的最佳方法是什么。我目前的解决方案是: # my_li
我正在尝试创建一个 Numpy 优化版本的逆 numpy.bincounts .我意识到 bincounts 不是一对一的,所以我们来谈谈最简单的版本。 import numpy as np def
是否可以使用 np.bincount 但得到最大值而不是权重总和?这里,索引 3 处的 bbb 有两个值,11.1 和 55.5。我想要 55.5,而不是 66.6。我怀疑我选择使用其他功能,但不太确
在 TensorFlow 中,我可以使用 tf.bincount 获取数组中每个元素的计数: x = tf.placeholder(tf.int32, [None]) freq = tf.bincou
我有一个 2d numpy 数组。A 我想将 np.bincount() 应用于矩阵 A 的每一列以生成另一个二维数组 B,它由原始矩阵 A 的每一列的 bincounts 组成。 我的问题是 np.
我看到了我无法理解的 numpy bincount 行为。我想按行方式将二维数组中的值装箱,并查看下面的行为。为什么它可以与 dbArray 一起工作但与 simarray 一起失败? >>> dbA
它的目的是什么?我尝试阅读官方网站,但无法理解。 最佳答案 bincount 返回 计数 每个 bin 中的值从 0 到数组中的最大值,即 np.bincount(my_list) == [count
给定一个整数计数数组c,我如何将其转换为一个整数数组inds,这样np.all(np.bincount(inds) ) == c) 是真的吗? 例如: >>> c = np.array([1,3,2,
给定一个整数数组 c,我如何将它转换成一个整数数组 inds 使得 np.all(np.bincount(inds ) == c) 是真的吗? 例如: >>> c = np.array([1,3,2,
考虑 numpy 数组 a a = np.array([1, 0, 2, 1, 1]) 如果我进行 bin 计数,我会得到整数 np.bincount(a) array([1, 3, 1]) 但是如果
我想使用 bincount 对数组求和,但它只支持 double 。例如,这有效: np.bincount([1, 1, 0],weights=np.array([1, 2, 4])) Out: ar
在我看来,numpy 函数 bincount 非常有用且易于使用,所以我很自然地使用 TensorFlow 中的模拟函数。最近我了解到很遗憾 tf.bincount 没有 GPU 支持(你可以阅读 h
我有关于自行车租赁需求和天气的每小时数据。我想根据好天气和坏天气分别绘制每小时的平均需求量。 当我绘制给定小时的平均需求(不考虑天气)时,我所做的是计算给定小时的租赁总需求,然后除以总小时数: hou
我一直在寻找解决方案here和 here但不知道如何将其应用到我的结构中。 我有 3 个数组:一个由零组成的 (M, N) 和一个由索引组成的 (P,)(有些重复)和一个 (P, N) 值。 我可以用
有没有办法将 bincount 与“axis = 1”一起应用?期望的结果将与列表理解相同: import numpy as np A = np.array([[1,0],[0,0]]) np.arr
我正在尝试获取浮点类型的 numpy 数组的 bincount: w = np.array([0.1, 0.2, 0.1, 0.3, 0.5]) print np.bincount(w) 如何将 bi
我想使用 xarray 的 apply_ufunc API 并行化 numpy.bincount 函数,以下代码是我尝试过的: import numpy as np import xarray as
我有一个带有整数值的 NumPy 数组。矩阵的值范围从 0 到矩阵中的最大元素(换句话说,矩阵中呈现从 0 到最大数据元素的所有数字)。我需要构建有效的(有效意味着快速完全矢量化解决方案)来搜索每行中
我有一个一维数组,我想使用 numpy bincount 创建直方图。它工作正常,但我希望它忽略 NaN 值。 histogram = np.bincount(distancesArray, weig
我有一个包含整数值的 NumPy 数组。矩阵的值范围从 0 到矩阵中的最大元素(换句话说,从 0 到最大数据元素的所有数字都出现在其中)。我需要构建有效(有效意味着快速全矢量化解决方案)来搜索每行中的
我是一名优秀的程序员,十分优秀!