pytket.mapping¶
- class pytket.mapping.AASLabellingMethod¶
Defines a Labeling Method for aas for labelling all unplaced qubits in a circuit
- __init__(self: pytket.mapping.AASLabellingMethod) None ¶
AASLabellingMethod constructor.
- class pytket.mapping.AASRouteRoutingMethod¶
Defines a RoutingMethod object for mapping circuits that uses the architecture aware synthesis method implemented in tket.
- __init__(self: pytket.mapping.AASRouteRoutingMethod, aaslookahead: int) None ¶
AASRouteRoutingMethod constructor.
- Parameters:
aaslookahead – recursive interation depth of the architecture aware synthesis.method.
- class pytket.mapping.BoxDecompositionRoutingMethod¶
Defines a RoutingMethod object for decomposing boxes.
- __init__(self: pytket.mapping.BoxDecompositionRoutingMethod) None ¶
BoxDecompositionRoutingMethod constructor.
- class pytket.mapping.LexiLabellingMethod¶
Defines a RoutingMethod for labelling Qubits that uses the Lexicographical Comparison approach outlined in arXiv:1902.08091.
- __init__(self: pytket.mapping.LexiLabellingMethod) None ¶
LexiLabellingMethod constructor.
- class pytket.mapping.LexiRouteRoutingMethod¶
Defines a RoutingMethod object for mapping circuits that uses the Lexicographical Comparison approach outlined in arXiv:1902.08091.Only supports 1-qubit, 2-qubit and barrier gates.
- __init__(self: pytket.mapping.LexiRouteRoutingMethod, lookahead: int = 10) None ¶
LexiRoute constructor.
- Parameters:
lookahead – Maximum depth of lookahead employed when picking SWAP for purpose of logical to physical mapping.
- class pytket.mapping.MappingManager¶
Defined by a pytket Architecture object, maps Circuit logical qubits to physically permitted Architecture qubits. Mapping is completed by sequential routing (full or partial) of subcircuits. A custom method for routing (full or partial) of subcircuits can be defined in Python.
- __init__(self: pytket.mapping.MappingManager, architecture: pytket.architecture.Architecture) None ¶
MappingManager constructor.
- Parameters:
architecture – pytket Architecture object.
- route_circuit(self: pytket.mapping.MappingManager, circuit: pytket.circuit.Circuit, routing_methods: Sequence[pytket.mapping.RoutingMethod]) bool ¶
Maps from given logical circuit to physical circuit. Modification defined by route_subcircuit, but typically this proceeds by insertion of SWAP gates that permute logical qubits on physical qubits.
- Parameters:
circuit – pytket circuit to be mapped
routing_methods – Ranked methods to use for routing subcircuits. In given order, each method is sequentially checked for viability, with the first viable method being used.
- class pytket.mapping.MultiGateReorderRoutingMethod¶
Defines a RoutingMethod object for commuting physically permitted multi-qubit gates to the front of the subcircuit.
- __init__(self: pytket.mapping.MultiGateReorderRoutingMethod, max_depth: int = 10, max_size: int = 10) None ¶
MultiGateReorderRoutingMethod constructor.
- Parameters:
max_depth – Maximum number of layers of gates checked for simultaneous commutation.
max_size – Maximum number of gates checked for simultaneous commutation.
- class pytket.mapping.RoutingMethod¶
Parent class for RoutingMethod, for inheritance purposes only, not for usage.
- __init__(self: pytket.mapping.RoutingMethod) None ¶
- class pytket.mapping.RoutingMethodCircuit¶
The RoutingMethod class captures a method for partially mapping logical subcircuits to physical operations as permitted by some architecture. Ranked RoutingMethod objects are used by the MappingManager to route whole circuits.
- __init__(self: pytket.mapping.RoutingMethodCircuit, route_subcircuit: Callable[[pytket.circuit.Circuit, pytket.architecture.Architecture], tuple[bool, pytket.circuit.Circuit, dict[pytket.unit_id.UnitID, pytket.unit_id.UnitID], dict[pytket.unit_id.UnitID, pytket.unit_id.UnitID]]], max_size: int, max_depth: int) None ¶
Constructor for a routing method defined by partially routing subcircuits.
- Parameters:
route_subcircuit – A function declaration that given a Circuit and Architecture object, returns a tuple containing a bool informing MappingManager whether to substitute the returned circuit into the circuit being routed, a new modified circuit, the initial logical to physical qubit mapping of the modified circuit and the permutation of logical to physical qubit mapping given operations in the modified circuit
max_size – The maximum number of gates permitted in a subcircuit
max_depth – The maximum permitted depth of a subcircuit.