jax.lax.ppermute#

jax.lax.ppermute(x, axis_name, perm)[源]#

根据排列 perm 执行集体置换。

如果 x 是一个 pytree,则结果等同于将此函数映射到树中的每个叶子。

此函数是 CollectivePermute HLO 的一个类似物。

参数:
  • x – 具有名为 axis_name 的映射轴的数组。

  • axis_name – 可哈希的 Python 对象,用于命名 pmapped 轴(有关更多详细信息,请参阅 jax.pmap() 文档)。

  • perm – 整数对列表,表示 (source_index, destination_index) 对,这些对编码了应如何洗牌名为 axis_name 的映射轴。整数值被视为映射轴 axis_name 的索引。任何两个对都不应具有相同的源索引或相同的目标索引。对于轴 axis_name 的每个索引,该索引不对应于 perm 中的目标索引,结果中的相应值将填充适当类型的零。

返回:

x 具有相同形状的数组,其切片沿着轴 axis_namex 中根据排列 perm 收集。