qiskit.transpiler.CouplingMap¶
-
class
CouplingMap
(couplinglist=None, description=None)[Quellcode]¶ Directed graph specifying fixed coupling.
Nodes correspond to physical qubits (integers) and directed edges correspond to permitted CNOT gates
Create coupling graph. By default, the generated coupling has no nodes.
- Parameter
couplinglist (list or None) – An initial coupling graph, specified as an adjacency list containing couplings, e.g. [[0,1], [0,2], [1,2]].
description (str) – A string to describe the coupling map.
-
__init__
(couplinglist=None, description=None)[Quellcode]¶ Create coupling graph. By default, the generated coupling has no nodes.
- Parameter
couplinglist (list or None) – An initial coupling graph, specified as an adjacency list containing couplings, e.g. [[0,1], [0,2], [1,2]].
description (str) – A string to describe the coupling map.
Methods
__init__
([couplinglist, description])Create coupling graph.
add_edge
(src, dst)Add directed edge to coupling graph.
add_physical_qubit
(physical_qubit)Add a physical qubit to the coupling graph as a node.
distance
(physical_qubit1, physical_qubit2)Returns the undirected distance between physical_qubit1 and physical_qubit2.
draw
()Draws the coupling map.
from_full
(num_qubits[, bidirectional])Return a fully connected coupling map on n qubits.
from_grid
(num_rows, num_columns[, bidirectional])Return qubits connected on a grid of num_rows x num_columns.
from_line
(num_qubits[, bidirectional])Return a fully connected coupling map on n qubits.
from_ring
(num_qubits[, bidirectional])Return a fully connected coupling map on n qubits.
Gets the list of edges in the coupling graph.
Test if the graph is connected.
Return a set of qubits in the largest connected component.
Convert uni-directional edges into bi-directional.
neighbors
(physical_qubit)Return the nearest neighbors of a physical qubit.
reduce
(mapping)Returns a reduced coupling map that corresponds to the subgraph of qubits selected in the mapping.
shortest_undirected_path
(physical_qubit1, …)Returns the shortest undirected path between physical_qubit1 and physical_qubit2.
size
()Return the number of physical qubits in this graph.
subgraph
(nodelist)Return a CouplingMap object for a subgraph of self.
Attributes
Return the distance matrix for the coupling map.
Test if the graph is symmetric.
Returns a sorted list of physical_qubits
-
add_edge
(src, dst)[Quellcode]¶ Add directed edge to coupling graph.
src (int): source physical qubit dst (int): destination physical qubit
-
add_physical_qubit
(physical_qubit)[Quellcode]¶ Add a physical qubit to the coupling graph as a node.
physical_qubit (int): An integer representing a physical qubit.
- Verursacht
CouplingError – if trying to add duplicate qubit
-
distance
(physical_qubit1, physical_qubit2)[Quellcode]¶ Returns the undirected distance between physical_qubit1 and physical_qubit2.
- Parameter
physical_qubit1 (int) – A physical qubit
physical_qubit2 (int) – Another physical qubit
- Rückgabe
The undirected distance
- Rückgabetyp
int
- Verursacht
CouplingError – if the qubits do not exist in the CouplingMap
-
property
distance_matrix
¶ Return the distance matrix for the coupling map.
-
draw
()[Quellcode]¶ Draws the coupling map.
This function needs pydot, which in turn needs Graphviz to be installed. Additionally, pillow will need to be installed.
- Rückgabe
Drawn coupling map.
- Rückgabetyp
PIL.Image
- Verursacht
ImportError – when pydot or pillow are not installed.
-
classmethod
from_full
(num_qubits, bidirectional=True)[Quellcode]¶ Return a fully connected coupling map on n qubits.
-
classmethod
from_grid
(num_rows, num_columns, bidirectional=True)[Quellcode]¶ Return qubits connected on a grid of num_rows x num_columns.
-
classmethod
from_line
(num_qubits, bidirectional=True)[Quellcode]¶ Return a fully connected coupling map on n qubits.
-
classmethod
from_ring
(num_qubits, bidirectional=True)[Quellcode]¶ Return a fully connected coupling map on n qubits.
-
get_edges
()[Quellcode]¶ Gets the list of edges in the coupling graph.
- Rückgabe
Each edge is a pair of physical qubits.
- Rückgabetyp
Tuple(int,int)
-
is_connected
()[Quellcode]¶ Test if the graph is connected.
Return True if connected, False otherwise
-
property
is_symmetric
¶ Test if the graph is symmetric.
Return True if symmetric, False otherwise
-
largest_connected_component
()[Quellcode]¶ Return a set of qubits in the largest connected component.
-
make_symmetric
()[Quellcode]¶ Convert uni-directional edges into bi-directional.
-
neighbors
(physical_qubit)[Quellcode]¶ Return the nearest neighbors of a physical qubit.
Directionality matters, i.e. a neighbor must be reachable by going one hop in the direction of an edge.
-
property
physical_qubits
¶ Returns a sorted list of physical_qubits
-
reduce
(mapping)[Quellcode]¶ Returns a reduced coupling map that corresponds to the subgraph of qubits selected in the mapping.
- Parameter
mapping (list) – A mapping of reduced qubits to device qubits.
- Rückgabe
A reduced coupling_map for the selected qubits.
- Rückgabetyp
- Verursacht
CouplingError – Reduced coupling map must be connected.
-
shortest_undirected_path
(physical_qubit1, physical_qubit2)[Quellcode]¶ Returns the shortest undirected path between physical_qubit1 and physical_qubit2.
- Parameter
physical_qubit1 (int) – A physical qubit
physical_qubit2 (int) – Another physical qubit
- Rückgabe
The shortest undirected path
- Rückgabetyp
List
- Verursacht
CouplingError – When there is no path between physical_qubit1, physical_qubit2.
-
size
()[Quellcode]¶ Return the number of physical qubits in this graph.
-
subgraph
(nodelist)[Quellcode]¶ Return a CouplingMap object for a subgraph of self.
nodelist (list): list of integer node labels