Source code for qrisp.circuit.pass_management.passes.remove_barriers
"""********************************************************************************
* Copyright (c) 2026 the Qrisp authors
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the Eclipse
* Public License, v. 2.0 are satisfied: GNU General Public License, version 2
* with the GNU Classpath Exception which is
* available at https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
********************************************************************************
"""
from __future__ import annotations
from qrisp.circuit.pass_management.circuit_pass import CircuitPass
from qrisp.circuit.quantum_circuit import QuantumCircuit
[docs]
@CircuitPass
def remove_barriers(qc: QuantumCircuit) -> QuantumCircuit:
"""Return a copy of *qc* with all barrier instructions removed.
Parameters
----------
qc : QuantumCircuit
The input circuit, potentially containing barrier instructions.
Returns
-------
QuantumCircuit
A new circuit identical to *qc* but without any barriers.
Examples
--------
Remove a barrier from a circuit::
>>> from qrisp import QuantumCircuit, PassManager
>>> from qrisp import remove_barriers
>>> qc = QuantumCircuit(2)
>>> qc.h(0)
>>> qc.barrier()
>>> qc.cx(0, 1)
>>> print(qc)
┌───┐ ░
qb_124: ┤ H ├─░───■──
└───┘ ░ ┌─┴─┐
qb_125: ──────░─┤ X ├
░ └───┘
>>> pm = PassManager()
>>> pm += remove_barriers
>>> clean_qc = pm.run(qc)
>>> print(clean_qc)
┌───┐
qb_124: ┤ H ├──■──
└───┘┌─┴─┐
qb_125: ─────┤ X ├
└───┘
"""
qc_new = qc.clearcopy()
for instr in qc.data:
if instr.op.name == "barrier":
continue
qc_new.append(instr)
return qc_new