Skip to content

perm_sign

Calculates the permutation sign.

perm_sign

perm_sign(perm: ndarray | list[int]) -> float

Compute the "sign" of a permutation 1.

The sign (either -1 or 1) of the permutation perm is -1**inv, where inv is the number of inversions contained in perm.

Examples: For the following vector

\[ [1, 2, 3, 4] \]

the permutation sign is positive as the number of elements in the vector are even. This can be performed in |toqito⟩ as follows.

from toqito.perms import perm_sign

print(perm_sign([1, 2, 3, 4]))

1.0

For the following vector

\[ [1, 2, 3, 4, 5] \]

the permutation sign is negative as the number of elements in the vector are odd. This can be performed in |toqito⟩ as follows.

from toqito.perms import perm_sign

print(perm_sign([1, 2, 4, 3, 5]))

-1.0

Parameters:

  • perm (ndarray | list[int]) –

    The permutation vector to be checked.

Returns:

  • float

    The value 1 if the permutation is of even length and the value of -1 if the permutation is of odd length.

References

1 Wikipedia. Parity of a permutation. link.

Source code in toqito/perms/perm_sign.py
def perm_sign(perm: np.ndarray | list[int]) -> float:
    r"""Compute the "sign" of a permutation [@WikiParPerm].

    The sign (either -1 or 1) of the permutation `perm` is `-1**inv`, where `inv` is the number of
    inversions contained in `perm`.

    Examples:
    For the following vector

    \[
        [1, 2, 3, 4]
    \]

    the permutation sign is positive as the number of elements in the vector are even. This can be performed in
    `|toqito⟩` as follows.

    ```python exec="1" source="above"
    from toqito.perms import perm_sign

    print(perm_sign([1, 2, 3, 4]))
    ```

    For the following vector

    \[
        [1, 2, 3, 4, 5]
    \]

    the permutation sign is negative as the number of elements in the vector are odd. This can be performed in
    `|toqito⟩` as follows.

    ```python exec="1" source="above"
    from toqito.perms import perm_sign

    print(perm_sign([1, 2, 4, 3, 5]))
    ```

    Args:
        perm: The permutation vector to be checked.

    Returns:
        The value 1 if the permutation is of even length and the value of -1 if the permutation is of odd length.

    """
    return linalg.det(np.eye(len(perm))[:, np.array(perm) - 1])