qiskit.transpiler.Layout¶
-
class
Layout
(input_dict=None)[source]¶ Two-ways dict to represent a Layout.
construct a Layout from a bijective dictionary, mapping virtual qubits to physical qubits
-
__init__
(input_dict=None)[source]¶ construct a Layout from a bijective dictionary, mapping virtual qubits to physical qubits
Methods
__init__
([input_dict])construct a Layout from a bijective dictionary, mapping virtual qubits to physical qubits
add
(virtual_bit[, physical_bit])Adds a map element between bit and physical_bit.
add_register
(reg)Adds at the end physical_qubits that map each bit in reg.
combine_into_edge_map
(another_layout)Combines self and another_layout into an « edge map ».
copy
()Returns a copy of a Layout instance.
from_dict
(input_dict)Populates a Layout from a dictionary.
from_intlist
(int_list, *qregs)Converts a list of integers to a Layout mapping virtual qubits (index of the list) to physical qubits (the list values).
from_qubit_list
(qubit_list, *qregs)Populates a Layout from a list containing virtual qubits, Qubit or None.
generate_trivial_layout
(*regs)Creates a trivial (« one-to-one ») Layout with the registers and qubits in regs.
Returns the dictionary where the keys are physical (qu)bits and the values are virtual (qu)bits.
Returns the registers in the layout [QuantumRegister(2, “qr0”), QuantumRegister(3, “qr1”)] :returns: A set of Registers in the layout :rtype: Set
Returns the dictionary where the keys are virtual (qu)bits and the values are physical (qu)bits.
order_based_on_type
(value1, value2)decides which one is physical/virtual based on the type.
reorder_bits
(bits)Given an ordered list of bits, reorder them according to this layout.
swap
(left, right)Swaps the map between left and right.
-
add
(virtual_bit, physical_bit=None)[source]¶ Adds a map element between bit and physical_bit. If physical_bit is not defined, bit will be mapped to a new physical bit (extending the length of the layout by one.)
- Paramètres
virtual_bit (tuple) – A (qu)bit. For example, (QuantumRegister(3, “qr”), 2).
physical_bit (int) – A physical bit. For example, 3.
-
add_register
(reg)[source]¶ Adds at the end physical_qubits that map each bit in reg.
- Paramètres
reg (Register) – A (qu)bit Register. For example, QuantumRegister(3, “qr”).
-
combine_into_edge_map
(another_layout)[source]¶ Combines self and another_layout into an « edge map ».
For example:
self another_layout resulting edge map qr_1 -> 0 0 <- q_2 qr_1 -> q_2 qr_2 -> 2 2 <- q_1 qr_2 -> q_1 qr_3 -> 3 3 <- q_0 qr_3 -> q_0
The edge map is used to compose dags via, for example, compose.
- Paramètres
another_layout (Layout) – The other layout to combine.
- Renvoie
A « edge map ».
- Type renvoyé
dict
- Lève
LayoutError – another_layout can be bigger than self, but not smaller. Otherwise, raises.
-
from_dict
(input_dict)[source]¶ Populates a Layout from a dictionary.
The dictionary must be a bijective mapping between virtual qubits (tuple) and physical qubits (int).
- Paramètres
input_dict (dict) –
e.g.:
{(QuantumRegister(3, 'qr'), 0): 0, (QuantumRegister(3, 'qr'), 1): 1, (QuantumRegister(3, 'qr'), 2): 2} Can be written more concisely as follows: * virtual to physical:: {qr[0]: 0, qr[1]: 1, qr[2]: 2} * physical to virtual:: {0: qr[0], 1: qr[1], 2: qr[2]}
-
static
from_intlist
(int_list, *qregs)[source]¶ Converts a list of integers to a Layout mapping virtual qubits (index of the list) to physical qubits (the list values).
- Paramètres
int_list (list) – A list of integers.
*qregs (QuantumRegisters) – The quantum registers to apply the layout to.
- Renvoie
The corresponding Layout object.
- Type renvoyé
- Lève
LayoutError – Invalid input layout.
-
static
from_qubit_list
(qubit_list, *qregs)[source]¶ Populates a Layout from a list containing virtual qubits, Qubit or None.
- Paramètres
qubit_list (list) – e.g.: [qr[0], None, qr[2], qr[3]]
*qregs (QuantumRegisters) – The quantum registers to apply the layout to.
- Renvoie
the corresponding Layout object
- Type renvoyé
- Lève
LayoutError – If the elements are not Qubit or None
-
static
generate_trivial_layout
(*regs)[source]¶ Creates a trivial (« one-to-one ») Layout with the registers and qubits in regs.
- Paramètres
*regs (Registers, Qubits) – registers and qubits to include in the layout.
- Renvoie
A layout with all the regs in the given order.
- Type renvoyé
-
get_physical_bits
()[source]¶ Returns the dictionary where the keys are physical (qu)bits and the values are virtual (qu)bits.
-
get_registers
()[source]¶ Returns the registers in the layout [QuantumRegister(2, “qr0”), QuantumRegister(3, “qr1”)] :returns: A set of Registers in the layout :rtype: Set
-
get_virtual_bits
()[source]¶ Returns the dictionary where the keys are virtual (qu)bits and the values are physical (qu)bits.
-
static
order_based_on_type
(value1, value2)[source]¶ decides which one is physical/virtual based on the type. Returns (virtual, physical)
-