jax.dlpack.from_dlpack#

jax.dlpack.from_dlpack(external_array, device=None, copy=None)[源]#

返回 DLPack 张量的 Array 表示。

如果没有请求设备传输或复制,则返回的 Arrayexternal_array 共享内存。

参数:
  • external_array – 具有 __dlpack____dlpack_device__ 方法的数组对象。

  • device (xla_client.Device | Sharding | None) – (可选) Device,表示应放置返回数组的设备。 如果给定,则结果将提交到该设备。 如果未指定,则生成的数组将被解包到它最初来自的同一设备上。 将 device 设置为与 external_array 的源不同的设备将需要复制,这意味着 copy 必须设置为 TrueNone

  • copy (bool | None) – (可选) 布尔值,控制是否执行复制。 如果 copy=True,则始终执行复制,即使解包到同一设备上也是如此。 如果 copy=False,则永远不会执行复制,并且如果需要,将引发错误。 当 copy=None 时,如果设备传输需要,则可以执行复制。

返回:

jax.Array

注意

虽然 JAX 数组始终是不可变的,但 dlpack 缓冲区无法标记为不可变,并且 JAX 外部的进程可能会就地修改它们。 如果从 dlpack 缓冲区构造 jax Array,并且该缓冲区稍后被就地修改,则在使用关联的 JAX 数组时可能会导致未定义的行为。