From 16f0bc53653567269d2fda73b98b6ee0f51cd3c8 Mon Sep 17 00:00:00 2001 From: Jake Lishman Date: Tue, 23 Jan 2024 11:47:10 +0000 Subject: [PATCH 1/2] Fix lurking `qiskit.tools` usage A few places in docstrings where we'd left in references to `qiskit.tools`. At least one of these was executed as part of the documentation build, so was causing failures that weren't being caught because `tox` is currently building an invalid environment for the docs for Qiskit 1.0. --- qiskit/passmanager/__init__.py | 2 +- qiskit/utils/parallel.py | 2 +- qiskit/visualization/gate_map.py | 4 ---- test/benchmarks/random_circuit_hex.py | 30 +++++---------------------- 4 files changed, 7 insertions(+), 31 deletions(-) diff --git a/qiskit/passmanager/__init__.py b/qiskit/passmanager/__init__.py index a84f37abbf03..ce90335cc118 100644 --- a/qiskit/passmanager/__init__.py +++ b/qiskit/passmanager/__init__.py @@ -75,7 +75,7 @@ A single flow controller always takes a single IR object, and returns a single IR object. Parallelism for multiple input objects is supported by the :class:`BasePassManager` by broadcasting the flow controller via -the :func:`qiskit.tools.parallel_map` function. +the :func:`.parallel_map` function. Examples diff --git a/qiskit/utils/parallel.py b/qiskit/utils/parallel.py index b46c3bc7c9b8..4c866a1fe730 100644 --- a/qiskit/utils/parallel.py +++ b/qiskit/utils/parallel.py @@ -139,7 +139,7 @@ def parallel_map( # pylint: disable=dangerous-default-value .. code-block:: python import time - from qiskit.tools.parallel import parallel_map + from qiskit.utils import parallel_map def func(_): time.sleep(0.1) return 0 diff --git a/qiskit/visualization/gate_map.py b/qiskit/visualization/gate_map.py index 6acd2f8b0ab7..7f20eeb038bd 100644 --- a/qiskit/visualization/gate_map.py +++ b/qiskit/visualization/gate_map.py @@ -1141,13 +1141,9 @@ def plot_circuit_layout(circuit, backend, view="virtual", qubit_coordinates=None .. plot:: :include-source: - import numpy as np from qiskit import QuantumCircuit, transpile from qiskit.providers.fake_provider import FakeVigoV2 from qiskit.visualization import plot_circuit_layout - from qiskit.tools.monitor import job_monitor - from qiskit.providers.fake_provider import FakeVigoV2 - import matplotlib.pyplot as plt ghz = QuantumCircuit(3, 3) ghz.h(0) diff --git a/test/benchmarks/random_circuit_hex.py b/test/benchmarks/random_circuit_hex.py index bb6c0882ae06..500503f1ecde 100644 --- a/test/benchmarks/random_circuit_hex.py +++ b/test/benchmarks/random_circuit_hex.py @@ -15,25 +15,9 @@ import copy +from qiskit import QuantumCircuit, ClassicalRegister, QuantumRegister, transpile +from qiskit.quantum_info.random import random_unitary from qiskit.quantum_info.synthesis import OneQubitEulerDecomposer -from qiskit import QuantumCircuit, ClassicalRegister, QuantumRegister - -try: - from qiskit.compiler import transpile - - TRANSPILER_SEED_KEYWORD = "seed_transpiler" -except ImportError: - from qiskit.transpiler import transpile - - TRANSPILER_SEED_KEYWORD = "seed_mapper" -try: - from qiskit.quantum_info.random import random_unitary - - HAS_RANDOM_UNITARY = True -except ImportError: - from qiskit.tools.qi.qi import random_unitary_matrix - - HAS_RANDOM_UNITARY = False # Make a random circuit on a ring @@ -55,11 +39,7 @@ def make_circuit_ring(nq, depth, seed): k = i * 2 + offset + j % 2 # j%2 makes alternating rounds overlap qc.cx(q[k % nq], q[(k + 1) % nq]) for i in range(nq): # round of single-qubit unitaries - if HAS_RANDOM_UNITARY: - u = random_unitary(2, seed).data - else: - u = random_unitary_matrix(2) # pylint: disable=used-before-assignment # noqa - + u = random_unitary(2, seed).data angles = decomposer.angles(u) qc.u3(angles[0], angles[1], angles[2], q[i]) @@ -106,7 +86,7 @@ def time_ibmq_backend_transpile(self, _): self.circuit, basis_gates=["u1", "u2", "u3", "cx", "id"], coupling_map=coupling_map, - **{TRANSPILER_SEED_KEYWORD: self.seed}, + seed_transpiler=self.seed, ) def track_depth_ibmq_backend_transpile(self, _): @@ -135,5 +115,5 @@ def track_depth_ibmq_backend_transpile(self, _): self.circuit, basis_gates=["u1", "u2", "u3", "cx", "id"], coupling_map=coupling_map, - **{TRANSPILER_SEED_KEYWORD: self.seed}, + seed_transpiler=self.seed, ).depth() From b721e57dfe85df49727a43a71cedcc90253b6214 Mon Sep 17 00:00:00 2001 From: Jake Lishman Date: Tue, 23 Jan 2024 12:15:44 +0000 Subject: [PATCH 2/2] Remove other old import paths Co-authored-by: Sebastian Brandhofer <148463728+sbrandhsn@users.noreply.github.com> --- test/benchmarks/qft.py | 7 +------ test/benchmarks/randomized_benchmarking.py | 14 +++----------- 2 files changed, 4 insertions(+), 17 deletions(-) diff --git a/test/benchmarks/qft.py b/test/benchmarks/qft.py index 4533ba413cbc..d8ed52f8f010 100644 --- a/test/benchmarks/qft.py +++ b/test/benchmarks/qft.py @@ -16,16 +16,11 @@ import itertools import math -from qiskit import QuantumRegister, QuantumCircuit +from qiskit import QuantumRegister, QuantumCircuit, transpile from qiskit.converters import circuit_to_dag from qiskit.transpiler import CouplingMap from qiskit.transpiler.passes import SabreSwap -try: - from qiskit.compiler import transpile -except ImportError: - from qiskit.transpiler import transpile - def build_model_circuit(qreg, circuit=None): """Create quantum fourier transform circuit on quantum register qreg.""" diff --git a/test/benchmarks/randomized_benchmarking.py b/test/benchmarks/randomized_benchmarking.py index 4772a7ccb4cc..e62a66cabea6 100644 --- a/test/benchmarks/randomized_benchmarking.py +++ b/test/benchmarks/randomized_benchmarking.py @@ -17,15 +17,7 @@ import os import numpy as np from qiskit_experiments.library import StandardRB - -try: - from qiskit.compiler import transpile - - TRANSPILER_SEED_KEYWORD = "seed_transpiler" -except ImportError: - from qiskit.transpiler import transpile - - TRANSPILER_SEED_KEYWORD = "seed_mapper" +from qiskit import transpile def build_rb_circuit(qubits, length_vector, num_samples=1, seed=None): @@ -102,7 +94,7 @@ def time_ibmq_backend_transpile(self, __): basis_gates=["u1", "u2", "u3", "cx", "id"], coupling_map=coupling_map, optimization_level=0, - **{TRANSPILER_SEED_KEYWORD: self.seed}, + seed_transpiler=self.seed, ) def time_ibmq_backend_transpile_single_thread(self, __): @@ -135,5 +127,5 @@ def time_ibmq_backend_transpile_single_thread(self, __): basis_gates=["u1", "u2", "u3", "cx", "id"], coupling_map=coupling_map, optimization_level=0, - **{TRANSPILER_SEED_KEYWORD: self.seed}, + seed_transpiler=self.seed, )