make np.vectorize返回标量输入的标量值

时间:2016-09-01 13:12:16

标签: python numpy numpy-ufunc

以下代码返回一个数组而不是预期的浮点值。

def f(x):
    return x+1
f = np.vectorize(f, otypes=[np.float])
>>> f(10.5)
array(11.5)

如果输入是标量而不是奇怪的数组类型,有没有办法强制它返回简单的标量值?

我觉得奇怪的是,默认情况下它并没有这样做,因为所有其他ufunc如np.cos,np.sin等都会返回常规标量

修改: 这是有效的代码:

import numpy as np
import functools

def as_scalar_if_possible(func):
    @functools.wraps(func) #this is here just to preserve signature
    def wrapper(*args, **kwargs):
        return func(*args, **kwargs)[()]

    return wrapper

@as_scalar_if_possible
@np.vectorize
def f(x):
    return x + 1

print(f(11.5))#srint 12.5

1 个答案:

答案 0 :(得分:2)

结果在技术上是一个标量,因为它的形状为()。例如,np.array(11.5)[0]不是有效操作,会导致异常。实际上,在大多数情况下,返回的结果将作为标量。

例如

x = np.array(11.5)
print(x + 1) # prints 12.5
print(x < 12) # prints True, rather than [ True]
x[0] # raises IndexError

如果你想获得一个“正确”的标量值,那么你可以只包装vectorised函数来检查返回数组的形状。这就是numpy ufuncs在幕后所做的事情。

例如

import numpy as np

def as_scalar_if_possible(func):
    def wrapper(arr):
        arr = func(arr)
        return arr if arr.shape else np.asscalar(arr)
    return wrapper

@as_scalar_if_possible
@np.vectorize
def f(x):
    return x + 1

print(f(11.5)) # prints 12.5