Skip to main contentIBM Quantum Documentation


class qiskit.transpiler.StagedPassManager(stages=None, **kwargs)

GitHub(opens in a new tab)

Bases: PassManager

A pass manager pipeline built from individual stages.

This class enables building a compilation pipeline out of fixed stages. Each StagedPassManager defines a list of stages which are executed in a fixed order, and each stage is defined as a standalone PassManager instance. There are also pre_ and post_ stages for each defined stage. This enables easily composing and replacing different stages and also adding hook points to enable programmatic modifications to a pipeline. When using a staged pass manager you are not able to modify the individual passes and are only able to modify stages.

By default, instances of StagedPassManager define a typical full compilation pipeline from an abstract virtual circuit to one that is optimized and capable of running on the specified backend. The default pre-defined stages are:

  1. init - Initial passes to run before embedding the circuit to the backend.
  2. layout - Maps the virtual qubits in the circuit to the physical qubits on the backend.
  3. routing - Inserts gates as needed to move the qubit states around until the circuit can be run with the chosen layout on the backend’s coupling map.
  4. translation - Translates the gates in the circuit to the target backend’s basis gate set.
  5. optimization - Optimizes the circuit to reduce the cost of executing it. These passes will typically run in a loop until a convergence criteria is met. For example, the convergence criteria might be that the circuit depth does not decrease in successive iterations.
  6. scheduling - Hardware-aware passes that schedule the operations in the circuit.

For backwards compatibility the relative positioning of these default stages will remain stable moving forward. However, new stages may be added to the default stage list in between current stages. For example, in a future release a new phase, something like logical_optimization, could be added immediately after the existing init stage in the default stage list. This would preserve compatibility for pre-existing StagedPassManager users as the relative positions of the stage are preserved so the behavior will not change between releases.

These stages will be executed in order and any stage set to None will be skipped. If a stage is provided multiple times (i.e. at diferent relative positions), the associated passes, including pre and post, will run once per declaration. If a PassManager input is being used for more than 1 stage here (for example in the case of a Pass that covers both Layout and Routing) you will want to set that to the earliest stage in sequence that it covers.

Initialize a new StagedPassManager object


  • stages (Iterable[str(opens in a new tab)]) – An optional list of stages to use for this instance. If this is not specified the default stages list ['init', 'layout', 'routing', 'translation', 'optimization', 'scheduling'] is used. After instantiation, the final list will be immutable and stored as tuple. If a stage is provided multiple times (i.e. at diferent relative positions), the associated passes, including pre and post, will run once per declaration.
  • kwargs – The initial PassManager values for any stages defined in stages. If a argument is not defined the stages will default to None indicating an empty/undefined stage.




Expanded Pass manager stages including pre_ and post_ phases.


Default value: re.compile('\\s|\\+|\\-|\\*|\\/|\\\\|\\%|\\<|\\>|\\@|\\!|\\~|\\^|\\&|\\:|\\[|\\]|\\{|\\}|\\(|\\)')


Pass manager stages




GitHub(opens in a new tab)

Append a Pass Set to the schedule of passes.


passes (Task | list(opens in a new tab)[Task]) – A set of transpiler passes to be added to schedule.


TranspilerError – if a pass in passes is not a proper pass.


draw(filename=None, style=None, raw=False)

GitHub(opens in a new tab)

Draw the staged pass manager.



GitHub(opens in a new tab)

Removes a particular pass in the scheduler.


index (int(opens in a new tab)) – Pass index to remove, based on the position in passes().


PassManagerError – If the index is not found.


replace(index, passes)

GitHub(opens in a new tab)

Replace a particular pass in the scheduler.



run(circuits, output_name=None, callback=None, num_processes=None)

GitHub(opens in a new tab)

Run all the passes on the specified circuits.


  • circuits (_CircuitsT) – Circuit(s) to transform via all the registered passes.

  • output_name (str(opens in a new tab) | None) – The output circuit name. If None, it will be set to the same as the input circuit name.

  • callback (Callable | None) –

    A callback function that will be called after each pass execution. The function will be called with 5 keyword arguments:

    pass_ (Pass): the pass being run
    dag (DAGCircuit): the dag output of the pass
    time (float): the time to execute the pass
    property_set (PropertySet): the property set
    count (int): the index for the pass execution

    Beware that the keyword arguments here are different to those used by the generic BasePassManager. This pass manager will translate those arguments into the form described above.

    The exact arguments pass expose the internals of the pass manager and are subject to change as the pass manager internals change. If you intend to reuse a callback function over multiple releases be sure to check that the arguments being passed are the same.

    To use the callback feature you define a function that will take in kwargs dict and access the variables. For example:

    def callback_func(**kwargs):
        pass_ = kwargs['pass_']
        dag = kwargs['dag']
        time = kwargs['time']
        property_set = kwargs['property_set']
        count = kwargs['count']
  • num_processes (int(opens in a new tab)) – The maximum number of parallel processes to launch if parallel execution is enabled. This argument overrides num_processes in the user configuration file, and the QISKIT_NUM_PROCS environment variable. If set to None the system default or local user configuration will be used.


The transformed circuit(s).

Return type




GitHub(opens in a new tab)

Linearize this manager into a single FlowControllerLinear, so that it can be nested inside another pass manager.


A linearized pass manager.

Return type


Was this page helpful?
Report a bug or request content on GitHub.