diff --git a/cirq/_compat.py b/cirq/_compat.py index 3cc1cdb1e5e..ea4030025f9 100644 --- a/cirq/_compat.py +++ b/cirq/_compat.py @@ -192,6 +192,9 @@ def _print(self, expr, **kwargs): if hasattr(value, "__qualname__"): return f"{value.__module__}.{value.__qualname__}" + if isinstance(value, np.number): + return str(value) + return repr(value) diff --git a/cirq/contrib/requirements.txt b/cirq/contrib/requirements.txt index 9bb5ef009e8..89faa2ab4c6 100644 --- a/cirq/contrib/requirements.txt +++ b/cirq/contrib/requirements.txt @@ -4,5 +4,5 @@ ply>=3.6 pylatex~=1.4 # quimb -quimb~=1.7 +quimb>=1.8 opt_einsum diff --git a/cirq/protocols/circuit_diagram_info_protocol.py b/cirq/protocols/circuit_diagram_info_protocol.py index 3b6b3445912..03ccf171ac0 100644 --- a/cirq/protocols/circuit_diagram_info_protocol.py +++ b/cirq/protocols/circuit_diagram_info_protocol.py @@ -277,6 +277,8 @@ def format_radians(self, radians: Union[sympy.Basic, int, float]) -> str: if self.precision is not None and not isinstance(radians, sympy.Basic): quantity = self.format_real(radians / np.pi) return quantity + unit + if isinstance(radians, np.number): + return str(radians) return repr(radians) def copy(self): diff --git a/cirq/protocols/circuit_diagram_info_protocol_test.py b/cirq/protocols/circuit_diagram_info_protocol_test.py index a1a5baca530..23198efea01 100644 --- a/cirq/protocols/circuit_diagram_info_protocol_test.py +++ b/cirq/protocols/circuit_diagram_info_protocol_test.py @@ -208,6 +208,9 @@ def test_format_real(): assert args.format_real(sympy.Symbol('t')) == 't' assert args.format_real(sympy.Symbol('t') * 2 + 1) == '2*t + 1' + assert args.format_real(np.float64(1.1)) == '1.1' + assert args.format_real(np.int32(1)) == '1' + args.precision = None assert args.format_real(1) == '1' assert args.format_real(1.1) == '1.1' @@ -252,6 +255,7 @@ def test_format_radians_without_precision(): assert args.format_radians(-np.pi) == '-pi' assert args.format_radians(1.1) == '1.1' assert args.format_radians(1.234567) == '1.234567' + assert args.format_radians(np.float32(1.234567)) == '1.234567' assert args.format_radians(1 / 7) == repr(1 / 7) assert args.format_radians(sympy.Symbol('t')) == 't' assert args.format_radians(sympy.Symbol('t') * 2 + 1) == '2*t + 1' @@ -261,6 +265,7 @@ def test_format_radians_without_precision(): assert args.format_radians(-np.pi) == '-π' assert args.format_radians(1.1) == '1.1' assert args.format_radians(1.234567) == '1.234567' + assert args.format_radians(np.float32(1.234567)) == '1.234567' assert args.format_radians(1 / 7) == repr(1 / 7) assert args.format_radians(sympy.Symbol('t')) == 't' assert args.format_radians(sympy.Symbol('t') * 2 + 1) == '2*t + 1' diff --git a/cirq/protocols/json_serialization_test.py b/cirq/protocols/json_serialization_test.py index 82ac67b6278..15334d31f5c 100644 --- a/cirq/protocols/json_serialization_test.py +++ b/cirq/protocols/json_serialization_test.py @@ -55,6 +55,13 @@ class _ModuleDeprecation: 'non_existent_should_be_fine': None, } +# TODO(#6706) remove after cirq_rigetti supports NumPy 2.0 +if np.__version__.startswith("2."): # pragma: no cover + warnings.warn( + "json_serialization_test - ignoring cirq_rigetti due to incompatibility with NumPy 2.0" + ) + del TESTED_MODULES["cirq_rigetti"] + def _get_testspecs_for_modules() -> List[ModuleJsonTestSpec]: modules = [] diff --git a/cirq/qis/states.py b/cirq/qis/states.py index f38ec81d010..5d3803fe8f7 100644 --- a/cirq/qis/states.py +++ b/cirq/qis/states.py @@ -264,7 +264,7 @@ def quantum_state( dtype = DEFAULT_COMPLEX_DTYPE data = one_hot(index=state, shape=(dim,), dtype=dtype) else: - data = np.array(state, copy=False) + data = np.asarray(state) if qid_shape is None: qid_shape = infer_qid_shape(state) if data.ndim == 1 and data.dtype.kind != 'c': diff --git a/cirq/sim/simulator.py b/cirq/sim/simulator.py index 2608482b6a0..66104a43f5e 100644 --- a/cirq/sim/simulator.py +++ b/cirq/sim/simulator.py @@ -912,7 +912,7 @@ def __repr__(self) -> str: def __str__(self) -> str: def bitstring(vals): separator = ' ' if np.max(vals) >= 10 else '' - return separator.join(str(int(v)) for v in vals) + return separator.join(str(v.item()) for v in vals) results = sorted([(key, bitstring(val)) for key, val in self.measurements.items()]) if not results: diff --git a/cirq/sim/sparse_simulator_test.py b/cirq/sim/sparse_simulator_test.py index d07e95ecd86..b4445026e6d 100644 --- a/cirq/sim/sparse_simulator_test.py +++ b/cirq/sim/sparse_simulator_test.py @@ -115,7 +115,7 @@ def test_run_repetitions_terminal_measurement_stochastic(): q = cirq.LineQubit(0) c = cirq.Circuit(cirq.H(q), cirq.measure(q, key='q')) results = cirq.Simulator().run(c, repetitions=10000) - assert 1000 <= sum(v[0] for v in results.measurements['q']) < 9000 + assert 1000 <= np.count_nonzero(results.measurements['q']) < 9000 @pytest.mark.parametrize('dtype', [np.complex64, np.complex128]) @@ -255,7 +255,7 @@ def test_run_mixture(dtype: Type[np.complexfloating], split: bool): simulator = cirq.Simulator(dtype=dtype, split_untangled_states=split) circuit = cirq.Circuit(cirq.bit_flip(0.5)(q0), cirq.measure(q0)) result = simulator.run(circuit, repetitions=100) - assert 20 < sum(result.measurements['q(0)'])[0] < 80 + assert 20 < np.count_nonzero(result.measurements['q(0)']) < 80 @pytest.mark.parametrize('dtype', [np.complex64, np.complex128]) @@ -265,8 +265,8 @@ def test_run_mixture_with_gates(dtype: Type[np.complexfloating], split: bool): simulator = cirq.Simulator(dtype=dtype, split_untangled_states=split, seed=23) circuit = cirq.Circuit(cirq.H(q0), cirq.phase_flip(0.5)(q0), cirq.H(q0), cirq.measure(q0)) result = simulator.run(circuit, repetitions=100) - assert sum(result.measurements['q(0)'])[0] < 80 - assert sum(result.measurements['q(0)'])[0] > 20 + assert np.count_nonzero(result.measurements['q(0)']) < 80 + assert np.count_nonzero(result.measurements['q(0)']) > 20 @pytest.mark.parametrize('dtype', [np.complex64, np.complex128]) diff --git a/requirements.txt b/requirements.txt index b526c835455..fc39ec8c005 100644 --- a/requirements.txt +++ b/requirements.txt @@ -4,10 +4,10 @@ attrs>=21.3.0 duet>=0.2.8 matplotlib~=3.0 networkx>=2.4 -numpy~=1.22 +numpy>=1.24 pandas sortedcontainers~=2.0 -scipy~=1.0 +scipy~=1.8 sympy typing_extensions>=4.2 tqdm