Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Track classical register indices for measurements #1006

Closed
15 changes: 9 additions & 6 deletions src/braket/circuits/braket_program_context.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
# ANY KIND, either express or implied. See the License for the specific
# language governing permissions and limitations under the License.

from collections.abc import Iterable
from typing import Optional, Union

import numpy as np
Expand Down Expand Up @@ -161,16 +162,18 @@ def handle_parameter_value(
return FreeParameterExpression(evaluated_value)
return value

def add_measure(self, target: tuple[int]) -> None:
def add_measure(
self, target: tuple[int], classical_targets: Iterable[int] | None = None
) -> None:
"""Add a measure instruction to the circuit

Args:
target (tuple[int]): the target qubits to be measured.

speller26 marked this conversation as resolved.
Show resolved Hide resolved
classical_targets (Iterable[int] | None): the classical registers
speller26 marked this conversation as resolved.
Show resolved Hide resolved
to use in the qubit measurement.
"""
for index, qubit in enumerate(target):
for iter, qubit in enumerate(target):
index = classical_targets[iter] if classical_targets else iter
instruction = Instruction(Measure(index=index), qubit)
self._circuit.add_instruction(instruction)
if self._circuit._measure_targets:
self._circuit._measure_targets.append(qubit)
else:
self._circuit._measure_targets = [qubit]
9 changes: 5 additions & 4 deletions src/braket/circuits/circuit.py
Original file line number Diff line number Diff line change
Expand Up @@ -504,6 +504,11 @@ def add_instruction(
# Check if there is a measure instruction on the circuit
self._check_if_qubit_measured(instruction, target, target_mapping)

# Update measure targets if instruction is a measurement
if isinstance(instruction.operator, Measure):
measure_target = target or instruction.target[0]
self._measure_targets = (self._measure_targets or []) + [measure_target]

if not target_mapping and not target:
# Nothing has been supplied, add instruction
instructions_to_add = [instruction]
Expand Down Expand Up @@ -710,10 +715,6 @@ def _add_measure(self, target_qubits: QubitSetInput) -> None:
target=target,
)
)
if self._measure_targets:
self._measure_targets.append(target)
else:
self._measure_targets = [target]

def measure(self, target_qubits: QubitSetInput) -> Circuit:
"""
Expand Down
Loading