jax.lax.psend#
- jax.lax.psend(x, axis_name, perm)[source]#
Perform a collective send according to the permutation
perm
.If
x
is a pytree then the result is equivalent to mapping this function to each leaf in the tree.This function is an analog of the Send HLO.
- Parameters:
x – array(s) with a mapped axis named
axis_name
.axis_name – hashable Python object used to name a pmapped axis (see the
jax.pmap()
documentation for more details).perm – list of pairs of ints, representing
(source_index, destination_index)
pairs that encode how the mapped axis namedaxis_name
should be shuffled. The integer values are treated as indices into the mapped axisaxis_name
. Any two pairs should not have the same source index or the same destination index. For each index of the axisaxis_name
that does not correspond to a destination index inperm
, the corresponding values in the result are filled with zeros of the appropriate type. The semantics here are platform-specific, and for GPU they correspond to NCCL send.
- Returns:
A compiler token that can be used by precv and lax.optimzation_barrier to enforce ordering of collective ops.