From b6fa6b88530cb6567f2d63c4e1794cb974999c7b Mon Sep 17 00:00:00 2001 From: Tanuj Khattar Date: Thu, 17 Feb 2022 22:35:44 +0530 Subject: [PATCH] Add `clean_operations` flag to `cirq.two_qubit_matrix_to_sqrt_iswap_operations` (#5002) * Add clean_operations flag to sqrt iswap decomposer * Add tests --- .../two_qubit_to_sqrt_iswap.py | 12 ++++++++++-- .../two_qubit_to_sqrt_iswap_test.py | 2 ++ 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/cirq-core/cirq/transformers/analytical_decompositions/two_qubit_to_sqrt_iswap.py b/cirq-core/cirq/transformers/analytical_decompositions/two_qubit_to_sqrt_iswap.py index a0bba8f4e1be..86281d4b4705 100644 --- a/cirq-core/cirq/transformers/analytical_decompositions/two_qubit_to_sqrt_iswap.py +++ b/cirq-core/cirq/transformers/analytical_decompositions/two_qubit_to_sqrt_iswap.py @@ -24,8 +24,9 @@ import numpy as np -from cirq import ops, linalg, protocols +from cirq import circuits, ops, linalg, protocols from cirq.transformers.analytical_decompositions import single_qubit_decompositions +from cirq.transformers.merge_single_qubit_gates import merge_single_qubit_gates_to_phxz if TYPE_CHECKING: import cirq @@ -40,6 +41,7 @@ def two_qubit_matrix_to_sqrt_iswap_operations( use_sqrt_iswap_inv: bool = False, atol: float = 1e-8, check_preconditions: bool = True, + clean_operations: bool = False, ) -> Sequence['cirq.Operation']: """Decomposes a two-qubit operation into ZPow/XPow/YPow/sqrt-iSWAP gates. @@ -69,6 +71,8 @@ def two_qubit_matrix_to_sqrt_iswap_operations( construction. check_preconditions: If set, verifies that the input corresponds to a 4x4 unitary before decomposing. + clean_operations: Merges runs of single qubit gates to a single `cirq.PhasedXZGate` in + the resulting operations list. Returns: A list of operations implementing the matrix including at most three @@ -92,7 +96,11 @@ def two_qubit_matrix_to_sqrt_iswap_operations( operations = _kak_decomposition_to_sqrt_iswap_operations( q0, q1, kak, required_sqrt_iswap_count, use_sqrt_iswap_inv, atol=atol ) - return operations + return ( + [*merge_single_qubit_gates_to_phxz(circuits.Circuit(operations)).all_operations()] + if clean_operations + else operations + ) def _kak_decomposition_to_sqrt_iswap_operations( diff --git a/cirq-core/cirq/transformers/analytical_decompositions/two_qubit_to_sqrt_iswap_test.py b/cirq-core/cirq/transformers/analytical_decompositions/two_qubit_to_sqrt_iswap_test.py index 6b4edeb8b50b..27db2f822dee 100644 --- a/cirq-core/cirq/transformers/analytical_decompositions/two_qubit_to_sqrt_iswap_test.py +++ b/cirq-core/cirq/transformers/analytical_decompositions/two_qubit_to_sqrt_iswap_test.py @@ -382,6 +382,8 @@ def test_decomp_optimal3(u): @pytest.mark.parametrize('u', ALL_REGION_UNITARIES) def test_all_weyl_regions(u): q0, q1 = cirq.LineQubit.range(2) + ops = cirq.two_qubit_matrix_to_sqrt_iswap_operations(q0, q1, u, clean_operations=True) + assert_valid_decomp(u, ops, single_qubit_gate_types=(cirq.PhasedXZGate,)) ops = cirq.two_qubit_matrix_to_sqrt_iswap_operations(q0, q1, u) assert_valid_decomp(u, ops)