jax.linear_transpose

jax.linear_transpose#

jax.linear_transpose(fun, *primals, reduce_axes=())[source]#

转置一个保证为线性的函数。

对于线性函数,此变换等效于 vjp(),但避免了计算前向传递的开销。

转置函数的输出将始终与 primals 具有完全相同的 dtype,即使某些值被截断(例如,从复数到浮点数,或从 float64 到 float32)。为了避免截断,请在 primals 中使用与转置函数所需输出的完整范围匹配的 dtype。不支持整数 dtype。

参数:
  • fun (Callable) – 要转置的线性函数。

  • *primals – 一个位置参数元组,包含数组、标量或(嵌套的)标准 Python 容器(元组、列表、字典、命名元组,即 pytrees),这些类型用于评估 fun(*primals) 的形状/数据类型。这些参数可以是实数标量/ndarray,但这并非必需:仅访问 shapedtype 属性。请参见下面的示例。(请注意,鸭子类型对象不能是命名元组,因为它们被视为标准 Python 容器。)

返回:

一个可调用对象,用于计算 fun 的转置。此函数的有效输入必须与 fun(*primals) 的结果具有相同的形状/数据类型/结构。输出将是一个元组,其形状/数据类型/结构与 primals 相同。

返回类型:

可调用对象

>>> import jax
>>> import types
>>>
>>> f = lambda x, y: 0.5 * x - 0.5 * y
>>> scalar = types.SimpleNamespace(shape=(), dtype=np.dtype(np.float32))
>>> f_transpose = jax.linear_transpose(f, scalar, scalar)
>>> f_transpose(1.0)
(Array(0.5, dtype=float32), Array(-0.5, dtype=float32))