Source code for quantify_scheduler.backends.qblox.operations.control_flow_library

# Repository: https://gitlab.com/quantify-os/quantify-scheduler
# Licensed according to the LICENCE file on the main branch
"""Contains the control flow operations for the Qblox backend."""

from __future__ import annotations

from typing import TYPE_CHECKING

from quantify_scheduler.backends.qblox import constants
from quantify_scheduler.operations.control_flow_library import (
    ConditionalOperation as _ConditionalOperation,
)

if TYPE_CHECKING:
    from quantify_scheduler.operations.operation import Operation
    from quantify_scheduler.schedules.schedule import Schedule


[docs] class ConditionalOperation(_ConditionalOperation): """ Conditional over another operation. If a preceding thresholded acquisition on ``qubit_name`` results in a "1", the body will be executed, otherwise it will generate a wait time that is equal to the time of the subschedule, to ensure the absolute timing of later operations remains consistent. Parameters ---------- body Operation to be conditionally played qubit_name Name of the device element on which the body will be conditioned t0 Time offset, by default 0 Example ------- A conditional reset can be implemented as follows: .. jupyter-execute:: # relevant imports from quantify_scheduler import Schedule from quantify_scheduler.qblox.operations import ConditionalOperation from quantify_scheduler.operations import Measure, X # define conditional reset as a Schedule conditional_reset = Schedule("conditional reset") conditional_reset.add(Measure("q0", feedback_trigger_label="q0")) conditional_reset.add( ConditionalOperation(body=X("q0"), qubit_name="q0"), rel_time=364e-9, ) """ def __init__( self, body: Operation | Schedule, qubit_name: str, t0: float = 0.0, ) -> None: super().__init__( body, qubit_name, t0, hardware_buffer_time=constants.MIN_TIME_BETWEEN_OPERATIONS * 1e-9, )