Usage of the backend#
Configuring the backend is done by specifying a Python dictionary (or loading it from a JSON file) that describes your experimental setup. An example of such a hardware configuration is shown below.
The entry "backend": "quantify_scheduler.backends.qblox_backend.hardware_compile"
specifies to the scheduler
that we are using the Qblox backend (specifically the hardware_compile()
function).
Two variants of the same hardware configuration are shown:
The current old-style unvalidated json/dict hardware configuration (see Cluster).
The new
HardwareCompilationConfig
variant that adds validation of the contents and divides into"hardware_description"
,"hardware_options"
and"connectivity"
(see Cluster (HardwareCompilationConfig), and the Hardware compilation configuration section of the User guide).
Example hardware configuration
{
"backend": "quantify_scheduler.backends.qblox_backend.hardware_compile",
"latency_corrections": {
"q4:mw-q4.01": 8e-09,
"q5:mw-q5.01": 4e-09
},
"distortion_corrections": {
"q0:fl-cl0.baseband": {
"clipping_values": [
-2.5,
2.5
],
"filter_func": "scipy.signal.lfilter",
"input_var_name": "x",
"kwargs": {
"a": [
1
],
"b": [
0,
0.25,
0.5
]
}
}
},
"cluster0": {
"cluster0_module1": {
"complex_output_0": {
"dc_mixer_offset_I": 0.0,
"dc_mixer_offset_Q": 0.0,
"lo_name": "lo0",
"portclock_configs": [
{
"clock": "q4.01",
"interm_freq": 200000000.0,
"mixer_amp_ratio": 0.9999,
"mixer_phase_error_deg": -4.2,
"port": "q4:mw"
}
]
},
"instrument_type": "QCM",
"sequence_to_file": false
},
"cluster0_module10": {
"instrument_type": "QCM",
"real_output_0": {
"portclock_configs": [
{
"clock": "cl0.baseband",
"port": "q0:fl"
}
]
},
"real_output_1": {
"portclock_configs": [
{
"clock": "cl0.baseband",
"port": "q1:fl"
}
]
},
"real_output_2": {
"portclock_configs": [
{
"clock": "cl0.baseband",
"port": "q2:fl"
}
]
},
"real_output_3": {
"portclock_configs": [
{
"clock": "cl0.baseband",
"port": "q3:fl"
}
]
},
"sequence_to_file": false
},
"cluster0_module12": {
"instrument_type": "QCM",
"real_output_0": {
"portclock_configs": [
{
"clock": "cl0.baseband",
"port": "q4:fl"
}
]
},
"sequence_to_file": false
},
"cluster0_module2": {
"complex_output_0": {
"lo_freq": null,
"output_att": 4,
"portclock_configs": [
{
"clock": "q0.01",
"interm_freq": 50000000.0,
"port": "q0:mw"
},
{
"clock": "q5.01",
"interm_freq": 50000000.0,
"port": "q5:mw"
}
]
},
"complex_output_1": {
"lo_freq": 5000000000.0,
"output_att": 6,
"portclock_configs": [
{
"clock": "q6.01",
"interm_freq": null,
"port": "q6:mw"
}
]
},
"instrument_type": "QCM_RF",
"sequence_to_file": false
},
"cluster0_module3": {
"complex_output_0": {
"dc_mixer_offset_I": -0.054,
"dc_mixer_offset_Q": -0.034,
"input_gain_I": 2,
"input_gain_Q": 3,
"lo_name": "lo1",
"portclock_configs": [
{
"clock": "q4.ro",
"interm_freq": null,
"mixer_amp_ratio": 0.9997,
"mixer_phase_error_deg": -4.0,
"port": "q4:res"
}
]
},
"instrument_type": "QRM",
"sequence_to_file": false
},
"cluster0_module4": {
"complex_input_0": {
"input_att": 10,
"lo_freq": null,
"portclock_configs": [
{
"clock": "q5.ro",
"interm_freq": 50000000.0,
"port": "q5:res"
}
]
},
"complex_output_0": {
"lo_freq": 7800000000.0,
"output_att": 12,
"portclock_configs": [
{
"clock": "q0.ro",
"interm_freq": null,
"port": "q0:res"
}
]
},
"instrument_type": "QRM_RF",
"sequence_to_file": false
},
"instrument_type": "Cluster",
"ref": "internal",
"sequence_to_file": false
},
"lo0": {
"frequency": null,
"instrument_type": "LocalOscillator",
"power": 1
},
"lo1": {
"frequency": 7200000000.0,
"instrument_type": "LocalOscillator",
"power": 1
}
}
Example hardware configuration (HardwareCompilationConfig)
{
"backend": "quantify_scheduler.backends.qblox_backend.hardware_compile",
"hardware_description": {
"cluster0": {
"instrument_type": "Cluster",
"ref": "internal",
"modules": {
"1": {
"instrument_type": "QCM"
},
"2": {
"instrument_type": "QCM_RF"
},
"3": {
"instrument_type": "QRM"
},
"4": {
"instrument_type": "QRM_RF"
},
"10": {
"instrument_type": "QCM"
},
"12": {
"instrument_type": "QCM"
}
}
},
"lo0": {
"instrument_type": "LocalOscillator",
"power": 1
},
"lo1": {
"instrument_type": "LocalOscillator",
"power": 1
}
},
"hardware_options": {
"latency_corrections": {
"q4:mw-q4.01": 8e-09,
"q5:mw-q5.01": 4e-09
},
"distortion_corrections": {
"q0:fl-cl0.baseband": {
"filter_func": "scipy.signal.lfilter",
"input_var_name": "x",
"kwargs": {
"b": [
0,
0.25,
0.5
],
"a": [
1
]
},
"clipping_values": [
-2.5,
2.5
]
}
},
"modulation_frequencies": {
"q0:res-q0.ro": {
"interm_freq": null,
"lo_freq": 7800000000.0
},
"q0:mw-q0.01": {
"interm_freq": 50000000.0,
"lo_freq": null
},
"q4:mw-q4.01": {
"interm_freq": 200000000.0,
"lo_freq": null
},
"q4:res-q4.ro": {
"interm_freq": null,
"lo_freq": 7200000000.0
},
"q5:mw-q5.01": {
"interm_freq": 50000000.0,
"lo_freq": null
},
"q5:res-q5.ro": {
"interm_freq": 50000000.0
},
"q6:mw-q6.01": {
"lo_freq": 5000000000.0
}
},
"mixer_corrections": {
"q4:mw-q4.01": {
"amp_ratio": 0.9999,
"phase_error": -4.2
},
"q4:res-q4.ro": {
"dc_offset_i": -0.054,
"dc_offset_q": -0.034,
"amp_ratio": 0.9997,
"phase_error": -4.0
}
},
"output_att": {
"q0:mw-q0.01": 4,
"q0:res-q0.ro": 12,
"q5:mw-q5.01": 4,
"q6:mw-q6.01": 6
},
"input_gain": {
"q4:res-q4.ro": {
"gain_I": 2,
"gain_Q": 3
}
},
"input_att": {
"q5:res-q5.ro": 10
},
"sequencer_options": {
"qe0:optical_readout-qe0.ge0": {
"ttl_acq_threshold": 0.5
}
}
},
"connectivity": {
"cluster0": {
"cluster0_module1": {
"complex_output_0": {
"lo_name": "lo0",
"portclock_configs": [
{
"port": "q4:mw",
"clock": "q4.01"
}
]
}
},
"cluster0_module2": {
"complex_output_0": {
"portclock_configs": [
{
"port": "q0:mw",
"clock": "q0.01"
},
{
"port": "q5:mw",
"clock": "q5.01"
}
]
},
"complex_output_1": {
"portclock_configs": [
{
"port": "q6:mw",
"clock": "q6.01"
}
]
}
},
"cluster0_module3": {
"complex_output_0": {
"lo_name": "lo1",
"portclock_configs": [
{
"port": "q4:res",
"clock": "q4.ro"
}
]
}
},
"cluster0_module4": {
"complex_input_0": {
"portclock_configs": [
{
"port": "q5:res",
"clock": "q5.ro"
}
]
},
"complex_output_0": {
"portclock_configs": [
{
"port": "q0:res",
"clock": "q0.ro"
}
]
}
},
"cluster0_module10": {
"real_output_0": {
"portclock_configs": [
{
"port": "q0:fl",
"clock": "cl0.baseband"
}
]
},
"real_output_1": {
"portclock_configs": [
{
"port": "q1:fl",
"clock": "cl0.baseband"
}
]
},
"real_output_2": {
"portclock_configs": [
{
"port": "q2:fl",
"clock": "cl0.baseband"
}
]
},
"real_output_3": {
"portclock_configs": [
{
"port": "q3:fl",
"clock": "cl0.baseband"
}
]
}
},
"cluster0_module12": {
"real_output_0": {
"portclock_configs": [
{
"port": "q4:fl",
"clock": "cl0.baseband"
}
]
}
}
}
}
}