From c6704ad8d3e034c25d8aaa5d71f0a8a4c4d7d6eb Mon Sep 17 00:00:00 2001 From: Hayk Sargsyan <52532457+hay-k@users.noreply.github.com> Date: Wed, 21 Aug 2024 15:30:00 +0400 Subject: [PATCH] fix kernel based weights being generated multiple times --- src/qibolab/instruments/zhinst/executor.py | 74 ++++++++++------------ 1 file changed, 33 insertions(+), 41 deletions(-) diff --git a/src/qibolab/instruments/zhinst/executor.py b/src/qibolab/instruments/zhinst/executor.py index bfba7a6d98..995863bf94 100644 --- a/src/qibolab/instruments/zhinst/executor.py +++ b/src/qibolab/instruments/zhinst/executor.py @@ -559,6 +559,34 @@ def get_channel_node_path(self, channel_name: str) -> str: f"Could not find instrument node corresponding to channel {channel_name}" ) + def _calculate_weight(self, pulse, qubit, exp_options): + if ( + qubit.kernel is not None + and exp_options.acquisition_type == lo.AcquisitionType.DISCRIMINATION + ): + return lo.pulse_library.sampled_pulse_complex( + samples=qubit.kernel * np.exp(1j * qubit.iq_angle), + ) + + elif exp_options.acquisition_type == lo.AcquisitionType.DISCRIMINATION: + return lo.pulse_library.sampled_pulse_complex( + samples=np.ones( + [ + int( + pulse.pulse.duration * 2 + - 3 * self.smearing * NANO_TO_SECONDS + ) + ] + ) + * np.exp(1j * qubit.iq_angle), + ) + else: + return lo.pulse_library.const( + length=round(pulse.pulse.duration * NANO_TO_SECONDS, 9) + - 1.5 * self.smearing * NANO_TO_SECONDS, + amplitude=1, + ) + def select_exp(self, exp, qubits, exp_options): """Build Zurich Experiment selecting the relevant sections.""" # channels that were not split are just applied in parallel to the rest of the experiment @@ -607,53 +635,17 @@ def select_exp(self, exp, qubits, exp_options): with exp.section(uid=section_uid, play_after=previous_section): for ch, pulse in seq.measurements: qubit = qubits[pulse.pulse.qubit] - q = qubit.name exp.delay( signal=acquire_channel_name(qubit), time=self.smearing * NANO_TO_SECONDS, ) - if ( - qubit.kernel is not None - and exp_options.acquisition_type - == lo.AcquisitionType.DISCRIMINATION - ): - weight = lo.pulse_library.sampled_pulse_complex( - samples=qubit.kernel * np.exp(1j * qubit.iq_angle), + if qubit.name not in weights: + weights[qubit.name] = self._calculate_weight( + pulse, qubit, exp_options ) - else: - if i == 0: - if ( - exp_options.acquisition_type - == lo.AcquisitionType.DISCRIMINATION - ): - weight = lo.pulse_library.sampled_pulse_complex( - samples=np.ones( - [ - int( - pulse.pulse.duration * 2 - - 3 * self.smearing * NANO_TO_SECONDS - ) - ] - ) - * np.exp(1j * qubit.iq_angle), - ) - weights[q] = weight - else: - weight = lo.pulse_library.const( - length=round( - pulse.pulse.duration * NANO_TO_SECONDS, 9 - ) - - 1.5 * self.smearing * NANO_TO_SECONDS, - amplitude=1, - ) - - weights[q] = weight - elif i != 0: - weight = weights[q] - measure_pulse_parameters = {"phase": 0} if i == len(self.sequence[measure_channel_name(qubit)]) - 1: @@ -663,8 +655,8 @@ def select_exp(self, exp, qubits, exp_options): exp.measure( acquire_signal=acquire_channel_name(qubit), - handle=f"sequence{q}_{i}", - integration_kernel=weight, + handle=f"sequence{qubit.name}_{i}", + integration_kernel=weights[qubit.name], integration_kernel_parameters=None, integration_length=None, measure_signal=measure_channel_name(qubit),