Source code for toqito.state_props.is_ensemble

"""Checks if a set of quantum states form an ensemble."""

import numpy as np

from toqito.matrix_props import is_positive_semidefinite


[docs] def is_ensemble(states: list[np.ndarray]) -> bool: r"""Determine if a set of states constitute an ensemble. For more info, see Section: Ensemble Of Quantum States from [@Watrous_2018_TQI]. An ensemble of quantum states is defined by a function \[ \eta : \Gamma \rightarrow \text{Pos}(\mathcal{X}) \] that satisfies \[ \text{Tr}\left( \sum_{a \in \Gamma} \eta(a) \right) = 1. \] Examples: Consider the following set of matrices \[ \eta = \left\{ \rho_0, \rho_1 \right\} \] where \[ \rho_0 = \frac{1}{2} \begin{pmatrix} 1 & 0 \\ 0 & 0 \end{pmatrix}, \quad \rho_1 = \frac{1}{2} \begin{pmatrix} 0 & 0 \\ 0 & 1 \end{pmatrix}. \] The set \(\eta\) constitutes a valid ensemble. ```python exec="1" source="above" from toqito.state_props import is_ensemble import numpy as np rho_0 = np.array([[0.5, 0], [0, 0]]) rho_1 = np.array([[0, 0], [0, 0.5]]) states = [rho_0, rho_1] print(is_ensemble(states)) ``` Args: states: The list of states to check. Returns: `True` if states form an ensemble and `False` otherwise. """ trace_sum = 0 for state in states: trace_sum += np.trace(state) # Constraint: All states in ensemble must be positive semidefinite. if not is_positive_semidefinite(state): return False # Constraint: The sum of the traces of all states within the ensemble must # be equal to 1. return np.allclose(trace_sum, 1)