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

# Repository: https://gitlab.com/quantify-os/quantify-scheduler
# Licensed according to the LICENCE file on the main branch
"""Contains the gate library for the Qblox backend."""
from __future__ import annotations

from quantify_scheduler.backends.qblox.constants import TRIGGER_DELAY
from quantify_scheduler.backends.qblox.operations.control_flow_library import (
    ConditionalOperation,
)
from quantify_scheduler.operations.gate_library import Measure, X
from quantify_scheduler.schedules.schedule import Schedule


[docs] class ConditionalReset(Schedule): r""" Reset a qubit to the :math:`|0\rangle` state. The :class:`~quantify_scheduler.backends.qblox.operations.gate_library.ConditionalReset` gate is a conditional gate that first measures the state of the device element using an :class:`~quantify_scheduler.operations.acquisition_library.ThresholdedAcquisition` operation and then performs a :math:`\pi` rotation on the condition that the measured state is :math:`|1\rangle`. If the measured state is in :math:`|0\rangle`, the hardware will wait the same amount of time the :math:`\pi` rotation would've taken to ensure that total execution time of :class:`~quantify_scheduler.backends.qblox.operations.gate_library.ConditionalReset` is the same regardless of the measured state. .. note:: The total time of the the ConditionalReset is the sum of 1) integration time (<device_element>.measure.integration_time) 2) acquisition delay (<device_element>.measure.acq_delay) 3) trigger delay (364ns) 4) pi-pulse duration (<device_element>.rxy.duration) 5) idle time (4ns) .. note:: Due to current hardware limitations, overlapping conditional resets might not work correctly if multiple triggers are sent within a 364ns window. See :ref:`sec-qblox-conditional-playback` for more information. .. note:: :class:`~quantify_scheduler.backends.qblox.operations.gate_library.ConditionalReset` is currently implemented as a subschedule, but can be added to an existing schedule as if it were a gate. See examples below. Parameters ---------- name : str The name of the conditional subschedule, by default "conditional_reset". qubit_name : str The name of the device element to reset to the :math:`|0\rangle` state. **kwargs: Additional keyword arguments are passed to :class:`~quantify_scheduler.operations.gate_library.Measure`. e.g. ``acq_channel``, ``acq_index``, and ``bin_mode``. Examples -------- .. jupyter-execute:: :hide-output: from quantify_scheduler import Schedule from quantify_scheduler.qblox.operations import ConditionalReset schedule = Schedule("example schedule") schedule.add(ConditionalReset("q0")) """ def __init__( self, qubit_name: str, name: str = "conditional_reset", **kwargs, # noqa: ANN003 (kwargs not annotated) ) -> None: device_element_name = qubit_name super().__init__(name) self.add( Measure( device_element_name, acq_protocol="ThresholdedAcquisition", feedback_trigger_label=device_element_name, **kwargs, ) ) self.add( ConditionalOperation(body=X(device_element_name), qubit_name=device_element_name), rel_time=TRIGGER_DELAY, )