Source code for toqito.matrix_props.is_anti_hermitian

"""Checks if the matrix is an anti-Hermitian matrix."""

import numpy as np

from toqito.matrix_props.is_hermitian import is_hermitian


[docs] def is_anti_hermitian(mat: np.ndarray, rtol: float = 1e-05, atol: float = 1e-08) -> bool: r"""Check if matrix is anti-Hermitian (a.k.a. skew-Hermitian) [@WikiAntiHerm]. An anti-Hermitian matrix is a complex square matrix that is equal to the negative of its own conjugate transpose. Examples: Consider the following matrix: \[ A = \begin{pmatrix} 2j & -1 + 2j & 4j \\ 1 + 2j & 3j & -1 \\ 4j & 1 & 1j \end{pmatrix} \] our function indicates that this is indeed an anti-Hermitian matrix as it holds that \[ A = -A^*. \] ```python exec="1" source="above" import numpy as np from toqito.matrix_props import is_anti_hermitian mat = np.array([[2j, -1 + 2j, 4j], [1 + 2j, 3j, -1], [4j, 1, 1j]]) print(is_anti_hermitian(mat)) ``` Alternatively, the following example matrix \(B\) defined as \[ B = \begin{pmatrix} 1 & 2 & 3 \\ 4 & 5 & 6 \\ 7 & 8 & 9 \end{pmatrix} \] is not anti-Hermitian. ```python exec="1" source="above" import numpy as np from toqito.matrix_props import is_anti_hermitian mat = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]]) print(is_anti_hermitian(mat)) ``` Args: mat: Matrix to check. rtol: The relative tolerance parameter (default 1e-05). atol: The absolute tolerance parameter (default 1e-08). Returns: Return True if matrix is anti-Hermitian, and False otherwise. """ return is_hermitian(mat * 1j, rtol, atol)