pulse_library ============= .. py:module:: quantify_scheduler.operations.pulse_library .. autoapi-nested-parse:: Standard pulse-level operations for use with the quantify_scheduler. Module Contents --------------- Classes ~~~~~~~ .. autoapisummary:: quantify_scheduler.operations.pulse_library.ReferenceMagnitude quantify_scheduler.operations.pulse_library.ShiftClockPhase quantify_scheduler.operations.pulse_library.ResetClockPhase quantify_scheduler.operations.pulse_library.SetClockFrequency quantify_scheduler.operations.pulse_library.VoltageOffset quantify_scheduler.operations.pulse_library.IdlePulse quantify_scheduler.operations.pulse_library.RampPulse quantify_scheduler.operations.pulse_library.StaircasePulse quantify_scheduler.operations.pulse_library.MarkerPulse quantify_scheduler.operations.pulse_library.SquarePulse quantify_scheduler.operations.pulse_library.SuddenNetZeroPulse quantify_scheduler.operations.pulse_library.SoftSquarePulse quantify_scheduler.operations.pulse_library.ChirpPulse quantify_scheduler.operations.pulse_library.DRAGPulse quantify_scheduler.operations.pulse_library.WindowOperation quantify_scheduler.operations.pulse_library.NumericalPulse quantify_scheduler.operations.pulse_library.SkewedHermitePulse Functions ~~~~~~~~~ .. autoapisummary:: quantify_scheduler.operations.pulse_library.decompose_long_square_pulse quantify_scheduler.operations.pulse_library.create_dc_compensation_pulse quantify_scheduler.operations.pulse_library._extract_pulses .. py:class:: ReferenceMagnitude Dataclass which describes an amplitude / power reference level, with respect to which pulse amplitudes are defined. This can be specified in units of "V", "dBm" or "A". .. py:attribute:: value :type: float .. py:attribute:: unit :type: Literal[V, dBm, A] .. py:method:: from_parameter(parameter: qcodes.InstrumentChannel) :classmethod: Initialise this dataclass by taking the value and unit from an ReferenceMagnitude QCoDeS InstrumentChannnel. .. py:class:: ShiftClockPhase(phase_shift: float, clock: str, t0: float = 0, duration: float = qblox_constants.NCO_SET_PH_DELTA_WAIT * 1e-09) Bases: :py:obj:`quantify_scheduler.Operation` Operation that shifts the phase of a clock by a specified amount. This is a low-level operation and therefore depends on the backend. Currently only implemented for Qblox backend, refer to :class:`~quantify_scheduler.backends.qblox.operation_handling.virtual.NcoPhaseShiftStrategy` for more details. :param phase_shift: The phase shift in degrees. :param clock: The clock of which to shift the phase. :param t0: Time in seconds when to execute the command relative to the start time of the Operation in the Schedule. :param duration: The duration of the operation in seconds. .. py:class:: ResetClockPhase(clock: str, t0: float = 0) Bases: :py:obj:`quantify_scheduler.Operation` An operation that resets the phase of a clock. Create a new instance of ResetClockPhase. :param clock: The clock of which to reset the phase. .. py:class:: SetClockFrequency(clock: str, clock_freq_new: float, t0: float = 0, duration: float = qblox_constants.NCO_SET_FREQ_WAIT * 1e-09) Bases: :py:obj:`quantify_scheduler.Operation` Operation that sets updates the frequency of a clock. This is a low-level operation and therefore depends on the backend. Currently only implemented for Qblox backend, refer to :class:`~quantify_scheduler.backends.qblox.operation_handling.virtual.NcoSetClockFrequencyStrategy` for more details. :param clock: The clock for which a new frequency is to be set. :param clock_freq_new: The new frequency in Hz. :param t0: Time in seconds when to execute the command relative to the start time of the Operation in the Schedule. :param duration: The duration of the operation in seconds. .. py:class:: VoltageOffset(offset_path_0: float, offset_path_1: float, duration: float = 0.0, port: Optional[str] = None, clock: Optional[str] = None, t0: float = 0) Bases: :py:obj:`quantify_scheduler.Operation` Operation that represents setting a constant offset to the output voltage. Currently only implemented for Qblox backend, refer to :class:`~quantify_scheduler.backends.qblox.operation_handling.virtual.AwgOffsetStrategy` for more details. :param offset_path_0: Offset of path 0 (the I-path). :type offset_path_0: float :param offset_path_1: Offset of path 1 (the Q-path). :type offset_path_1: float :param port: Port of the stitched pulse. :type port: str or None, optional :param clock: Clock used to modulate the stitched pulse. :type clock: str or None, optional :param duration: The time to hold the offset for (in seconds). :type duration: float, optional :param t0: Time in seconds when to start the pulses relative to the start time of the Operation in the Schedule. :type t0: float, optional .. py:class:: IdlePulse(duration: float) Bases: :py:obj:`quantify_scheduler.Operation` The IdlePulse Operation is a placeholder for a specified duration of time. Create a new instance of IdlePulse. The IdlePulse Operation is a placeholder for a specified duration of time. :param duration: The duration of idle time in seconds. .. py:class:: RampPulse(amp: float, duration: float, port: str, clock: str = BasebandClockResource.IDENTITY, reference_magnitude: Optional[ReferenceMagnitude] = None, offset: float = 0, t0: float = 0) Bases: :py:obj:`quantify_scheduler.Operation` The RampPulse Operation is a real-valued pulse that ramps from the specified offset to the specified amplitude + offset during the duration of the pulse. Create a new instance of RampPulse. The RampPulse Operation is a real-valued pulse that ramps from zero to the specified amplitude during the duration of the pulse. The pulse is given as a function of time :math:`t` and the parameters offset and amplitude by .. math:: P(t) = \mathrm{offset} + t \times \mathrm{amp}. :param amp: Unitless amplitude of the ramp envelope function. :param duration: The pulse duration in seconds. :param offset: Starting point of the ramp pulse :param port: Port of the pulse. :param clock: Clock used to modulate the pulse, by default a BasebandClock is used. :param reference_magnitude: Scaling value and unit for the unitless amplitude. Uses settings in hardware config if not provided. :param t0: Time in seconds when to start the pulses relative to the start time of the Operation in the Schedule. .. py:class:: StaircasePulse(start_amp: float, final_amp: float, num_steps: int, duration: float, port: str, clock: str = BasebandClockResource.IDENTITY, reference_magnitude: Optional[ReferenceMagnitude] = None, t0: float = 0) Bases: :py:obj:`quantify_scheduler.Operation` A real valued staircase pulse, which reaches it's final amplitude in discrete steps. In between it will maintain a plateau. Constructor for a staircase. :param start_amp: Starting unitless amplitude of the staircase envelope function. :param final_amp: Final unitless amplitude of the staircase envelope function. :param num_steps: The number of plateaus. :param duration: Duration of the pulse in seconds. :param port: Port of the pulse. :param clock: Clock used to modulate the pulse. :param reference_magnitude: Scaling value and unit for the unitless amplitude. Uses settings in hardware config if not provided. :param t0: Time in seconds when to start the pulses relative to the start time of the Operation in the Schedule. .. py:class:: MarkerPulse(duration: float, port: str, t0: float = 0, clock: str = 'digital') Bases: :py:obj:`quantify_scheduler.Operation` A representation of quantum circuit operations. The `Operation` class is a JSON-compatible data structure that contains information on how to represent the operation on the quantum-circuit and/or the quantum-device layer. It also contains information on where the operation should be applied: the :class:`~quantify_scheduler.resources.Resource` s used. An operation always has the following attributes: - duration (float): duration of the operation in seconds (can be 0). - hash (str): an auto generated unique identifier. - name (str): a readable identifier, does not have to be unique. An Operation can contain information on several levels of abstraction. This information is used when different representations are required. Note that when initializing an operation not all of this information needs to be available as operations are typically modified during the compilation steps. .. tip:: :mod:`quantify_scheduler` comes with a :mod:`~quantify_scheduler.operations.gate_library` and a :mod:`~quantify_scheduler.operations.pulse_library` , both containing common operations. **JSON schema of a valid Operation** .. jsonschema:: https://gitlab.com/quantify-os/quantify-scheduler/-/raw/main/quantify_scheduler/schemas/operation.json .. note:: Two different Operations containing the same information generate the same hash and are considered identical. Digital pulse that is HIGH for the specified duration. Played on marker output. Currently only implemented for Qblox backend. :param duration: Duration of the HIGH signal. :param port: Name of associated port. :param clock: As digital IO's technically do not have a clock, this parameter is by default set to "digital". In circuit to device compilation digital IO's get assigned the digital clock. .. py:class:: SquarePulse(amp: float, duration: float, port: str, clock: str = BasebandClockResource.IDENTITY, reference_magnitude: Optional[ReferenceMagnitude] = None, phase: float = 0, t0: float = 0) Bases: :py:obj:`quantify_scheduler.Operation` The SquarePulse Operation is a real-valued pulse with the specified amplitude during the pulse. Create a new instance of SquarePulse. The SquarePulse Operation is a real-valued pulse with the specified amplitude during the pulse. :param amp: Unitless amplitude of the envelope. :param duration: The pulse duration in seconds. :param port: Port of the pulse, must be capable of playing a complex waveform. :param clock: Clock used to modulate the pulse. :param reference_magnitude: Scaling value and unit for the unitless amplitude. Uses settings in hardware config if not provided. :param phase: Phase of the pulse in degrees. :param t0: Time in seconds when to start the pulses relative to the start time of the Operation in the Schedule. .. py:class:: SuddenNetZeroPulse(amp_A: float, amp_B: float, net_zero_A_scale: float, t_pulse: float, t_phi: float, t_integral_correction: float, port: str, clock: str = BasebandClockResource.IDENTITY, reference_magnitude: Optional[ReferenceMagnitude] = None, t0: float = 0) Bases: :py:obj:`quantify_scheduler.Operation` The sudden net-zero (SNZ) pulse from :cite:t:`negirneac_high_fidelity_2021`. The sudden net-zero (SNZ) pulse from :cite:t:`negirneac_high_fidelity_2021`. The SuddenNetZeroPulse is a real-valued pulse that can be used to implement a conditional phase gate in transmon qubits. :param amp_A: unitless amplitude of the main square pulse :param amp_B: unitless scaling correction for the final sample of the first square and first sample of the second square pulse. :param net_zero_A_scale: amplitude scaling correction factor of the negative arm of the net-zero pulse. :param t_pulse: the total duration of the two half square pulses :param t_phi: the idling duration between the two half pulses :param t_integral_correction: the duration in which any non-zero pulse amplitude needs to be corrected. :param port: Port of the pulse, must be capable of playing a complex waveform. :param clock: Clock used to modulate the pulse. :param reference_magnitude: Scaling value and unit for the unitless amplitude. Uses settings in hardware config if not provided. :param t0: Time in seconds when to start the pulses relative to the start time of the Operation in the Schedule. .. py:function:: decompose_long_square_pulse(duration: float, duration_max: float, single_duration: bool = False, **kwargs) -> list Generates a list of square pulses equivalent to a (very) long square pulse. Intended to be used for waveform-memory-limited devices. Effectively, only two square pulses, at most, will be needed: a main one of duration `duration_max` and a second one for potential mismatch between N `duration_max` and overall `duration`. :param duration: Duration of the long pulse in seconds. :param duration_max: Maximum duration of square pulses to be generated in seconds. :param single_duration: If `True`, only square pulses of duration `duration_max` will be generated. If `False`, a square pulse of `duration` < `duration_max` might be generated if necessary. :param \*\*kwargs: Other keyword arguments to be passed to the :class:`~SquarePulse`. :returns: A list of :class`SquarePulse` s equivalent to the desired long pulse. .. py:class:: SoftSquarePulse(amp: float, duration: float, port: str, clock: str, reference_magnitude: Optional[ReferenceMagnitude] = None, t0: float = 0) Bases: :py:obj:`quantify_scheduler.Operation` The SoftSquarePulse Operation is a real valued square pulse convolved with a Hann window for smoothing. Create a new instance of SoftSquarePulse. The SoftSquarePulse Operation is a real valued square pulse convolved with a Hann window for smoothing. :param amp: Unitless amplitude of the envelope. :param duration: The pulse duration in seconds. :param port: Port of the pulse, must be capable of playing a complex waveform. :param clock: Clock used to modulate the pulse. :param reference_magnitude: Scaling value and unit for the unitless amplitude. Uses settings in hardware config if not provided. :param t0: Time in seconds when to start the pulses relative to the start time of the Operation in the Schedule. .. py:class:: ChirpPulse(amp: float, duration: float, port: str, clock: str, start_freq: float, end_freq: float, reference_magnitude: Optional[ReferenceMagnitude] = None, t0: float = 0) Bases: :py:obj:`quantify_scheduler.Operation` A linear chirp signal. A sinusoidal signal that ramps up in frequency. Constructor for a chirp pulse. :param amp: Unitless amplitude of the envelope. :param duration: Duration of the pulse. :param port: The port of the pulse. :param clock: Clock used to modulate the pulse. :param start_freq: Start frequency of the Chirp. Note that this is the frequency at which the waveform is calculated, this may differ from the clock frequency. :param end_freq: End frequency of the Chirp. :param reference_magnitude: Scaling value and unit for the unitless amplitude. Uses settings in hardware config if not provided. :param t0: Shift of the start time with respect to the start of the operation. .. py:class:: DRAGPulse(G_amp: float, D_amp: float, phase: float, duration: float, port: str, clock: str, reference_magnitude: Optional[ReferenceMagnitude] = None, t0: float = 0) Bases: :py:obj:`quantify_scheduler.Operation` DRAG pulse intended for single qubit gates in transmon based systems. A DRAG pulse is a gaussian pulse with a derivative component added to the out-of-phase channel to reduce unwanted excitations of the :math:`|1\rangle - |2\rangle` transition (:cite:t:`motzoi_simple_2009` and :cite:t:`gambetta_analytic_2011`). The waveform is generated using :func:`.waveforms.drag` . Create a new instance of DRAGPulse. :param G_amp: Unitless amplitude of the Gaussian envelope. :param D_amp: Unitless amplitude of the derivative component, the DRAG-pulse parameter. :param duration: The pulse duration in seconds. :param phase: Phase of the pulse in degrees. :param clock: Clock used to modulate the pulse. :param port: Port of the pulse, must be capable of carrying a complex waveform. :param reference_magnitude: Scaling value and unit for the unitless amplitude. Uses settings in hardware config if not provided. :param t0: Time in seconds when to start the pulses relative to the start time of the Operation in the Schedule. .. py:function:: create_dc_compensation_pulse(pulses: List[quantify_scheduler.Operation], sampling_rate: float, port: str, t0: float = 0, amp: Optional[float] = None, reference_magnitude: Optional[ReferenceMagnitude] = None, duration: Optional[float] = None) -> SquarePulse Calculates a SquarePulse to counteract charging effects based on a list of pulses. The compensation is calculated by summing the area of all pulses on the specified port. This gives a first order approximation for the pulse required to compensate the charging. All modulated pulses ignored in the calculation. :param pulses: List of pulses to compensate :param sampling_rate: Resolution to calculate the enclosure of the pulses to calculate the area to compensate. :param amp: Desired unitless amplitude of the DCCompensationPulse. Leave to None to calculate the value for compensation, in this case you must assign a value to duration. The sign of the amplitude is ignored and adjusted automatically to perform the compensation. :param duration: Desired pulse duration in seconds. Leave to None to calculate the value for compensation, in this case you must assign a value to amp. The sign of the value of amp given in the previous step is adjusted to perform the compensation. :param port: Port to perform the compensation. Any pulse that does not belong to the specified port is ignored. :param clock: Clock used to modulate the pulse. :param reference_magnitude: Scaling value and unit for the unitless amplitude. Uses settings in hardware config if not provided. :param phase: Phase of the pulse in degrees. :param t0: Time in seconds when to start the pulses relative to the start time of the Operation in the Schedule. :returns: * * Returns a SquarePulse object that compensates all pulses passed as argument. .. py:function:: _extract_pulses(pulses: List[quantify_scheduler.Operation], port: str) -> List[Dict[str, Any]] .. py:class:: WindowOperation(window_name: str, duration: float, t0: float = 0.0) Bases: :py:obj:`quantify_scheduler.Operation` The WindowOperation is an operation for visualization purposes. The `WindowOperation` has a starting time and duration. Create a new instance of WindowOperation. .. py:property:: window_name :type: str Return the window name of this operation .. py:class:: NumericalPulse(samples: Union[numpy.ndarray, list], t_samples: Union[numpy.ndarray, list], port: str, clock: str, reference_magnitude: Optional[ReferenceMagnitude] = None, t0: float = 0, interpolation: str = 'linear') Bases: :py:obj:`quantify_scheduler.Operation` Defines a pulse where the shape is determined by specifying an array of (complex) points. If points are required between the specified samples (such as could be required by the sampling rate of the hardware), meaning :math:`t[n] < t' < t[n+1]`, `scipy.interpolate.interp1d` will be used to interpolate between the two points and determine the value. Creates an instance of the `NumericalPulse`. :param samples: An array of (possibly complex) values specifying the shape of the pulse. :param t_samples: An array of values specifying the corresponding times at which the `samples` are evaluated. :param port: The port that the pulse should be played on. :param clock: Clock used to (de)modulate the pulse. :param reference_magnitude: Scaling value and unit for the unitless samples. Uses settings in hardware config if not provided. :param t0: Time in seconds when to start the pulses relative to the start time of the Operation in the Schedule. :param interpolation: Specifies the type of interpolation used. This is passed as the "kind" argument to `scipy.interpolate.interp1d`. .. py:class:: SkewedHermitePulse(duration: float, amplitude: float, skewness: float, phase: float, port: str, clock: str, reference_magnitude: Optional[ReferenceMagnitude] = None, t0: float = 0) Bases: :py:obj:`quantify_scheduler.Operation` Hermite pulse intended for single qubit gates in diamond based systems. The waveform is generated using :func:`~quantify_scheduler.waveforms.skewed_hermite`. Create a new instance of SkewedHermitePulse. :param duration: The pulse duration in seconds. :param amplitude: Unitless amplitude of the hermite pulse. :param skewness: Skewness in the frequency space. :param phase: Phase of the pulse in degrees. :param clock: Clock used to modulate the pulse. :param port: Port of the pulse, must be capable of carrying a complex waveform. :param reference_magnitude: Scaling value and unit for the unitless amplitude. Uses settings in hardware config if not provided. :param t0: Time in seconds when to start the pulses relative to the start time of the Operation in the Schedule. By default 0.