numpy.linalg.slogdet#
- linalg.slogdet(a)[источник]#
Вычислите знак и (натуральный) логарифм определителя массива.
Если массив имеет очень маленький или очень большой определитель, то вызов
detможет вызвать переполнение или потерю значимости. Эта процедура более устойчива к таким проблемам, поскольку вычисляет логарифм определителя, а не сам определитель.- Параметры:
- a(…, M, M) array_like
Входной массив, должен быть квадратным 2-D массивом.
- Возвращает:
- Именованный кортеж со следующими атрибутами:
- знак(…) array_like
Число, представляющее знак определителя. Для вещественной матрицы это 1, 0 или -1. Для комплексной матрицы это комплексное число с абсолютным значением 1 (т.е. на единичной окружности) или 0.
- logabsdet(…) array_like
Натуральный логарифм абсолютного значения определителя.
- Если определитель равен нулю, то
signбудет 0 и logabsdet - будет -inf. Во всех случаях определитель равен
sign * np.exp(logabsdet).
Смотрите также
Примечания
Применяются правила трансляции, см.
numpy.linalgдокументации для подробностей.Определитель вычисляется через LU-факторизацию с использованием подпрограммы LAPACK
z/dgetrf.Примеры
Определитель двумерного массива
[[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)