numpy.linalg.slogdet#
- linalg.slogdet(a)[源代码]#
计算数组行列式的符号和(自然)对数.
如果数组具有非常小或非常大的行列式,则调用
det可能会溢出或下溢.此例程对于此类问题更具鲁棒性,因为它计算的是行列式的对数,而不是行列式本身.- 参数:
- a(…, M, M) array_like
输入数组,必须是方阵 2-D 数组.
- 返回:
- 具有以下属性的命名元组:
- sign(…) array_like
表示行列式符号的数字.对于实数矩阵,这是 1,0 或 -1.对于复数矩阵,这是一个绝对值为 1(即,在单位圆上)的复数,否则为 0.
- logabsdet(…) array_like
行列式绝对值的自然对数.
- 如果行列式为零,则 sign 将为 0 并且 logabsdet
- 将为 -inf.在所有情况下,行列式都等于
sign * np.exp(logabsdet).
参见
注释
应用广播规则,有关详细信息,请参见
numpy.linalg文档.行列式通过使用 LAPACK 例程
z/dgetrf的 LU 分解计算.示例
2-D 数组
[[a, b], [c, d]]的行列式是ad - bc:>>> import numpy as np >>> a = np.array([[1, 2], [3, 4]]) >>> (sign, logabsdet) = np.linalg.slogdet(a) >>> (sign, logabsdet) (-1, 0.69314718055994529) # may vary >>> sign * np.exp(logabsdet) -2.0
计算矩阵堆栈的对数行列式:
>>> a = np.array([ [[1, 2], [3, 4]], [[1, 2], [2, 1]], [[1, 3], [3, 1]] ]) >>> a.shape (3, 2, 2) >>> sign, logabsdet = np.linalg.slogdet(a) >>> (sign, logabsdet) (array([-1., -1., -1.]), array([ 0.69314718, 1.09861229, 2.07944154])) >>> sign * np.exp(logabsdet) array([-2., -3., -8.])
此例程在普通
det失败的地方可以成功:>>> np.linalg.det(np.eye(500) * 0.1) 0.0 >>> np.linalg.slogdet(np.eye(500) * 0.1) (1, -1151.2925464970228)