numpy.ufunc.reduce#

方法

ufunc.reduce(array, axis=0, dtype=None, out=None, keepdims=False, initial=<no value>, where=True)#

沿着一个轴应用 ufunc,将array的维度减一。

\(array.shape = (N_0, ..., N_i, ..., N_{M-1})\)。则 \(ufunc.reduce(array, axis=i)[k_0, ..,k_{i-1}, k_{i+1}, .., k_{M-1}]\) = 对 \(range(N_i)\) 中的每个 j 进行迭代的结果,累积地将 ufunc 应用于每个 \(array[k_0, ..,k_{i-1}, j, k_{i+1}, .., k_{M-1}]\)。对于一维数组,reduce产生的结果等价于

r = op.identity # op = ufunc
for i in range(len(A)):
  r = op(r, A[i])
return r

例如,add.reduce() 等价于 sum()。

参数:
arrayarray_like

要操作的数组。

axisNone 或 int 或 int 元组,可选

执行约简的轴或轴组。默认值 (axis = 0) 是对输入数组的第一维执行约简。axis 可以为负数,在这种情况下,它从最后一个轴到第一个轴进行计数。

如果为 None,则对所有轴执行约简。如果这是一个 int 元组,则会对多个轴执行约简,而不是像以前那样对单个轴或所有轴执行约简。

对于既不是可交换的也不是可结合的操作,对多个轴进行约简是没有明确定义的。ufunc 目前不会在此情况下引发异常,但在将来可能会这样做。

dtype数据类型代码,可选

用于执行操作的数据类型。如果给出,则默认为 out 的数据类型;否则默认为 array 的数据类型(尽管对于某些情况,例如整数或布尔输入的 numpy.add.reduce,会向上转换以保留精度)。

outndarray、None 或 ndarray 和 None 的元组,可选

存储结果的位置。如果未提供或为 None,则返回一个新分配的数组。为了与 ufunc.__call__ 保持一致,如果作为关键字给出,则可以使用 1 元素元组将其包装。

keepdimsbool,可选

如果将其设置为 True,则约简的轴将保留在结果中,其大小为一。使用此选项,结果将与原始 array 正确广播。

initial标量,可选

用于启动约简的值。如果 ufunc 没有恒等式或 dtype 为 object,则默认为 None;否则默认为 ufunc.identity。如果给出 None,则使用约简的第一个元素,如果约简为空,则会引发错误。

where布尔值的 array_like,可选

一个布尔数组,其广播以匹配 array 的维度,并选择要包含在约简中的元素。请注意,对于像 minimum 这样未定义恒等式的 ufunc,必须同时传入 initial

返回:
rndarray

约简后的数组。如果提供了 out,则 r 是对它的引用。

示例

>>> import numpy as np
>>> np.multiply.reduce([2,3,5])
30

多维数组示例

>>> X = np.arange(8).reshape((2,2,2))
>>> X
array([[[0, 1],
        [2, 3]],
       [[4, 5],
        [6, 7]]])
>>> np.add.reduce(X, 0)
array([[ 4,  6],
       [ 8, 10]])
>>> np.add.reduce(X) # confirm: default axis value is 0
array([[ 4,  6],
       [ 8, 10]])
>>> np.add.reduce(X, 1)
array([[ 2,  4],
       [10, 12]])
>>> np.add.reduce(X, 2)
array([[ 1,  5],
       [ 9, 13]])

您可以使用 initial 关键字参数用不同的值初始化约简,并使用 where 选择要包含的特定元素。

>>> np.add.reduce([10], initial=5)
15
>>> np.add.reduce(np.ones((2, 2, 2)), axis=(0, 2), initial=10)
array([14., 14.])
>>> a = np.array([10., np.nan, 10])
>>> np.add.reduce(a, where=~np.isnan(a))
20.0

允许约简通常会失败的空数组,例如对于没有恒等式的 ufunc。

>>> np.minimum.reduce([], initial=np.inf)
inf
>>> np.minimum.reduce([[1., 2.], [3., 4.]], initial=10., where=[True, False])
array([ 1., 10.])
>>> np.minimum.reduce([])
Traceback (most recent call last):
    ...
ValueError: zero-size array to reduction operation minimum which has no identity