"""
Copyright (c) Entropica Labs Pte Ltd 2025.
Use, distribution and reproduction of this program in its source or compiled
form is prohibited without the express written consent of Entropica Labs Pte
Ltd.
"""
from __future__ import annotations
from pydantic.dataclasses import dataclass
from loom.eka.utilities import dataclass_params
from .utilities import Cbit
[docs]
@dataclass(**dataclass_params)
class LogicalObservable:
"""
Once a logical operator is measured, the details of the measurement are stored in
an instance of LogicalObservable. This dataclass does not store the actual value of
the logical observable but instead the required information on how to calculate it
given the output of a quantum circuit.
Parameters
----------
label : str
Label of the logical observable measurement which is later on used to access the
measurement result
measurements : tuple[Cbit, ...]
Tuple of classical bits from which the logical observable is calculated. The
logical observable is calculated by taking the parity of these measurements.
This includes the readout of data qubits as well as potential updates/
corrections based on data qubit readouts during e.g. split or shrink operations.
"""
label: str
measurements: tuple[Cbit, ...]
def __eq__(self, other: LogicalObservable) -> bool:
return self.label == other.label and set(self.measurements) == set(
other.measurements
)