-
Notifications
You must be signed in to change notification settings - Fork 2.3k
/
enlarge_with_ancilla.py
49 lines (36 loc) · 1.68 KB
/
enlarge_with_ancilla.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
# This code is part of Qiskit.
#
# (C) Copyright IBM 2017, 2019.
#
# This code is licensed under the Apache License, Version 2.0. You may
# obtain a copy of this license in the LICENSE.txt file in the root directory
# of this source tree or at http://www.apache.org/licenses/LICENSE-2.0.
#
# Any modifications or derivative works of this code must retain this
# copyright notice, and modified files need to carry a notice indicating
# that they have been altered from the originals.
"""Extend the dag with virtual qubits that are in layout but not in the circuit yet."""
from qiskit.transpiler.basepasses import TransformationPass
from qiskit.transpiler.exceptions import TranspilerError
class EnlargeWithAncilla(TransformationPass):
"""Extend the dag with virtual qubits that are in layout but not in the circuit yet.
Extend the DAG circuit with new virtual qubits (ancilla) that are specified
in the layout, but not present in the circuit. Which qubits to add are
previously allocated in the ``layout`` property, by a previous pass.
"""
def run(self, dag):
"""Run the EnlargeWithAncilla pass on `dag`.
Args:
dag (DAGCircuit): DAG to extend.
Returns:
DAGCircuit: An extended DAG.
Raises:
TranspilerError: If there is no layout in the property set or not set at init time.
"""
layout = self.property_set["layout"]
if layout is None:
raise TranspilerError('EnlargeWithAncilla requires property_set["layout"]')
new_qregs = {reg for reg in layout.get_registers() if reg not in dag.qregs.values()}
for qreg in new_qregs:
dag.add_qreg(qreg)
return dag