首页 >后端开发 >Python教程 >在 NumPy 数组上映射函数的最有效方法是什么?

在 NumPy 数组上映射函数的最有效方法是什么?

Barbara Streisand
Barbara Streisand原创
2025-01-04 03:50:39456浏览

What's the Most Efficient Way to Map Functions Over a NumPy Array?

高效的 Numpy 数组映射策略

当涉及到 Numpy 数组上的映射函数时,性能效率至关重要。出现了一个基本问题:“映射操作最有效的方法是什么?”

低效方法:Python 列表理解

问题中提供的示例使用了一个列表理解:

squares = np.array([squarer(xi) for xi in x])

虽然这种方法有效,但由于从 a 的中间转换,它具有固有的低效率。 Python列表返回Numpy数组。

优化策略

测试各种方法,出现最佳解决方案:

1.使用内置 Numpy 函数:

如果您要映射的函数已在 Numpy 中进行矢量化(例如 x^2),则直接使用它可提供卓越的性能:

squares = x ** 2

2。使用 numpy.vectorize 进行矢量化:

对于自定义函数,使用 numpy.vectorize 进行矢量化显示出显着的速度提升:

f = lambda x: x ** 2
vf = np.vectorize(f)
squares = vf(x)

3。 numpy.fromiter:

此方法从函数创建迭代器,并使用 numpy.fromiter 高效构造 Numpy 数组:

squares = np.fromiter((squarer(xi) for xi in x), x.dtype)

4。 numpy.array(list(map(...)):

另一个优化的替代方案是使用map,然后将其转换为Numpy数组:

squares = np.array(list(map(squarer, x)))

进行的基准测试使用 perfplot 证明这些优化方法明显优于原始列表理解方法。

以上是在 NumPy 数组上映射函数的最有效方法是什么?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn