One- and Two-Qubit Randomized Benchmarking in LabOne Q with Qiskit¶
In this notebook, we'll use the Qiskit Experiment Library to generate one and two qubit randomized benchmarking experiments. We'll then export the generated experiment to OpenQASM, import these OpenQASM experiments into LabOne Q, compile, and simulate the output signals.
When generating randomized benchmarking experiments in Qiskit, it will return a list of quantum circuits with the specified parameters. We show here how to efficiently import, compile and execute such a list into LabOne Q, resulting in a single, large experiment.
Imports¶
from __future__ import annotations
# LabOne Q:
# additional imports
# device setup and descriptor
from laboneq import openqasm3
from laboneq.contrib.example_helpers.generate_device_setup import (
generate_device_setup_qubits,
)
# plotting functionality
from laboneq.contrib.example_helpers.plotting.plot_helpers import plot_simulation
# core LabOne Q functionality
from laboneq.simple import *
# qiskit
from qiskit import qasm3, transpile
from qiskit_experiments.library import randomized_benchmarking
Define the Experimental Setup¶
Below, we generate a pre-calibrated experimental setup containing a DeviceSetup, Transmon qubits and a Session to run the experiments.
# specify the number of qubits you want to use
number_of_qubits = 2
# generate the device setup and the qubit objects using a helper function
device_setup, qubits = generate_device_setup_qubits(
number_qubits=number_of_qubits,
pqsc=[{"serial": "DEV10001"}],
hdawg=[{"serial": "DEV8001", "zsync": 0, "number_of_channels": 8, "options": None}],
shfqc=[
{
"serial": "DEV12001",
"zsync": 1,
"number_of_channels": 6,
"readout_multiplex": 6,
"options": None,
}
],
include_flux_lines=True,
server_host="localhost",
setup_name=f"my_{number_of_qubits}_tuneable_qubit_setup",
)
q0, q1 = qubits[:2]
# create and connect to Session
# use emulation mode - no connection to instruments
use_emulation = True
my_session = Session(device_setup=device_setup)
my_session.connect(do_emulation=use_emulation, reset_devices=True)
[2025.01.21 09:44:53.771] INFO Logging initialized from [Default inline config in laboneq.laboneq_logging] logdir is /builds/qccs/laboneq-applications/docs/sources/how-to-guides/sources/04_qasm/laboneq_output/log
[2025.01.21 09:44:53.772] INFO VERSION: laboneq 2.44.0
[2025.01.21 09:44:53.773] INFO Connecting to data server at localhost:8004
[2025.01.21 09:44:53.775] INFO Connected to Zurich Instruments LabOne Data Server version 24.10 at localhost:8004
[2025.01.21 09:44:53.776] WARNING HDAWG:dev8001: Include the device options 'HDAWG8/MF/ME/SKW/PC' in the device setup ('options' field of the 'instruments' list in the device setup descriptor, 'device_options' argument when constructing instrument objects to be added to 'DeviceSetup' instances). This will become a strict requirement in the future.
[2025.01.21 09:44:53.778] WARNING SHFQC/QA:dev12001: Include the device options 'SHFQC/QC6CH' in the device setup ('options' field of the 'instruments' list in the device setup descriptor, 'device_options' argument when constructing instrument objects to be added to 'DeviceSetup' instances). This will become a strict requirement in the future.
[2025.01.21 09:44:53.779] INFO Configuring the device setup
[2025.01.21 09:44:53.828] INFO The device setup is configured
<laboneq.dsl.session.ConnectionState at 0x7156db585790>
Defining the QPU and Quantum Operations¶
Here, we define the QPU and the class of quantum operations corresponding to the gates in our QASM programs for Randomized Benchmarking produced with Qiskit.
To learn more about quantum operations, check out these pages in the LabOne Q User's Manual, here and here. To learn more about the QPU, have a look at this page.
class QASMOperations(dsl.QuantumOperations):
"""Class implementing the collection of quantum operations.
Operations for the QASM RB experiments created by Qiskit.
"""
QUBIT_TYPES = Transmon
@dsl.quantum_operation
def delay(self, q: Transmon, time: float) -> None:
"""A delay operation on the drive signal of the qubit."""
dsl.delay(q.signals["drive"], time=time)
@dsl.quantum_operation
def x(
self,
q: Transmon,
amplitude_scale: float = 1.0,
amplitude: float | None = None,
label: str = "x",
) -> None:
"""A drag pulse implementing an x rotation.
The pulse length and amplitude are taken from the qubit parameters.
"""
pulse_parameters = {"function": "drag"}
x_pulse = dsl.create_pulse(pulse_parameters, name=f"{q.uid}_{label}")
if amplitude is None:
amplitude = amplitude_scale * q.parameters.user_defined["amplitude_pi"]
dsl.play(
q.signals["drive"],
amplitude=amplitude,
length=q.parameters.user_defined["pulse_length"],
pulse=x_pulse,
)
@dsl.quantum_operation
def sx(self, q: Transmon) -> None:
"""An sx operation used in the RB decomposition.
Calls the x operation with a fixed amplitude_scale of 0.5.
"""
self.x.omit_section(q, amplitude_scale=0.5, label="sx")
@dsl.quantum_operation
def rz(self, q: Transmon, angle: float) -> None:
"""An operation implementing a z rotation by the given angle."""
dsl.play(
signal=q.signals["drive"],
pulse=None,
increment_oscillator_phase=angle,
)
@dsl.quantum_operation
def measure(self, q: Transmon, handle: str) -> None:
"""An operation implementing a qubit measurement.
The results are stored under the name given by handle. The readout
and integration parameters are taken from the qubit.
"""
ro_pulse_parameters = {"function": "gaussian_square", "zero_boundaries": True}
ro_pulse = dsl.create_pulse(ro_pulse_parameters, name=f"{q.uid}_readout_pulse")
int_pulse_parameters = {"function": "const"}
kernels = [
dsl.create_pulse(int_pulse_parameters, name=f"{q.uid}_integration_kernel")
]
dsl.measure(
measure_signal=q.signals["measure"],
measure_pulse_amplitude=q.parameters.user_defined["readout_amplitude"],
measure_pulse_length=q.parameters.user_defined["readout_length"],
measure_pulse=ro_pulse,
handle=handle,
acquire_signal=q.signals["acquire"],
integration_kernel=kernels,
integration_length=q.parameters.user_defined["readout_length"],
reset_delay=None,
)
@dsl.quantum_operation
def reset(self, q: Transmon) -> None:
"""An operation implementing active reset on a qubit."""
handle = f"{q.uid}_qubit_state"
self.measure(q, handle=handle)
self.delay(q, q.parameters.user_defined["reset_delay_length"])
with dsl.match(name=f"match_{q.uid}", handle=handle):
with dsl.case(name=f"case_{q.uid}_g", state=0):
pass
with dsl.case(name=f"case_{q.uid}_e", state=1):
self.x.omit_section(q)
@dsl.quantum_operation
def cx(self, q_control: Transmon, q_target: Transmon) -> None:
"""An operation implementing a cx gate on two qubits.
The controlled X gate is implemented using a cross-resonance gate.
"""
cx_id = f"cx_{q_control.uid}_{q_target.uid}"
# define cancellation pulses for target and control
cancellation_control_n = dsl.create_pulse(
{"function": "gaussian_square"}, name="CR-"
)
cancellation_control_p = dsl.create_pulse(
{"function": "gaussian_square"}, name="CR+"
)
cancellation_target_p = dsl.create_pulse(
{"function": "gaussian_square"}, name="q1+"
)
cancellation_target_n = dsl.create_pulse(
{"function": "gaussian_square"}, name="q1-"
)
# play X pulses on both target and control
with dsl.section(name=f"{cx_id}_x_both") as x180_both:
self.x(q_control, label="x180")
self.x(q_target, label="x180")
# First cross-resonance component
with dsl.section(
name=f"{cx_id}_canc_p", play_after=x180_both.uid
) as cancellation_p:
dsl.play(signal=q_target.signals["drive"], pulse=cancellation_target_p)
dsl.play(signal=q_control.signals["flux"], pulse=cancellation_control_n)
# play X pulse on control
x180_control = self.x(q_control, label="x180")
x180_control.play_after = cancellation_p.uid
# Second cross-resonance component
with dsl.section(
name=f"cx_{cx_id}_canc_n", play_after=x180_control.uid
):
dsl.play(signal=q_target.signals["drive"], pulse=cancellation_target_n)
dsl.play(signal=q_control.signals["flux"], pulse=cancellation_control_p)
from laboneq.dsl.quantum import QPU
qpu = QPU(qubits=[q0, q1], quantum_operations=QASMOperations())
Single-Qubit Randomised Benchmarking using Qiskit¶
You'll start by creating Standard RB experiments from the Qiskit Experiment Library here. Here, we do this for one qubit for a few different RB sequence lengths.
Note that most circuits that can be generated in Qiskit and converted to OpenQASM could be adapted to be run in a similar way in LabOne Q!
Define Circuits with Qiskit¶
# Use Qiskit Experiment Library to Generate RB
rb1_qiskit_circuits = randomized_benchmarking.StandardRB(
physical_qubits=[0],
lengths=[4, 8, 16],
num_samples=2,
).circuits()
When efficiently importing and executing a list of quantum circuits, there currently are strong limitations as to how the measurements are scheduled in these experiment. We strip them here from the Qiskit circuit. We will re-add them to the LabOne Q experiment separately when doing the import.
for circuit in rb1_qiskit_circuits:
circuit.remove_final_measurements()
rb1_qiskit_circuits[2].draw()
┌─────────────────┐ ░ ┌────────────────┐ ░ ┌─────────────────┐ ░ » q: ┤ Clifford-1Q(14) ├─░─┤ Clifford-1Q(3) ├─░─┤ Clifford-1Q(17) ├─░─» └─────────────────┘ ░ └────────────────┘ ░ └─────────────────┘ ░ » « ┌────────────────┐ ░ ┌─────────────────┐ ░ ┌────────────────┐ ░ » «q: ┤ Clifford-1Q(4) ├─░─┤ Clifford-1Q(19) ├─░─┤ Clifford-1Q(4) ├─░─» « └────────────────┘ ░ └─────────────────┘ ░ └────────────────┘ ░ » « ┌─────────────────┐ ░ ┌─────────────────┐ ░ ┌────────────────┐ ░ » «q: ┤ Clifford-1Q(23) ├─░─┤ Clifford-1Q(20) ├─░─┤ Clifford-1Q(4) ├─░─» « └─────────────────┘ ░ └─────────────────┘ ░ └────────────────┘ ░ » « ┌─────────────────┐ ░ ┌─────────────────┐ ░ ┌─────────────────┐ ░ » «q: ┤ Clifford-1Q(16) ├─░─┤ Clifford-1Q(20) ├─░─┤ Clifford-1Q(16) ├─░─» « └─────────────────┘ ░ └─────────────────┘ ░ └─────────────────┘ ░ » « ┌─────────────────┐ ░ ┌─────────────────┐ ░ ┌─────────────────┐ ░ » «q: ┤ Clifford-1Q(20) ├─░─┤ Clifford-1Q(22) ├─░─┤ Clifford-1Q(14) ├─░─» « └─────────────────┘ ░ └─────────────────┘ ░ └─────────────────┘ ░ » « ┌────────────────┐ ░ ┌─────────────────┐ «q: ┤ Clifford-1Q(5) ├─░─┤ Clifford-1Q(15) ├ « └────────────────┘ ░ └─────────────────┘
You can then use the Qiskit transpile
function to obtain a representation of the circuits in your favorite set of basis gates.
Below, we choose the basis ["id", "sx", "x", "rz", "cx"]
. Note that all these gates (except the identity "id") must exist in your set of quantum operations!
# Choose basis gates
rb1_transpiled_circuits = transpile(
rb1_qiskit_circuits, basis_gates=["id", "sx", "x", "rz", "cx"]
)
rb1_program_list = []
for circuit in rb1_transpiled_circuits:
rb1_program_list.append(qasm3.dumps(circuit))
print(rb1_program_list[2])
OPENQASM 3.0; include "stdgates.inc"; qubit[1] q; sx q[0]; rz(-pi) q[0]; barrier q[0]; sx q[0]; rz(pi/2) q[0]; barrier q[0]; rz(-pi/2) q[0]; sx q[0]; rz(-pi) q[0]; barrier q[0]; rz(pi/2) q[0]; barrier q[0]; rz(pi/2) q[0]; sx q[0]; rz(-pi/2) q[0]; barrier q[0]; rz(pi/2) q[0]; barrier q[0]; rz(pi/2) q[0]; sx q[0]; barrier q[0]; rz(-pi) q[0]; sx q[0]; barrier q[0]; rz(pi/2) q[0]; barrier q[0]; x q[0]; rz(pi/2) q[0]; barrier q[0]; rz(-pi) q[0]; sx q[0]; barrier q[0]; x q[0]; rz(pi/2) q[0]; barrier q[0]; rz(-pi) q[0]; sx q[0]; barrier q[0]; rz(-pi/2) q[0]; barrier q[0]; sx q[0]; rz(-pi) q[0]; barrier q[0]; rz(pi/2) q[0]; sx q[0]; rz(-pi) q[0]; barrier q[0]; rz(-pi) q[0]; sx q[0]; rz(-pi/2) q[0];
Execute a single QASM program¶
Now, you'll transpile a single OpenQASM program into a LabOne Q Experiment
pulse sequence using the class OpenQASMTranspiler
and the options class SingleProgramOptions
. Check out the LabOne Q QASM transplier tutorial to learn more about this interface.
Once you've done that, you can compile your Experiment
and plot the output using the LabOne Q simulator.
Note: the parameter qubit_map
below may need to be updated to match the names of the qubit register from your QASM circuit!
Below, we choose the QASM program defined in the first entry of rb1_program_list
.
# Instantiate OpenQASMTranspiler from the QPU
transpiler = openqasm3.OpenQASMTranspiler(qpu)
# Define options
options = openqasm3.SingleProgramOptions()
# We will not change any of the default options
# Create the Experiment
rb1_exp_single_program = transpiler.experiment( # create Experiment
program=rb1_program_list[2],
qubit_map={"q": [q0]},
options=options,
)
# Set the Experiment calibration from the qubit calibration
rb1_exp_single_program.set_calibration(q0.calibration())
# Compile the Experiment
rb1_compiled_exp_single_program = my_session.compile(rb1_exp_single_program)
# Run the Experiment
rb1_results_single_program = my_session.run(rb1_compiled_exp_single_program)
[2025.01.21 09:44:55.130] INFO Resolved modulation type of oscillator 'q0_readout_acquire_osc' on signal 'q0/acquire' to SOFTWARE
[2025.01.21 09:44:55.131] INFO Resolved modulation type of oscillator 'q0_drive_ge_osc' on signal 'q0/drive' to HARDWARE
[2025.01.21 09:44:55.132] INFO Starting LabOne Q Compiler run...
[2025.01.21 09:44:55.139] INFO Schedule completed. [0.003 s]
[2025.01.21 09:44:55.152] INFO Code generation completed for all AWGs. [0.013 s]
[2025.01.21 09:44:55.153] INFO Completed compilation step 1 of 1. [0.017 s]
[2025.01.21 09:44:55.157] INFO ────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.157] INFO Device AWG SeqC LOC CT entries Waveforms Samples
[2025.01.21 09:44:55.157] INFO ────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.158] INFO hdawg_0 0 4 1 0 0
[2025.01.21 09:44:55.158] INFO shfqc_0 0 3 0 0 0
[2025.01.21 09:44:55.158] INFO shfqc_0_sg 0 26 8 5 3616
[2025.01.21 09:44:55.159] INFO ────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.159] INFO TOTAL 33 9 3616
[2025.01.21 09:44:55.159] INFO ────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.164] INFO Finished LabOne Q Compiler run.
[2025.01.21 09:44:55.173] INFO Starting near-time execution...
[2025.01.21 09:44:55.182] INFO Finished near-time execution.
Look at the simulated output¶
Draw the circuit from above¶
rb1_transpiled_circuits[2].draw()
global phase: 3π/4 ┌────┐┌────────┐ ░ ┌────┐┌─────────┐ ░ ┌──────────┐┌────┐┌────────┐ ░ » q: ┤ √X ├┤ Rz(-π) ├─░─┤ √X ├┤ Rz(π/2) ├─░─┤ Rz(-π/2) ├┤ √X ├┤ Rz(-π) ├─░─» └────┘└────────┘ ░ └────┘└─────────┘ ░ └──────────┘└────┘└────────┘ ░ » « ┌─────────┐ ░ ┌─────────┐┌────┐┌──────────┐ ░ ┌─────────┐ ░ ┌─────────┐» «q: ┤ Rz(π/2) ├─░─┤ Rz(π/2) ├┤ √X ├┤ Rz(-π/2) ├─░─┤ Rz(π/2) ├─░─┤ Rz(π/2) ├» « └─────────┘ ░ └─────────┘└────┘└──────────┘ ░ └─────────┘ ░ └─────────┘» « ┌────┐ ░ ┌────────┐┌────┐ ░ ┌─────────┐ ░ ┌───┐┌─────────┐ ░ ┌────────┐» «q: ┤ √X ├─░─┤ Rz(-π) ├┤ √X ├─░─┤ Rz(π/2) ├─░─┤ X ├┤ Rz(π/2) ├─░─┤ Rz(-π) ├» « └────┘ ░ └────────┘└────┘ ░ └─────────┘ ░ └───┘└─────────┘ ░ └────────┘» « ┌────┐ ░ ┌───┐┌─────────┐ ░ ┌────────┐┌────┐ ░ ┌──────────┐ ░ ┌────┐» «q: ┤ √X ├─░─┤ X ├┤ Rz(π/2) ├─░─┤ Rz(-π) ├┤ √X ├─░─┤ Rz(-π/2) ├─░─┤ √X ├» « └────┘ ░ └───┘└─────────┘ ░ └────────┘└────┘ ░ └──────────┘ ░ └────┘» « ┌────────┐ ░ ┌─────────┐┌────┐┌────────┐ ░ ┌────────┐┌────┐┌──────────┐ «q: ┤ Rz(-π) ├─░─┤ Rz(π/2) ├┤ √X ├┤ Rz(-π) ├─░─┤ Rz(-π) ├┤ √X ├┤ Rz(-π/2) ├ « └────────┘ ░ └─────────┘└────┘└────────┘ ░ └────────┘└────┘└──────────┘
Look at the pulse sheet¶
show_pulse_sheet(name="1-qubit RB", compiled_experiment=rb1_compiled_exp_single_program)
[2025.01.21 09:44:55.464] INFO Recompiling the experiment due to missing extra information in the compiled experiment. Compile with `OUTPUT_EXTRAS=True` and `MAX_EVENTS_TO_PUBLISH=1000` to bypass this step with a small impact on the compilation time.
[2025.01.21 09:44:55.470] INFO Resolved modulation type of oscillator 'q0_readout_acquire_osc' on signal 'q0/acquire' to SOFTWARE
[2025.01.21 09:44:55.471] INFO Resolved modulation type of oscillator 'q0_drive_ge_osc' on signal 'q0/drive' to HARDWARE
[2025.01.21 09:44:55.471] INFO Starting LabOne Q Compiler run...
[2025.01.21 09:44:55.479] INFO Schedule completed. [0.005 s]
[2025.01.21 09:44:55.491] INFO Code generation completed for all AWGs. [0.012 s]
[2025.01.21 09:44:55.492] INFO Completed compilation step 1 of 1. [0.018 s]
[2025.01.21 09:44:55.494] INFO Finished LabOne Q Compiler run.
[2025.01.21 09:44:55.642] INFO Writing html file to /builds/qccs/laboneq-applications/docs/sources/how-to-guides/sources/04_qasm/1-qubit RB_2025-01-21-09-44-55.html
Execute the full RB Experiment¶
Below, we will use the .batch_experiment()
method to create and Experiment
from our list of QASM programs rb1_program_list
, containing the full single-qubit RB experiment.
The entries in rb1_program_list
are individual RB sequences of a given number of gates, m
. In total, there will be $m\times K$ sequences in the list, where K
is the number of randomizations of each length (the num_samples
parameter in the Qiskit interface above). In our choice above, we have $K=2$ and $m\in \{4, 8, 16\}$.
In the MultiProgramOptions
, you can use the field batch_execution_mode
to specify how all these RB sequences in the list should be executed:
- all in real-time ("rt");
- every sequence of
m
gates in real-time and the iteration over the sequences in near-time ("nt"); - split the entries into the number of near-time steps (called "chunks") using the pipeliner ("pipeline"). Specify the number of chunks to use in the options field
pipeline_chunk_count
.
Below, we use the "pipeline" option, and split our 10 sequences into 2 chunks of 3 RB sequences each. This means that we will have two near-time steps, and each real-time loop will run over 3 RB sequences (all the lengths, in our case).
Note that here we use a different options class, MultiProgramOptions
.
# Instantiate OpenQASMTranspiler from the QPU
transpiler = openqasm3.OpenQASMTranspiler(qpu)
# Define options
options = openqasm3.MultiProgramOptions()
options.repetition_time = 20e-5
options.batch_execution_mode = "pipeline"
options.pipeline_chunk_count = 2
options.add_reset = False
# Create the Experiment
rb1_exp = transpiler.batch_experiment(
programs=rb1_program_list,
qubit_map={"q": [q0]},
options=options,
)
# Set the Experiment calibration from the qubit calibration
rb1_exp.set_calibration(q0.calibration())
# Compile the Experiment
rb1_compiled_exp = my_session.compile(rb1_exp)
# Run the Experiment
rb1_results = my_session.run(rb1_compiled_exp)
[2025.01.21 09:44:55.710] INFO Resolved modulation type of oscillator 'q0_readout_acquire_osc' on signal 'q0/acquire' to SOFTWARE
[2025.01.21 09:44:55.710] INFO Resolved modulation type of oscillator 'q0_drive_ge_osc' on signal 'q0/drive' to HARDWARE
[2025.01.21 09:44:55.712] INFO Starting LabOne Q Compiler run...
[2025.01.21 09:44:55.724] INFO Schedule completed. [0.008 s]
[2025.01.21 09:44:55.742] INFO Code generation completed for all AWGs. [0.017 s]
[2025.01.21 09:44:55.742] INFO Completed compilation step 1 of 2. [0.027 s]
[2025.01.21 09:44:55.749] INFO Schedule completed. [0.006 s]
[2025.01.21 09:44:55.767] INFO Code generation completed for all AWGs. [0.018 s]
[2025.01.21 09:44:55.768] INFO Completed compilation step 2 of 2. [0.025 s]
[2025.01.21 09:44:55.774] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.774] INFO Step Device AWG SeqC LOC CT entries Waveforms Samples
[2025.01.21 09:44:55.775] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.775] INFO 0 hdawg_0 0 4 1 0 0
[2025.01.21 09:44:55.776] INFO shfqc_0 0 8 0 1 8000
[2025.01.21 09:44:55.776] INFO shfqc_0_sg 0 46 13 7 5216
[2025.01.21 09:44:55.777] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.778] INFO 1 hdawg_0 0 4 1 0 0
[2025.01.21 09:44:55.779] INFO shfqc_0 0 8 0 1 8000
[2025.01.21 09:44:55.779] INFO shfqc_0_sg 0 47 16 7 5216
[2025.01.21 09:44:55.780] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.780] INFO TOTAL 105 30 18432
[2025.01.21 09:44:55.781] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.787] INFO Finished LabOne Q Compiler run.
[2025.01.21 09:44:55.796] INFO Starting near-time execution...
[2025.01.21 09:44:55.828] INFO Finished near-time execution.
## KNOWN ISSUE - pulse sheet viewer and output simulation are not available
Execute the full RB Experiment - including active qubit reset¶
Let's re-run the single-qubit RB experiment with active reset. Just set the options field .add_reset
to True
.
# Instantiate OpenQASMTranspiler from the QPU
transpiler = openqasm3.OpenQASMTranspiler(qpu)
# Define options
options = openqasm3.MultiProgramOptions()
options.repetition_time = 20e-5
options.batch_execution_mode = "pipeline"
options.pipeline_chunk_count = 2
options.add_reset = True
# Create the Experiment
rb1_exp_with_reset = transpiler.batch_experiment(
programs=rb1_program_list,
qubit_map={"q": [q0]},
options=options,
)
# Set the Experiment calibration from the qubit calibration
rb1_exp_with_reset.set_calibration(q0.calibration())
# Compile the Experiment
rb1_compiled_exp_with_reset = my_session.compile(rb1_exp_with_reset)
# Run the Experiment
rb1_results_with_reset = my_session.run(rb1_compiled_exp_with_reset)
[2025.01.21 09:44:55.901] INFO Resolved modulation type of oscillator 'q0_readout_acquire_osc' on signal 'q0/acquire' to SOFTWARE
[2025.01.21 09:44:55.902] INFO Resolved modulation type of oscillator 'q0_drive_ge_osc' on signal 'q0/drive' to HARDWARE
[2025.01.21 09:44:55.903] INFO Starting LabOne Q Compiler run...
[2025.01.21 09:44:55.917] INFO Due to feedback latency constraints, the timing of the following match sections with corresponding handles were changed: [2025.01.21 09:44:55.917] INFO - '__match_q0_0' with handle 'q0_qubit_state', delayed by 272.00 ns [2025.01.21 09:44:55.917] INFO - '__match_q0_0' with handle 'q0_qubit_state', delayed by 272.00 ns [2025.01.21 09:44:55.917] INFO - '__match_q0_0' with handle 'q0_qubit_state', delayed by 272.00 ns
[2025.01.21 09:44:55.918] INFO Schedule completed. [0.010 s]
[2025.01.21 09:44:55.938] INFO Code generation completed for all AWGs. [0.020 s]
[2025.01.21 09:44:55.939] INFO Completed compilation step 1 of 2. [0.031 s]
[2025.01.21 09:44:55.948] INFO Due to feedback latency constraints, the timing of the following match sections with corresponding handles were changed: [2025.01.21 09:44:55.948] INFO - '__match_q0_0' with handle 'q0_qubit_state', delayed by 272.00 ns [2025.01.21 09:44:55.948] INFO - '__match_q0_0' with handle 'q0_qubit_state', delayed by 272.00 ns [2025.01.21 09:44:55.948] INFO [4 similar messages suppressed, see log file for full set of messages.]
[2025.01.21 09:44:55.948] INFO Schedule completed. [0.009 s]
[2025.01.21 09:44:55.969] INFO Code generation completed for all AWGs. [0.020 s]
[2025.01.21 09:44:55.970] INFO Completed compilation step 2 of 2. [0.031 s]
[2025.01.21 09:44:55.975] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.976] INFO Step Device AWG SeqC LOC CT entries Waveforms Samples
[2025.01.21 09:44:55.976] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.977] INFO 0 hdawg_0 0 4 1 0 0
[2025.01.21 09:44:55.978] INFO shfqc_0 0 9 0 1 8000
[2025.01.21 09:44:55.978] INFO shfqc_0_sg 0 60 15 8 5632
[2025.01.21 09:44:55.979] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.979] INFO 1 hdawg_0 0 4 1 0 0
[2025.01.21 09:44:55.980] INFO shfqc_0 0 9 0 1 8000
[2025.01.21 09:44:55.981] INFO shfqc_0_sg 0 61 18 8 5632
[2025.01.21 09:44:55.981] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.982] INFO TOTAL 134 34 19264
[2025.01.21 09:44:55.982] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:55.988] INFO Finished LabOne Q Compiler run.
[2025.01.21 09:44:55.998] INFO Starting near-time execution...
[2025.01.21 09:44:56.019] INFO Finished near-time execution.
Two-Qubit Randomized Benchmarking using Qiskit¶
Define Circuits with Qiskit¶
# Use Qiskit Experiment Library to Generate RB
rb2_qiskit_circuits = randomized_benchmarking.StandardRB(
physical_qubits=[0, 1],
lengths=[4, 8, 16],
num_samples=2,
).circuits()
When efficiently importing and executing a list of quantum circuits, there currently are strong limitations as to how the measurements are scheduled in these experiment. We strip them here from the Qiskit circuit. We will re-add them to the LabOne Q experiment separately when doing the import.
for circuit in rb1_qiskit_circuits:
circuit.remove_final_measurements()
rb2_qiskit_circuits[0].draw()
┌────────────────────┐ ░ ┌────────────────────┐ ░ » q_0: ┤0 ├─░─┤0 ├─░─» │ Clifford-2Q(7130) │ ░ │ Clifford-2Q(3169) │ ░ » q_1: ┤1 ├─░─┤1 ├─░─» └────────────────────┘ ░ └────────────────────┘ ░ » meas: 2/══════════════════════════════════════════════════» » « ┌────────────────────┐ ░ ┌────────────────────┐ ░ » « q_0: ┤0 ├─░─┤0 ├─░─» « │ Clifford-2Q(8461) │ ░ │ Clifford-2Q(4206) │ ░ » « q_1: ┤1 ├─░─┤1 ├─░─» « └────────────────────┘ ░ └────────────────────┘ ░ » «meas: 2/══════════════════════════════════════════════════» « » « ┌────────────────────┐ ░ ┌─┐ « q_0: ┤0 ├─░─┤M├─── « │ Clifford-2Q(9275) │ ░ └╥┘┌─┐ « q_1: ┤1 ├─░──╫─┤M├ « └────────────────────┘ ░ ║ └╥┘ «meas: 2/══════════════════════════╩══╩═ « 0 1
You can then use the Qiskit transpile
function to obtain a representation of the circuits in your favorite set of basis gates.
Below, we choose the basis ["id", "sx", "x", "rz", "cx"]
. Note that all these gates (except the identity "id") must exist in your set of quantum operations!
# Choose basis gates
rb2_transpiled_circuits = transpile(
rb2_qiskit_circuits, basis_gates=["id", "sx", "x", "rz", "cx"]
)
rb2_program_list = []
for circuit in rb2_transpiled_circuits:
rb2_program_list.append(qasm3.dumps(circuit))
print(rb2_program_list[0])
OPENQASM 3.0; include "stdgates.inc"; bit[2] meas; qubit[2] q; rz(-pi) q[0]; sx q[0]; rz(-2.132183167708309) q[1]; sx q[1]; rz(pi/2) q[1]; cx q[0], q[1]; sx q[0]; rz(-pi/2) q[0]; rz(-pi/2) q[1]; sx q[1]; rz(2.58020581267638) q[1]; sx q[1]; barrier q[0], q[1]; rz(pi/2) q[1]; sx q[1]; rz(pi/2) q[1]; cx q[0], q[1]; cx q[1], q[0]; rz(pi/2) q[0]; sx q[0]; rz(-pi) q[0]; rz(-pi/2) q[1]; sx q[1]; barrier q[0], q[1]; sx q[1]; rz(-1.0094094858814842) q[1]; sx q[1]; rz(-pi/2) q[1]; cx q[0], q[1]; sx q[0]; rz(-pi/2) q[1]; sx q[1]; rz(-2.1321831677083107) q[1]; sx q[1]; barrier q[0], q[1]; sx q[0]; rz(3*pi/2) q[0]; rz(-pi) q[1]; sx q[1]; rz(-pi) q[1]; cx q[0], q[1]; rz(-pi) q[1]; sx q[1]; rz(-pi/2) q[1]; barrier q[0], q[1]; rz(pi/2) q[0]; sx q[0]; rz(pi/2) q[0]; rz(-pi) q[1]; sx q[1]; rz(-pi) q[1]; cx q[0], q[1]; cx q[1], q[0]; cx q[0], q[1]; rz(pi) q[0]; x q[0]; rz(pi) q[1]; barrier q[0], q[1]; meas[0] = measure q[0]; meas[1] = measure q[1];
Execute a single QASM program¶
Now, you'll transpile a two-qubit OpenQASM program into a LabOne Q Experiment
pulse sequence using the class OpenQASMTranspiler
and the options class SingleProgramOptions
. Check out the LabOne Q QASM transplier tutorial to learn more about this interface.
Once you've done that, you can compile your Experiment
and plot the output using the LabOne Q simulator.
Note: the parameter qubit_map
below may need to be updated to match the names of the qubit register from your QASM circuit!
Below, we choose the QASM program defined in the first entry of rb2_program_list
.
# Instantiate OpenQASMTranspiler from the QPU
transpiler = openqasm3.OpenQASMTranspiler(qpu)
# Define options
options = openqasm3.SingleProgramOptions()
# We will not change any of the default options
# Create the Experiment
rb2_exp_single_program = transpiler.experiment(
program=rb2_program_list[0],
qubit_map={"q": [q0, q1]},
options=options,
)
# Set the Experiment calibration from the qubit calibrations
rb2_exp_single_program.set_calibration(q0.calibration())
rb2_exp_single_program.set_calibration(q1.calibration())
# Compile the Experiment
rb2_compiled_exp_single_program = my_session.compile(rb2_exp_single_program)
# Run the Experiment
rb2_results_single_program = my_session.run(rb2_compiled_exp_single_program)
[2025.01.21 09:44:57.370] INFO Resolved modulation type of oscillator 'q0_readout_acquire_osc' on signal 'q0/acquire' to SOFTWARE
[2025.01.21 09:44:57.371] INFO Resolved modulation type of oscillator 'q0_drive_ge_osc' on signal 'q0/drive' to HARDWARE
[2025.01.21 09:44:57.371] INFO Resolved modulation type of oscillator 'q1_readout_acquire_osc' on signal 'q1/acquire' to SOFTWARE
[2025.01.21 09:44:57.372] INFO Resolved modulation type of oscillator 'q1_drive_ge_osc' on signal 'q1/drive' to HARDWARE
[2025.01.21 09:44:57.373] INFO Starting LabOne Q Compiler run...
[2025.01.21 09:44:57.384] INFO Schedule completed. [0.007 s]
[2025.01.21 09:44:57.419] INFO Code generation completed for all AWGs. [0.035 s]
[2025.01.21 09:44:57.420] INFO Completed compilation step 1 of 1. [0.044 s]
[2025.01.21 09:44:57.424] INFO ────────────────────────────────────────────────────────────────
[2025.01.21 09:44:57.425] INFO Device AWG SeqC LOC CT entries Waveforms Samples
[2025.01.21 09:44:57.425] INFO ────────────────────────────────────────────────────────────────
[2025.01.21 09:44:57.425] INFO hdawg_0 0 55 7 6 2496
[2025.01.21 09:44:57.426] INFO shfqc_0 0 6 0 2 16000
[2025.01.21 09:44:57.426] INFO shfqc_0_sg 0 69 13 8 4096
[2025.01.21 09:44:57.426] INFO shfqc_0_sg 1 68 15 10 6848
[2025.01.21 09:44:57.427] INFO ────────────────────────────────────────────────────────────────
[2025.01.21 09:44:57.427] INFO TOTAL 198 35 29440
[2025.01.21 09:44:57.427] INFO ────────────────────────────────────────────────────────────────
[2025.01.21 09:44:57.436] INFO Finished LabOne Q Compiler run.
[2025.01.21 09:44:57.446] INFO Starting near-time execution...
[2025.01.21 09:44:57.456] INFO Finished near-time execution.
Look at the simulated output¶
plot_simulation(
rb2_compiled_exp_single_program,
length=15e-6,
plot_width=12,
plot_height=3,
signal_names_to_show=[
"q0/drive",
"q0/flux",
"q1/drive",
"q1/flux",
],
)
Draw the circuit from above¶
rb2_transpiled_circuits[0].draw()
global phase: π ┌────────┐ ┌────┐ ┌────┐ ┌──────────┐» q_0: ───┤ Rz(-π) ├──┤ √X ├─────────────■─────┤ √X ├───┤ Rz(-π/2) ├» ┌──┴────────┴─┐├────┤┌─────────┐┌─┴─┐┌──┴────┴──┐└──┬────┬──┘» q_1: ┤ Rz(-2.1322) ├┤ √X ├┤ Rz(π/2) ├┤ X ├┤ Rz(-π/2) ├───┤ √X ├───» └─────────────┘└────┘└─────────┘└───┘└──────────┘ └────┘ » meas: 2/═════════════════════════════════════════════════════════════» » « ░ ┌───┐» « q_0: ─────────────────────░───────────────────────────────■──┤ X ├» « ┌────────────┐┌────┐ ░ ┌─────────┐┌────┐┌─────────┐┌─┴─┐└─┬─┘» « q_1: ┤ Rz(2.5802) ├┤ √X ├─░─┤ Rz(π/2) ├┤ √X ├┤ Rz(π/2) ├┤ X ├──■──» « └────────────┘└────┘ ░ └─────────┘└────┘└─────────┘└───┘ » «meas: 2/═════════════════════════════════════════════════════════════» « » « ┌─────────┐ ┌────┐┌────────┐ ░ » « q_0: ┤ Rz(π/2) ├─┤ √X ├┤ Rz(-π) ├─░────────────────────────────────────────» « ├─────────┴┐├────┤└────────┘ ░ ┌────┐┌─────────────┐┌────┐┌──────────┐» « q_1: ┤ Rz(-π/2) ├┤ √X ├───────────░─┤ √X ├┤ Rz(-1.0094) ├┤ √X ├┤ Rz(-π/2) ├» « └──────────┘└────┘ ░ └────┘└─────────────┘└────┘└──────────┘» «meas: 2/══════════════════════════════════════════════════════════════════════» « » « ┌────┐ ░ ┌────┐ ┌──────────┐» « q_0: ──■─────┤ √X ├───────────────────────────────░───┤ √X ├──┤ Rz(3π/2) ├» « ┌─┴─┐┌──┴────┴──┐┌────┐┌─────────────┐┌────┐ ░ ┌─┴────┴─┐└──┬────┬──┘» « q_1: ┤ X ├┤ Rz(-π/2) ├┤ √X ├┤ Rz(-2.1322) ├┤ √X ├─░─┤ Rz(-π) ├───┤ √X ├───» « └───┘└──────────┘└────┘└─────────────┘└────┘ ░ └────────┘ └────┘ » «meas: 2/═════════════════════════════════════════════════════════════════════» « » « ░ ┌─────────┐┌────┐» « q_0: ────────────■───────────────────────────────░─┤ Rz(π/2) ├┤ √X ├» « ┌────────┐┌─┴─┐┌────────┐┌────┐┌──────────┐ ░ └┬────────┤├────┤» « q_1: ┤ Rz(-π) ├┤ X ├┤ Rz(-π) ├┤ √X ├┤ Rz(-π/2) ├─░──┤ Rz(-π) ├┤ √X ├» « └────────┘└───┘└────────┘└────┘└──────────┘ ░ └────────┘└────┘» «meas: 2/═══════════════════════════════════════════════════════════════» « » « ┌─────────┐ ┌───┐ ┌───────┐┌───┐ ░ ┌─┐ « q_0: ┤ Rz(π/2) ├──■──┤ X ├──■──┤ Rz(π) ├┤ X ├─░─┤M├─── « └┬────────┤┌─┴─┐└─┬─┘┌─┴─┐├───────┤└───┘ ░ └╥┘┌─┐ « q_1: ─┤ Rz(-π) ├┤ X ├──■──┤ X ├┤ Rz(π) ├──────░──╫─┤M├ « └────────┘└───┘ └───┘└───────┘ ░ ║ └╥┘ «meas: 2/════════════════════════════════════════════╩══╩═ « 0 1
Look at the pulse sheet¶
show_pulse_sheet(
name="2-qubit RB",
compiled_experiment=rb2_compiled_exp_single_program,
max_events_to_publish=10e4
)
[2025.01.21 09:44:58.202] INFO Recompiling the experiment due to missing extra information in the compiled experiment. Compile with `OUTPUT_EXTRAS=True` and `MAX_EVENTS_TO_PUBLISH=100000.0` to bypass this step with a small impact on the compilation time.
[2025.01.21 09:44:58.214] INFO Resolved modulation type of oscillator 'q0_readout_acquire_osc' on signal 'q0/acquire' to SOFTWARE
[2025.01.21 09:44:58.214] INFO Resolved modulation type of oscillator 'q0_drive_ge_osc' on signal 'q0/drive' to HARDWARE
[2025.01.21 09:44:58.215] INFO Resolved modulation type of oscillator 'q1_readout_acquire_osc' on signal 'q1/acquire' to SOFTWARE
[2025.01.21 09:44:58.215] INFO Resolved modulation type of oscillator 'q1_drive_ge_osc' on signal 'q1/drive' to HARDWARE
[2025.01.21 09:44:58.216] INFO Starting LabOne Q Compiler run...
[2025.01.21 09:44:58.230] INFO Schedule completed. [0.011 s]
[2025.01.21 09:44:58.263] INFO Code generation completed for all AWGs. [0.033 s]
[2025.01.21 09:44:58.264] INFO Completed compilation step 1 of 1. [0.045 s]
[2025.01.21 09:44:58.266] INFO Finished LabOne Q Compiler run.
[2025.01.21 09:44:58.281] INFO Writing html file to /builds/qccs/laboneq-applications/docs/sources/how-to-guides/sources/04_qasm/2-qubit RB_2025-01-21-09-44-58.html
Execute the full RB Experiment¶
Below, we will use the .batch_experiment()
method to create and Experiment
from our list of QASM programs, rb2_program_list
, containing the full two-qubit RB experiment.
The entries in rb2_program_list
are individual RB sequences of a given number of gates, m
. In total, there will be $m\times K$ sequences in the list, where K
is the number of randomizations of each length (the num_samples
parameter in the Qiskit interface above). In our choice above, we have $K=2$ and $m\in \{4, 8, 16\}$.
In the MultiProgramOptions
, you can use the field batch_execution_mode
to specify how all these RB sequences in the list should be executed:
- all in real-time ("rt");
- every sequence of
m
gates in real-time and the iteration over the sequences in near-time ("nt"); - split the entries into the number of near-time steps (called "chunks") using the pipeliner ("pipeline"). Specify the number of chunks to use in the options field
pipeline_chunk_count
.
Below, we use the "pipeline" option, and split our 10 sequences into 2 chunks of 3 RB sequences each. This means that we will have two near-time steps, and each real-time loop will run over 3 RB sequences (all the lengths, in our case).
Note that here we use a different options class, MultiProgramOptions
.
# Instantiate OpenQASMTranspiler from the QPU
transpiler = openqasm3.OpenQASMTranspiler(qpu)
# Define options
options = openqasm3.MultiProgramOptions()
options.repetition_time = 100e-5
options.batch_execution_mode = "pipeline"
options.pipeline_chunk_count = 2
options.add_reset = False
# Create the Experiment
rb2_exp = transpiler.batch_experiment(
programs=rb2_program_list,
qubit_map={"q": [q0, q1]},
options=options,
)
# Set the Experiment calibration from the qubit calibrations
rb2_exp.set_calibration(q0.calibration())
rb2_exp.set_calibration(q1.calibration())
# Compile the Experiment
rb2_compiled_exp = my_session.compile(rb2_exp)
# Run the Experiment
rb2_results = my_session.run(rb2_compiled_exp)
[2025.01.21 09:44:58.680] INFO Resolved modulation type of oscillator 'q0_readout_acquire_osc' on signal 'q0/acquire' to SOFTWARE
[2025.01.21 09:44:58.681] INFO Resolved modulation type of oscillator 'q0_drive_ge_osc' on signal 'q0/drive' to HARDWARE
[2025.01.21 09:44:58.681] INFO Resolved modulation type of oscillator 'q1_readout_acquire_osc' on signal 'q1/acquire' to SOFTWARE
[2025.01.21 09:44:58.681] INFO Resolved modulation type of oscillator 'q1_drive_ge_osc' on signal 'q1/drive' to HARDWARE
[2025.01.21 09:44:58.686] INFO Starting LabOne Q Compiler run...
[2025.01.21 09:44:58.750] INFO Schedule completed. [0.041 s]
[2025.01.21 09:44:58.855] INFO Code generation completed for all AWGs. [0.105 s]
[2025.01.21 09:44:58.856] INFO Completed compilation step 1 of 2. [0.147 s]
[2025.01.21 09:44:58.913] INFO Schedule completed. [0.056 s]
[2025.01.21 09:44:59.034] INFO Code generation completed for all AWGs. [0.120 s]
[2025.01.21 09:44:59.036] INFO Completed compilation step 2 of 2. [0.179 s]
[2025.01.21 09:44:59.043] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:59.043] INFO Step Device AWG SeqC LOC CT entries Waveforms Samples
[2025.01.21 09:44:59.044] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:59.044] INFO 0 hdawg_0 0 208 9 8 3328
[2025.01.21 09:44:59.044] INFO shfqc_0 0 13 0 2 16000
[2025.01.21 09:44:59.045] INFO shfqc_0_sg 0 290 31 21 12576
[2025.01.21 09:44:59.045] INFO shfqc_0_sg 1 266 34 21 13728
[2025.01.21 09:44:59.045] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:59.046] INFO 1 hdawg_0 0 260 9 8 3328
[2025.01.21 09:44:59.046] INFO shfqc_0 0 13 0 2 16000
[2025.01.21 09:44:59.046] INFO shfqc_0_sg 0 326 31 22 13760
[2025.01.21 09:44:59.047] INFO shfqc_0_sg 1 305 31 21 14112
[2025.01.21 09:44:59.047] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:59.047] INFO TOTAL 1668 145 76832
[2025.01.21 09:44:59.047] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:44:59.066] INFO Finished LabOne Q Compiler run.
[2025.01.21 09:44:59.114] INFO Starting near-time execution...
[2025.01.21 09:44:59.156] INFO Finished near-time execution.
## KNOWN ISSUE - pulse sheet viewer and output simulation are not available
Execute the full RB Experiment - including active qubit reset¶
Let's re-run the two-qubit RB experiment with active reset. Just set the options field .add_reset
to True
.
# Instantiate OpenQASMTranspiler from the QPU
transpiler = openqasm3.OpenQASMTranspiler(qpu)
# Define options
options = openqasm3.MultiProgramOptions()
options.repetition_time = 100e-5
options.batch_execution_mode = "pipeline"
options.pipeline_chunk_count = 2
options.add_reset = True
# Create the Experiment
rb2_exp_with_reset = transpiler.batch_experiment(
programs=rb2_program_list,
qubit_map={"q": [q0, q1]},
options=options,
)
# Set the Experiment calibration from the qubit calibrations
rb2_exp_with_reset.set_calibration(q0.calibration())
rb2_exp_with_reset.set_calibration(q1.calibration())
# Compile the Experiment
rb2_compiled_exp_with_reset = my_session.compile(rb2_exp_with_reset)
# Run the Experiment
rb2_results_with_reset = my_session.run(rb2_compiled_exp_with_reset)
[2025.01.21 09:44:59.594] INFO Resolved modulation type of oscillator 'q0_readout_acquire_osc' on signal 'q0/acquire' to SOFTWARE
[2025.01.21 09:44:59.595] INFO Resolved modulation type of oscillator 'q0_drive_ge_osc' on signal 'q0/drive' to HARDWARE
[2025.01.21 09:44:59.595] INFO Resolved modulation type of oscillator 'q1_readout_acquire_osc' on signal 'q1/acquire' to SOFTWARE
[2025.01.21 09:44:59.596] INFO Resolved modulation type of oscillator 'q1_drive_ge_osc' on signal 'q1/drive' to HARDWARE
[2025.01.21 09:44:59.601] INFO Starting LabOne Q Compiler run...
[2025.01.21 09:44:59.667] INFO Due to feedback latency constraints, the timing of the following match sections with corresponding handles were changed: [2025.01.21 09:44:59.667] INFO - '__match_q0_1' with handle 'q0_qubit_state', delayed by 272.00 ns [2025.01.21 09:44:59.667] INFO - '__match_q1_0' with handle 'q1_qubit_state', delayed by 272.00 ns [2025.01.21 09:44:59.667] INFO [4 similar messages suppressed, see log file for full set of messages.]
[2025.01.21 09:44:59.668] INFO Schedule completed. [0.044 s]
[2025.01.21 09:44:59.774] INFO Code generation completed for all AWGs. [0.106 s]
[2025.01.21 09:44:59.775] INFO Completed compilation step 1 of 2. [0.152 s]
[2025.01.21 09:44:59.964] INFO Due to feedback latency constraints, the timing of the following match sections with corresponding handles were changed: [2025.01.21 09:44:59.964] INFO - '__match_q0_1' with handle 'q0_qubit_state', delayed by 272.00 ns [2025.01.21 09:44:59.964] INFO - '__match_q1_0' with handle 'q1_qubit_state', delayed by 272.00 ns [2025.01.21 09:44:59.964] INFO [10 similar messages suppressed, see log file for full set of messages.]
[2025.01.21 09:44:59.965] INFO Schedule completed. [0.189 s]
[2025.01.21 09:45:00.087] INFO Code generation completed for all AWGs. [0.121 s]
[2025.01.21 09:45:00.089] INFO Completed compilation step 2 of 2. [0.314 s]
[2025.01.21 09:45:00.096] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:45:00.096] INFO Step Device AWG SeqC LOC CT entries Waveforms Samples
[2025.01.21 09:45:00.096] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:45:00.097] INFO 0 hdawg_0 0 208 9 8 3328
[2025.01.21 09:45:00.097] INFO shfqc_0 0 14 0 2 16000
[2025.01.21 09:45:00.097] INFO shfqc_0_sg 0 301 33 21 12576
[2025.01.21 09:45:00.098] INFO shfqc_0_sg 1 280 36 22 14144
[2025.01.21 09:45:00.098] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:45:00.098] INFO 1 hdawg_0 0 260 9 8 3328
[2025.01.21 09:45:00.098] INFO shfqc_0 0 14 0 2 16000
[2025.01.21 09:45:00.099] INFO shfqc_0_sg 0 337 33 22 13760
[2025.01.21 09:45:00.099] INFO shfqc_0_sg 1 319 33 22 14528
[2025.01.21 09:45:00.099] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:45:00.099] INFO TOTAL 1719 153 77664
[2025.01.21 09:45:00.100] INFO ───────────────────────────────────────────────────────────────────────
[2025.01.21 09:45:00.118] INFO Finished LabOne Q Compiler run.
[2025.01.21 09:45:00.165] INFO Starting near-time execution...
[2025.01.21 09:45:00.206] INFO Finished near-time execution.