jax.scipy.linalg.eigh#

jax.scipy.linalg.eigh(a: ArrayLike, b: ArrayLike | None = None, lower: bool = True, eigvals_only: Literal[False] = False, overwrite_a: bool = False, overwrite_b: bool = False, turbo: bool = True, eigvals: None = None, type: int = 1, check_finite: bool = True) tuple[Array, Array][来源]#
jax.scipy.linalg.eigh(a: ArrayLike, b: ArrayLike | None = None, lower: bool = True, *, eigvals_only: Literal[True], overwrite_a: bool = False, overwrite_b: bool = False, turbo: bool = True, eigvals: None = None, type: int = 1, check_finite: bool = True) Array
jax.scipy.linalg.eigh(a: ArrayLike, b: ArrayLike | None, lower: bool, eigvals_only: Literal[True], overwrite_a: bool = False, overwrite_b: bool = False, turbo: bool = True, eigvals: None = None, type: int = 1, check_finite: bool = True) Array
jax.scipy.linalg.eigh(a: ArrayLike, b: ArrayLike | None = None, lower: bool = True, eigvals_only: bool = False, overwrite_a: bool = False, overwrite_b: bool = False, turbo: bool = True, eigvals: None = None, type: int = 1, check_finite: bool = True) Array | tuple[Array, Array]

计算厄米矩阵的特征值和特征向量

JAX 实现 scipy.linalg.eigh()

仅支持标准特征值问题:a @ v = lambda * v

参数 b 必须为 None;未实现广义问题(a @ v = lambda * b @ v)。

参数:
  • a – 厄米输入数组,形状为 (..., N, N)

  • b – 必须为 None。不支持广义特征值问题。

  • lower – 如果为 True(默认),则仅访问输入矩阵的下三角部分。否则,仅访问上三角部分。

  • eigvals_only – 如果为 True,则仅计算特征值。如果为 False(默认),则同时计算特征值和特征向量。

  • type – 未使用。仅支持 type=1。

  • eigvals – 未使用。仅支持 eigvals=None。

  • overwrite_a – JAX 未使用。

  • overwrite_b – JAX 未使用。

  • turbo – JAX 未使用。

  • check_finite – JAX 未使用。

返回:

如果 eigvals_only 为 False,则返回一个元组 (eigvals, eigvecs),否则返回一个数组 eigvals

  • eigvals: 包含特征值的数组,形状为 (..., N)

  • eigvecs: 包含特征向量的数组,形状为 (..., N, N)

引发:

NotImplementedError – 如果 b 不为 None。

另请参阅

示例

计算一个简单的 2x2 矩阵的标准特征值分解

>>> a = jnp.array([[2., 1.],
...                [1., 2.]])
>>> eigvals, eigvecs = jax.scipy.linalg.eigh(a)
>>> eigvals
Array([1., 3.], dtype=float32)
>>> eigvecs
Array([[-0.70710677,  0.70710677],
       [ 0.70710677,  0.70710677]], dtype=float32)

特征向量是正交的

>>> jnp.allclose(eigvecs.T @ eigvecs, jnp.eye(2), atol=1E-5)
Array(True, dtype=bool)

解满足特征值问题

>>> jnp.allclose(a @ eigvecs, eigvecs @ jnp.diag(eigvals))
Array(True, dtype=bool)