jax.dlpack.from_dlpack#
- jax.dlpack.from_dlpack(external_array, device=None, copy=None)[source]#
返回 DLPack 张量的
Array
表示形式。如果未请求设备传输或复制,则返回的
Array
与external_array
共享内存。- 参数:
external_array – 具有
__dlpack__
和__dlpack_device__
方法的数组对象。device (xla_client.Device | Sharding | None | None) – (可选的)
Device
,表示返回的数组应放置在其上的设备。如果给定,则结果将提交到设备。如果未指定,则结果数组将被解包到其原始来源的同一设备上。将device
设置为与external_array
的来源不同的设备将需要复制,这意味着copy
必须设置为True
或None
。copy (bool | None | None) – (可选的)布尔值,控制是否执行复制。如果
copy=True
,则始终执行复制,即使解包到同一设备上也是如此。如果copy=False
,则永远不会执行复制,如果必要则会引发错误。当copy=None
时,如果需要进行设备传输,则可能会执行复制。
- 返回:
一个 jax.Array
注意
虽然 JAX 数组始终是不可变的,但 dlpack 缓冲区不能标记为不可变的,并且 JAX 外部的进程可能会就地修改它们。如果从 dlpack 缓冲区构造 jax Array,并且该缓冲区稍后被就地修改,则在使用关联的 JAX 数组时可能会导致未定义的行为。