数组API标准兼容性#

NumPy 的主命名空间以及 numpy.fftnumpy.linalg 命名空间与 Python 数组 API 标准的 2022.12 版本 兼容[1]

NumPy 目标是实现对 2023.12 版本 和未来版本的标准的支持——假设这些未来版本可以根据 NumPy 的 向后兼容性策略 进行升级。

对于希望编写可在 NumPy 和其他数组库中使用的代码的下游库和最终用户的用法指南,我们参考数组 API 标准本身的文档以及 SciPy 和 scikit-learn 中面向代码和开发者的文档。

请注意,为了将符合标准的代码与较旧的 NumPy 版本 (< 2.0) 一起使用,array-api-compat 包可能很有用。为了测试使用 NumPy 的代码是否只使用了符合标准的功能而不是任何 NumPy 特定的功能,可以使用 array-api-strict 包。

历史

NumPy 1.22.0 是第一个包含对数组 API 标准支持的版本,通过一个单独的 numpy.array_api 子模块实现。此模块被标记为实验性(导入时会发出警告),并在 NumPy 2.0 中删除,因为完整支持已包含在主命名空间中。NEP 47NEP 56 描述了在 NumPy 中实现数组 API 标准的动机和范围。

入口点#

NumPy 安装了一个 入口点,可用于发现目的。

>>> from importlib.metadata import entry_points
>>> entry_points(group='array_api', name='numpy')
[EntryPoint(name='numpy', value='numpy', group='array_api')]

请注意,省略 name='numpy' 将导致返回所有安装了入口点的数组 API 标准兼容实现的入口点列表。

脚注

检查#

NumPy 实现 数组 API 检查实用程序。可以通过 __array_namespace_info__() 函数访问这些函数,该函数返回包含检查实用程序的命名空间。

__array_namespace_info__()

获取 NumPy 的数组 API 检查命名空间。