Skip to content

laboneq_applications.analysis.echo

This module defines the analysis for extracting T2 from a Hahn Echo experiment.

The experiment is defined in laboneq_applications.experiments. See the docstring of this file for more details on how the experiment is created.

In this analysis, we first interpret the raw data into qubit populations using principal component analysis or rotation and projection on the measured calibration states. Then we fit an exponential decay model to the qubit population and extract the qubit dephasing time T2 from the fit. Finally, we plot the data and the fit.

analysis_workflow(result, qubits, delays, options=None)

The Hahn echo analysis workflow.

The workflow consists of the following steps:

Parameters:

Name Type Description Default
result RunExperimentResults

The experiment results returned by the run_experiment task of the Hahn echo experiment workflow.

required
qubits QuantumElements

The qubits on which to run the analysis. May be either a single qubit or a list of qubits. The UIDs of these qubits must exist in the result.

required
delays QubitSweepPoints

The delays to sweep over for each qubit. The delays between the two x90 pulses and the refocusing pulse are delays / 2; see the schematic of the pulse sequence in the file defining the experiment. Note that delays must be identical for qubits that use the same measure port.

required
options TuneUpAnalysisWorkflowOptions | None

The options for building the workflow as an instance of [TuneUpAnalysisWorkflowOptions]. See the docstrings of this class for more details.

None

Returns:

Name Type Description
WorkflowBuilder None

The builder for the analysis workflow.

Example
options = analysis_workflow.options()
options.close_figures(False)
result = analysis_workflow(
    results=results
    qubits=[q0, q1],
    delays=[
        np.linspace(0, 10e-6, 11),
        np.linspace(0, 10e-6, 11),
    ],
    options=options,
).run()

extract_qubit_parameters(qubits, fit_results, options=None)

Extract the new T2 values for each qubit from the fit results.

Parameters:

Name Type Description Default
qubits QuantumElements

The qubits on which to run the task. May be either a single qubit or a list of qubits.

required
fit_results dict[str, ModelResult]

the fit-results dictionary returned by the task fit_data.

required
options TuneupAnalysisOptions | None

The options for building the workflow as an instance of [TuneupAnalysisOptions]. See the docstrings of this class for more details.

None

Returns:

Type Description
dict[str, dict[str, dict[str, int | float | Variable | None]]]

dict with extracted qubit parameters and the previous values for those qubit

dict[str, dict[str, dict[str, int | float | Variable | None]]]

parameters. The dictionary has the following form:

dict[str, dict[str, dict[str, int | float | Variable | None]]]

```python

dict[str, dict[str, dict[str, int | float | Variable | None]]]

{ "new_parameter_values": { q.uid: { qb_param_name: qb_param_value }, } "old_parameter_values": { q.uid: { qb_param_name: qb_param_value }, }

dict[str, dict[str, dict[str, int | float | Variable | None]]]

}

dict[str, dict[str, dict[str, int | float | Variable | None]]]

```

dict[str, dict[str, dict[str, int | float | Variable | None]]]

If the do_fitting option is False, the new_parameter_values are not extracted

dict[str, dict[str, dict[str, int | float | Variable | None]]]

and the function only returns the old_parameter_values.

dict[str, dict[str, dict[str, int | float | Variable | None]]]

If a qubit uid is not found in fit_results, the new_parameter_values entry for

dict[str, dict[str, dict[str, int | float | Variable | None]]]

that qubit is left empty.

fit_data(qubits, processed_data_dict, options=None)

Perform a fit of an exponential-decay model to the qubit e-state population.

Parameters:

Name Type Description Default
qubits QuantumElements

The qubits on which to run the task. May be either a single qubit or a list of qubits. The UIDs of these qubits must exist in processed_data_dict

required
processed_data_dict dict[str, dict[str, ArrayLike]]

the processed data dictionary containing the qubit population to be fitted and the sweep points of the experiment.

required
options TuneupAnalysisOptions | None

The options for building the workflow as an instance of [TuneupAnalysisOptions]. See the docstrings of this class for more details.

None

Returns:

Type Description
dict[str, ModelResult]

dict with qubit UIDs as keys and the fit results for each qubit as values.

plot_population(qubits, processed_data_dict, fit_results, qubit_parameters, options=None)

Create the Hahn echo plots.

Parameters:

Name Type Description Default
qubits QuantumElements

The qubits on which to run the task. May be either a single qubit or a list of qubits. The UIDs of these qubits must exist in processed_data_dict, fit_results and qubit_parameters.

required
processed_data_dict dict[str, dict[str, ArrayLike]]

the processed data dictionary returned by process_raw_data

required
fit_results dict[str, ModelResult] | None

the fit-results dictionary returned by fit_data

required
qubit_parameters dict[str, dict[str, dict[str, int | float | Variable | None]]] | None

the qubit-parameters dictionary returned by extract_qubit_parameters

required
options TuneupAnalysisOptions | None

The options for processing the raw data. See [TuneupAnalysisOptions], [TuneupExperimentOptions] and [BaseExperimentOptions] for accepted options. Overwrites the options from [TuneupAnalysisOptions], [TuneupExperimentOptions] and [BaseExperimentOptions].

None

Returns:

Type Description
dict[str, Figure]

dict with qubit UIDs as keys and the figures for each qubit as values.

dict[str, Figure]

If a qubit uid is not found in fit_results, the fit and the textbox with the

dict[str, Figure]

extracted qubit parameters are not plotted.

plot_raw_complex_data_1d(qubits, result, delays, options=None)

Creates the raw-data plots for the Hahn Echo experiment.

Calls plot_raw_complex_data_1d. This task is needed because we want to plot the raw data as a function of the total time separation between the two x90 pulses in the experiment. Therefore, we need to first add the length of the refocusing pulse to the delays before calling plot_raw_complex_data_1d.

Parameters:

Name Type Description Default
result RunExperimentResults | tuple[RunExperimentResults, Results]

The experiment results returned by the run_experiment task of the Hahn echo experiment workflow.

required
qubits QuantumElements

The qubits on which to run the task. May be either a single qubit or a list of qubits. The UIDs of these qubits must exist in the result.

required
delays QubitSweepPoints

The delays to sweep over for each qubit. The delays between the two x90 pulses and the refocusing pulse are delays / 2; see the schematic of the pulse sequence in the file defining the experiment. Note that delays must be identical for qubits that use the same measure port.

required
options TuneupAnalysisOptions | None

The options for building the workflow as an instance of [TuneupAnalysisOptions]. See the docstrings of this class for more details.

None

Returns:

Type Description
dict[str, dict[str, ArrayLike]]

dict with qubit UIDs as keys and the figures for each qubit as values.