`np.fromfunction()` 并非对每个坐标点逐次调用函数,而是将整张索引网格(如 `i`, `j` 数组)一次性传入函数;若函数未利用这些输入数组进行广播运算,将导致标量返回、结果降维。
numpy.fromfunction(func, shape, **kwargs) 是一个常被误解的函数。它的核心机制是:预先生成与目标数组形状一致的索引数组(如 i 表示行索引,j 表示列索引),并将这些索引数组作为参数一次性传给 func;func 必须返回一个与 shape 兼容的数组(通常通过 NumPy 广播实现),而非标量值。
以 shape=(2, 2) 为例,fromfunction 内部会构造:
i = np.array([[0., 0.],
[1., 1.]]) # 每行对应行号,广播至整列
j = np.array([[0., 1.],
[0., 1.]]) # 每列对应列号,广播至整行然后执行
func(i, j) —— 注意:这是单次函数调用,输入是两个二维数组,不是四次调用 (0,0), (0,1), (1,0), (1,1)。
因此:
✅ 正确写法(推荐显式利用索引):
import numpy as np # 创建全 1 数组(利用广播) arr1 = np.fromfunction(lambda i, j: np.ones_like(i), shape=(2, 2), dtype=float) print(arr1) # [[1. 1.] # [1. 1.]] # 或更自然地:基于索引但保持广播性 arr2 = np.fromfunction(lambda i, j: 0*i + 0*j + 1, shape=(2, 2), dtype=float) print(arr2) # [[1. 1.] # [1. 1.]]
⚠️ 注意事项:
总之,fromfunction 是“向量化构造器”,不是“逐点映射器”——理解其输入为广播索引数组,是正确使用它的关键。