From 8b7dcc30170de15686ce162014e3fe38add6f2ac Mon Sep 17 00:00:00 2001 From: Pavol Juhas Date: Tue, 12 Jul 2022 20:15:33 -0700 Subject: [PATCH] Remove unused method SimulationState.with_qubits Avoid constructor argument conundrum detailed in #5721. Closes #5721 --- .../density_matrix_simulation_state_test.py | 14 ------------- cirq-core/cirq/sim/simulation_state.py | 21 ------------------- .../sim/state_vector_simulation_state_test.py | 14 ------------- 3 files changed, 49 deletions(-) diff --git a/cirq-core/cirq/sim/density_matrix_simulation_state_test.py b/cirq-core/cirq/sim/density_matrix_simulation_state_test.py index 03b5e5d497f..c2d84b0c4a5 100644 --- a/cirq-core/cirq/sim/density_matrix_simulation_state_test.py +++ b/cirq-core/cirq/sim/density_matrix_simulation_state_test.py @@ -73,20 +73,6 @@ class NoDetails: cirq.act_on(NoDetails(), args, qubits=()) -def test_with_qubits(): - original = cirq.DensityMatrixSimulationState( - qubits=cirq.LineQubit.range(1), initial_state=1, dtype=np.complex64 - ) - extened = original.with_qubits(cirq.LineQubit.range(1, 2)) - np.testing.assert_almost_equal( - extened.target_tensor, - cirq.density_matrix_kronecker_product( - np.array([[0, 0], [0, 1]], dtype=np.complex64), - np.array([[1, 0], [0, 0]], dtype=np.complex64), - ), - ) - - def test_qid_shape_error(): with pytest.raises(ValueError, match="qid_shape must be provided"): cirq.sim.density_matrix_simulation_state._BufferedDensityMatrix.create(initial_state=0) diff --git a/cirq-core/cirq/sim/simulation_state.py b/cirq-core/cirq/sim/simulation_state.py index 7f14faa3118..fcaeb95f9f2 100644 --- a/cirq-core/cirq/sim/simulation_state.py +++ b/cirq-core/cirq/sim/simulation_state.py @@ -173,27 +173,6 @@ def kronecker_product(self: TSelf, other: TSelf, *, inplace=False) -> TSelf: args._set_qubits(self.qubits + other.qubits) return args - def with_qubits(self: TSelf, qubits) -> TSelf: - """Extend current state space with added qubits. - - The state of the added qubits is the default value set in the - subclasses. A new state space is created as the Kronecker product of - the original one and the added one. - - Args: - qubits: The qubits to be added to the state space. - - Returns: - A new subclass object containing the extended state space. - """ - # TODO(#5721): Fix inconsistent usage of the `state` argument in the - # SimulationState base (required) and in its derived classes (unknown - # in StateVectorSimulationState), then remove the pylint filter below. - # pylint: disable=missing-kwoa - new_space = type(self)(qubits=qubits) # type: ignore - # pylint: enable=missing-kwoa - return self.kronecker_product(new_space) - def factor( self: TSelf, qubits: Sequence['cirq.Qid'], *, validate=True, atol=1e-07, inplace=False ) -> Tuple[TSelf, TSelf]: diff --git a/cirq-core/cirq/sim/state_vector_simulation_state_test.py b/cirq-core/cirq/sim/state_vector_simulation_state_test.py index 102d5bb5045..8bc5f2b6d96 100644 --- a/cirq-core/cirq/sim/state_vector_simulation_state_test.py +++ b/cirq-core/cirq/sim/state_vector_simulation_state_test.py @@ -269,20 +269,6 @@ def test_measured_mixture(): assert results.histogram(key='flip') == results.histogram(key='m') -def test_with_qubits(): - original = cirq.StateVectorSimulationState( - qubits=cirq.LineQubit.range(2), initial_state=1, dtype=np.complex64 - ) - extened = original.with_qubits(cirq.LineQubit.range(2, 4)) - np.testing.assert_almost_equal( - extened.target_tensor, - cirq.state_vector_kronecker_product( - np.array([[0.0 + 0.0j, 1.0 + 0.0j], [0.0 + 0.0j, 0.0 + 0.0j]], dtype=np.complex64), - np.array([[1.0 + 0.0j, 0.0 + 0.0j], [0.0 + 0.0j, 0.0 + 0.0j]], dtype=np.complex64), - ), - ) - - def test_qid_shape_error(): with pytest.raises(ValueError, match="qid_shape must be provided"): cirq.sim.state_vector_simulation_state._BufferedStateVector.create(initial_state=0)