Source code for braket.circuits.noise_model.circuit_instruction_criteria

# Copyright Amazon.com Inc. or its affiliates. All Rights Reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License"). You
# may not use this file except in compliance with the License. A copy of
# the License is located at
#
#     http://aws.amazon.com/apache2.0/
#
# or in the "license" file accompanying this file. This file is
# distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
# ANY KIND, either express or implied. See the License for the specific
# language governing permissions and limitations under the License.

from abc import abstractmethod
from typing import Optional, Union

from braket.circuits.instruction import Instruction
from braket.circuits.noise_model.criteria import Criteria
from braket.registers.qubit_set import QubitSetInput


[docs] class CircuitInstructionCriteria(Criteria): """Criteria that implement these methods may be used to determine gate noise."""
[docs] @abstractmethod def instruction_matches(self, instruction: Instruction) -> bool: """Returns True if an Instruction matches the criteria. Args: instruction (Instruction): An Instruction to match. Raises: NotImplementedError: Not implemented. Returns: bool: True if an Instruction matches the criteria. """ raise NotImplementedError
@staticmethod def _check_target_in_qubits( qubits: Optional[set[Union[int, tuple[int]]]], target: QubitSetInput ) -> bool: """Returns true if the given targets of an instruction match the given qubit input set. Args: qubits (Optional[set[Union[int, tuple[int]]]]): The qubits provided to the criteria. target (QubitSetInput): Targets of an instruction. Returns: bool: True if the provided target should be matched by the given qubits. """ if qubits is None: return True target = [int(item) for item in target] return target[0] in qubits if len(target) == 1 else tuple(target) in qubits