From ad29fa87caa005ccd22fa5101d353fdb5230355c Mon Sep 17 00:00:00 2001 From: Pavol Juhas Date: Wed, 18 Sep 2024 13:51:35 -0700 Subject: [PATCH] Fix Rigetti check for Aspen family device kind (#6734) * Sync with new API for checking device family in qcs-sdk-python, Ref: https://github.com/rigetti/qcs-sdk-rust/pull/463 in isa.pyi * Require qcs-sdk-python-0.20.1 which introduced the new family API Fixes #6732 --- cirq-rigetti/cirq_rigetti/aspen_device.py | 2 +- cirq-rigetti/cirq_rigetti/aspen_device_test.py | 6 +++--- cirq-rigetti/requirements.txt | 3 +++ 3 files changed, 7 insertions(+), 4 deletions(-) diff --git a/cirq-rigetti/cirq_rigetti/aspen_device.py b/cirq-rigetti/cirq_rigetti/aspen_device.py index 5278ca68dfb1..9097eb18665a 100644 --- a/cirq-rigetti/cirq_rigetti/aspen_device.py +++ b/cirq-rigetti/cirq_rigetti/aspen_device.py @@ -66,7 +66,7 @@ def __init__(self, isa: Union[InstructionSetArchitecture, Dict[str, Any]]) -> No else: self.isa = InstructionSetArchitecture.from_raw(json.dumps(isa)) - if self.isa.architecture.family != Family.Aspen: + if not Family.is_aspen(self.isa.architecture.family): raise UnsupportedRigettiQCSQuantumProcessor( 'this integration currently only supports Aspen devices, ' f'but client provided a {self.isa.architecture.family} device' diff --git a/cirq-rigetti/cirq_rigetti/aspen_device_test.py b/cirq-rigetti/cirq_rigetti/aspen_device_test.py index 5b29d5b4b3ae..3184293dbce7 100644 --- a/cirq-rigetti/cirq_rigetti/aspen_device_test.py +++ b/cirq-rigetti/cirq_rigetti/aspen_device_test.py @@ -253,10 +253,10 @@ def test_rigetti_qcs_aspen_device_repr(qcs_aspen8_isa: InstructionSetArchitectur def test_rigetti_qcs_aspen_device_family_validation(qcs_aspen8_isa: InstructionSetArchitecture): """test RigettiQCSAspenDevice validates architecture family on initialization""" non_aspen_isa = InstructionSetArchitecture.from_raw(qcs_aspen8_isa.json()) - non_aspen_isa.architecture.family = Family.NONE + non_aspen_isa.architecture.family = Family.new_none() - assert ( - non_aspen_isa.architecture.family == Family.Aspen + assert Family.is_aspen( + non_aspen_isa.architecture.family ), 'ISA family is read-only and should still be Aspen' diff --git a/cirq-rigetti/requirements.txt b/cirq-rigetti/requirements.txt index 274ad9ad52fa..c892298fd613 100644 --- a/cirq-rigetti/requirements.txt +++ b/cirq-rigetti/requirements.txt @@ -1 +1,4 @@ pyquil>=4.11.0,<5.0.0 + +# TODO - remove once pyquil requires qcs-sdk-python >= 0.20.1 +qcs-sdk-python>=0.20.1