DAGCircuit
class qiskit.dagcircuit.DAGCircuit
Bases: object
Quantum circuit as a directed acyclic graph.
There are 3 types of nodes in the graph: inputs, outputs, and operations. The nodes are connected by directed edges that correspond to qubits and bits.
Attributes
clbits
Returns the current sequence of registered Clbit instances as a list.
Do not modify this list yourself. It will invalidate the DAGCircuit data structures.
Returns
The current sequence of registered clbits.
Return type
list(Clbit)
cregs
Returns the dict containing the ClassicalRegisters in the circuit
duration
Returns the total duration of the circuit, set by a scheduling transpiler pass. Its unit is specified by unit
DEPRECATED since Qiskit 1.3.0 and will be removed in Qiskit 3.0.0
global_phase
Return the global phase of the circuit.
input_map
metadata
Circuit metadata
name
Circuit name. Generally, this corresponds to the name of the QuantumCircuit from which the DAG was generated.
node_counter
Returns the number of nodes in the dag.
num_captured_stretches
Number of captured stretches tracked by the circuit.
num_captured_vars
Number of captured classical variables tracked by the circuit.
num_declared_stretches
Number of declared local stretches tracked by the circuit.
num_declared_vars
Number of declared local classical variables tracked by the circuit.
num_input_vars
Number of input classical variables tracked by the circuit.
num_stretches
Total number of stretches tracked by the circuit.
num_vars
Total number of classical variables tracked by the circuit.
output_map
qregs
Returns the dict containing the QuantumRegisters in the circuit
qubits
Returns the current sequence of registered Qubit instances as a list.
Do not modify this list yourself. It will invalidate the DAGCircuit data structures.
Returns
The current sequence of registered qubits.
Return type
list(Qubit)
unit
Returns the unit that duration is specified in.
DEPRECATED since Qiskit 1.3.0 and will be removed in Qiskit 3.0.0
wires
Return a list of the wires in order.
Methods
add_captured_stretch
add_captured_stretch(stretch)
Add a captured stretch to the circuit.
Parameters
stretch – the stretch to add.
add_captured_var
add_captured_var(var)
Add a captured variable to the circuit.
Parameters
var – the variable to add.
add_clbits
add_clbits(clbits)
Add individual clbit wires.
add_creg
add_creg(creg)
Add all wires in a classical register.
add_declared_stretch
add_declared_stretch(stretch)
Add a declared stretch to the circuit.
Parameters
stretch – the stretch to add.
add_declared_var
add_declared_var(var)
Add a declared local variable to the circuit.
Parameters
var – the variable to add.
add_input_var
add_input_var(var)
Add an input variable to the circuit.
Parameters
var – the variable to add.
add_qreg
add_qreg(qreg)
Add all wires in a quantum register.
add_qubits
add_qubits(qubits)
Add individual qubit wires.
ancestors
ancestors(node)
Returns set of the ancestors of a node as DAGOpNodes and DAGInNodes.
The ancestors are the set of all nodes that can reach the target node. Whereas the DAGCircuit.predecessors() only contains the immediate predecessors, the ancestors recursively contain the predecessors of each predecessor.
apply_operation_back
apply_operation_back(op, qargs=None, cargs=None, *, check=True)
Apply an operation to the output of the circuit.
Parameters
- op (qiskit.circuit.Operation) – the operation associated with the DAG node
- qargs (tuple[Qubit]) – qubits that op will be applied to
- cargs (tuple[Clbit]) – cbits that op will be applied to
- check (bool) – If True(default), this function will enforce that theDAGCircuitdata-structure invariants are maintained (allqargsareQubit\ s, all are in the DAG, etc). IfFalse, the caller must uphold these invariants itself, but the cost of several checks will be skipped. This is most useful when building a new DAG from a source of known-good nodes.
Returns
the node for the op that was added to the dag
Return type
Raises
DAGCircuitError – if a leaf node is connected to multiple outputs
apply_operation_front
apply_operation_front(op, qargs=None, cargs=None, *, check=True)
Apply an operation to the input of the circuit.
Parameters
- op (qiskit.circuit.Operation) – the operation associated with the DAG node
- qargs (tuple[Qubit]) – qubits that op will be applied to
- cargs (tuple[Clbit]) – cbits that op will be applied to
- check (bool) – If True(default), this function will enforce that theDAGCircuitdata-structure invariants are maintained (allqargsareQubit\ s, all are in the DAG, etc). IfFalse, the caller must uphold these invariants itself, but the cost of several checks will be skipped. This is most useful when building a new DAG from a source of known-good nodes.
Returns
the node for the op that was added to the dag
Return type
Raises
DAGCircuitError – if initial nodes connected to multiple out edges
bfs_successors
bfs_successors(node)
Returns an iterator of tuples of (DAGNode, [DAGNodes]) where the DAGNode is the current node and [DAGNodes] is a list of the successors in BFS order.
classical_predecessors
classical_predecessors(node)
Returns iterator of the predecessors of a node that are connected by a classical edge as DAGOpNodes and DAGInNodes.
classical_successors
classical_successors(node)
Returns iterator of the successors of a node that are connected by a classical edge as DAGOpNodes and DAGOutNodes.
collect_1q_runs
collect_1q_runs()
Return a set of non-conditional runs of 1q “op” nodes.
collect_2q_runs
collect_2q_runs()
Return a set of non-conditional runs of 2q “op” nodes.
collect_runs
collect_runs(namelist)
Return a set of non-conditional runs of “op” nodes with the given names.
For example, “… h q[0]; cx q[0],q[1]; cx q[0],q[1]; h q[1]; ..” would produce the tuple of cx nodes as an element of the set returned from a call to collect_runs([“cx”]). If instead the cx nodes were “cx q[0],q[1]; cx q[1],q[0];”, the method would still return the pair in a tuple. The namelist can contain names that are not in the circuit’s basis.
Nodes must have only one successor to continue the run.
compose
compose(other, qubits=None, clbits=None, front=False, inplace=True, *, inline_captures=False)
Compose the other circuit onto the output of this circuit.
A subset of input wires of other are mapped to a subset of output wires of this circuit.
other can be narrower or of equal width to self.
Parameters
- other (DAGCircuit) – circuit to compose with self
- qubits (list[Qubit|int]) – qubits of self to compose onto.
- clbits (list[Clbit|int]) – clbits of self to compose onto.
- front (bool) – If True, front composition will be performed (not implemented yet)
- inplace (bool) – If True, modify the object. Otherwise return composed circuit.
- inline_captures (bool) – If True, variables marked as “captures” in theotherDAG will be inlined onto existing uses of those same variables inself. IfFalse, all variables inotherare required to be distinct fromself, and they will be added toself.
Returns
the composed dag (returns None if inplace==True).
Return type
Raises
DAGCircuitError – if other is wider or there are duplicate edge mappings.
control_flow_op_nodes
control_flow_op_nodes()
Get a list of “op” nodes in the dag that contain control flow instructions.
Returns
The list of dag nodes containing control flow ops.
Return type
copy_empty_like
copy_empty_like(*, vars_mode=Ellipsis)
Return a copy of self with the same structure but empty.
That structure includes:
- name and other metadata
- global phase
- duration
- all the qubits and clbits, including the registers.
Returns
An empty copy of self.
Return type
count_ops
count_ops(*, recurse=True)
Count the occurrences of operation names.
Parameters
recurse – if True (default), then recurse into control-flow operations. In all cases, this counts only the number of times the operation appears in any possible block; both branches of if-elses are counted, and for- and while-loop blocks are only counted once.
Returns
a mapping of operation names to the number of times it appears.
Return type
count_ops_longest_path
count_ops_longest_path()
Count the occurrences of operation names on the longest path.
Returns a dictionary of counts keyed on the operation name.
depth
depth(*, recurse=False)
Return the circuit depth. If there is control flow present, this count may only be an estimate, as the complete control-flow path cannot be statically known.
Parameters
recurse – if True, then recurse into control-flow operations. For loops with known-length iterators are counted as if the loop had been manually unrolled (i.e. with each iteration of the loop body written out explicitly). If-else blocks take the longer case of the two branches. While loops are counted as if the loop body runs once only. Defaults to False and raises DAGCircuitError if any control flow is present, to avoid silently returning a nonsensical number.
Returns
the circuit depth
Return type
Raises
- DAGCircuitError – if not a directed acyclic graph
- DAGCircuitError – if unknown control flow is present in a recursive call, or any control flow is present in a non-recursive call.
descendants
descendants(node)
Returns set of the descendants of a node as DAGOpNodes and DAGOutNodes.
The descendants are the set of all nodes that can be reached from the target node. In comparison, DAGCircuit.successors() is an iterator over the immediate successors, whereas this method contains all the successors’ succesors.
draw
draw(scale=0.7, filename=None, style='color')
Draws the dag circuit.
This function needs Graphviz to be installed. Graphviz is not a python package and can’t be pip installed (the graphviz package on PyPI is a Python interface library for Graphviz and does not actually install Graphviz). You can refer to the Graphviz documentation on how to install it.
Parameters
- scale (float) – scaling factor
- filename (str) – file path to save image to (format inferred from name)
- style (str) – ‘plain’: B&W graph; ‘color’ (default): color input/output/op nodes
Returns
if in Jupyter notebook and not saving to file, otherwise None.
Return type
Ipython.display.Image
edges
edges(nodes=None)
Iterator for edge values with source and destination node.
This works by returning the outgoing edges from the specified nodes. If no nodes are specified all edges from the graph are returned.
Parameters
nodes (DAGOpNode, DAGInNode, or DAGOutNode|list(DAGOpNode, DAGInNode, or DAGOutNode) – Either a list of nodes or a single input node. If none is specified, all edges are returned from the graph.
Yields
edge –
the edge as a tuple with the format
(source node, destination node, edge wire)
find_bit
find_bit(bit)
Finds locations in the circuit, by mapping the Qubit and Clbit to positional index BitLocations is defined as: BitLocations = namedtuple(“BitLocations”, (“index”, “registers”))
Parameters
bit (Bit) – The bit to locate.
Returns
A 2-tuple. The first element (index)
contains the index at which the Bit can be found (in either qubits, clbits, depending on its type). The second element (registers) is a list of (register, index) pairs with an entry for each Register in the circuit which contains the Bit (and the index in the Register at which it can be found).
Return type
namedtuple(int, List[Tuple(Register, int)])
Raises:
DAGCircuitError: If the supplied Bit was of an unknown type. DAGCircuitError: If the supplied Bit could not be found on the circuit.
front_layer
front_layer()
Return a list of op nodes in the first layer of this dag.
gate_nodes
gate_nodes()
Get the list of gate nodes in the dag.
Returns
the list of DAGOpNodes that represent gates.
Return type
has_identifier
has_identifier(var)
Is this identifier in the DAG?
Parameters
var – the identifier or name to check.
has_stretch
has_stretch(var)
Is this stretch in the DAG?
Parameters
var – the stretch or name to check.
has_var
has_var(var)
Is this realtime variable in the DAG?
Parameters
var – the variable or name to check.
idle_wires
idle_wires(ignore=None)
Return idle wires.
Parameters
ignore (list(str)) – List of node names to ignore. Default: []
Yields
Bit – Bit in idle wire.
Raises
DAGCircuitError – If the DAG is invalid
is_predecessor
is_predecessor(node, node_pred)
Checks if a second node is in the predecessors of node.
is_successor
is_successor(node, node_succ)
Checks if a second node is in the successors of node.
iter_captured_stretches
iter_captured_stretches()
Iterable over the captured stretches tracked by the circuit.
iter_captured_vars
iter_captured_vars()
Iterable over the captured classical variables tracked by the circuit.
iter_captures
iter_captures()
Iterable over all captured identifiers tracked by the circuit.
iter_declared_stretches
iter_declared_stretches()
Iterable over the declared stretches tracked by the circuit.
iter_declared_vars
iter_declared_vars()
Iterable over the declared classical variables tracked by the circuit.
iter_input_vars
iter_input_vars()
Iterable over the input classical variables tracked by the circuit.
iter_stretches
iter_stretches()
Iterable over all the stretches tracked by the circuit.
iter_vars
iter_vars()
Iterable over all the classical variables tracked by the circuit.
layers
layers(*, vars_mode=Ellipsis)
Yield a shallow view on a layer of this DAGCircuit for all d layers of this circuit.
A layer is a circuit whose gates act on disjoint qubits, i.e., a layer has depth 1. The total number of layers equals the circuit depth d. The layers are indexed from 0 to d-1 with the earliest layer at index 0. The layers are constructed using a greedy algorithm. Each returned layer is a dict containing {“graph”: circuit graph, “partition”: list of qubit lists}.
The returned layer contains new (but semantically equivalent) DAGOpNodes, DAGInNodes, and DAGOutNodes. These are not the same as nodes of the original dag, but are equivalent via DAGNode.semantic_eq(node1, node2).
TODO: Gates that use the same cbits will end up in different layers as this is currently implemented. This may not be the desired behavior.
longest_path
longest_path()
Returns the longest path in the dag as a list of DAGOpNodes, DAGInNodes, and DAGOutNodes.
make_physical
make_physical(num_qubits=None)
Put self into the canonical physical form, with the given number of qubits.
This acts in place, and does not need to traverse the DAG. It is intended for use when the DAG is known to already represent a physical circuit, and we just need to assert that it is canonical physical form.
This erases any information about virtual qubits in the DAGCircuit; if using this yourself, you may need to ensure you have created and stored a suitable Layout. Effectively, this applies the “trivial” layout mapping virtual qubit 0 to physical qubit 0, and so on.
Parameters
num_qubits – if given, the total number of physical qubits in the output; it must be at least as large as the number of qubits in the DAG. If not given, the number of qubits is unchanged.
multi_qubit_ops
multi_qubit_ops()
Get list of 3+ qubit operations. Ignore directives like snapshot and barrier.
multigraph_layers
multigraph_layers()
Yield layers of the multigraph.
named_nodes
named_nodes(*names)
Get the set of “op” nodes with the given name.
node
node(node_id)
Get the node in the dag.
Parameters
node_id (int) – Node identifier.
Returns
the node.
Return type
node
nodes
nodes()
Iterator for node values.
Yields
node – the node.
nodes_on_wire
nodes_on_wire(wire, only_ops=False)
Iterator for nodes that affect a given wire.
Parameters
- wire (Bit) – the wire to be looked at.
- only_ops (bool) – True if only the ops nodes are wanted; otherwise, all nodes are returned.
Yields
Iterator – the successive nodes on the given wire
Raises
DAGCircuitError – if the given wire doesn’t exist in the DAG
num_clbits
num_clbits()
Return the total number of classical bits used by the circuit.
num_ops
num_ops()
Get the number of op nodes in the DAG.
num_qubits
num_qubits()
Return the total number of qubits used by the circuit. num_qubits() replaces former use of width(). DAGCircuit.width() now returns qubits + clbits for consistency with Circuit.width() [qiskit-terra #2564].
num_tensor_factors
num_tensor_factors()
Compute how many components the circuit can decompose into.
op_nodes
op_nodes(op=None, include_directives=True)
Get the list of “op” nodes in the dag.
Parameters
- op (Type) – qiskit.circuit.Operationsubclass op nodes to return. If None, return all op nodes.
- include_directives (bool) – include barrier, snapshot etc.
Returns
the list of dag nodes containing the given op.
Return type
op_predecessors
op_predecessors(node)
Returns the iterator of “op” predecessors of a node in the dag.
op_successors
op_successors(node)
Returns iterator of “op” successors of a node in the dag.
predecessors
properties
properties()
Return a dictionary of circuit properties.
quantum_causal_cone
quantum_causal_cone(qubit)
Returns causal cone of a qubit.
A qubit’s causal cone is the set of qubits that can influence the output of that qubit through interactions, whether through multi-qubit gates or operations. Knowing the causal cone of a qubit can be useful when debugging faulty circuits, as it can help identify which wire(s) may be causing the problem.
This method does not consider any classical data dependency in the DAGCircuit, classical bit wires are ignored for the purposes of building the causal cone.
Parameters
qubit (Qubit) – The output qubit for which we want to find the causal cone.
Returns
The set of qubits whose interactions affect qubit.
Return type
Set[Qubit]
quantum_predecessors
quantum_predecessors(node)
Returns iterator of the predecessors of a node that are connected by a quantum edge as DAGOpNodes and DAGInNodes.
quantum_successors
quantum_successors(node)
Returns iterator of the successors of a node that are connected by a quantum edge as DAGOpNodes and DAGOutNodes.
remove_all_ops_named
remove_all_ops_named(opname)
Remove all operation nodes with the given name.
remove_ancestors_of
remove_ancestors_of(node)
Remove all of the ancestor operation nodes of node.
remove_clbits
remove_clbits(*clbits)
Remove classical bits from the circuit. All bits MUST be idle. Any registers with references to at least one of the specified bits will also be removed.
This method is rather slow, since it must iterate over the entire DAG to fix-up bit indices.
Parameters
clbits (List[Clbit]) – The bits to remove.
Raises
DAGCircuitError – a clbit is not a Clbit, is not in the circuit, or is not idle.
remove_cregs
remove_cregs(*cregs)
Remove classical registers from the circuit, leaving underlying bits in place.
Raises
- DAGCircuitError – a creg is not a ClassicalRegister, or is not in
- the circuit. –
remove_descendants_of
remove_descendants_of(node)
Remove all of the descendant operation nodes of node.
remove_nonancestors_of
remove_nonancestors_of(node)
Remove all of the non-ancestors operation nodes of node.
remove_nondescendants_of
remove_nondescendants_of(node)
Remove all of the non-descendants operation nodes of node.
remove_op_node
remove_op_node(node)
Remove an operation node n.
Add edges from predecessors to successors.
remove_qregs
remove_qregs(*qregs)
Remove quantum registers from the circuit, leaving underlying bits in place.
Raises
- DAGCircuitError – a qreg is not a QuantumRegister, or is not in
- the circuit. –
remove_qubits
remove_qubits(*qubits)
Remove quantum bits from the circuit. All bits MUST be idle. Any registers with references to at least one of the specified bits will also be removed.
This method is rather slow, since it must iterate over the entire DAG to fix-up bit indices.
Parameters
qubits (List[Qubit]) – The bits to remove.
Raises
DAGCircuitError – a qubit is not a Qubit, is not in the circuit, or is not idle.
replace_block_with_op
replace_block_with_op(node_block, op, wire_pos_map, cycle_check=True)
Replace a block of nodes with a single node.
This is used to consolidate a block of DAGOpNodes into a single operation. A typical example is a block of gates being consolidated into a single UnitaryGate representing the unitary matrix of the block.
Parameters
- node_block (List[DAGNode]) – A list of dag nodes that represents the node block to be replaced
- op (qiskit.circuit.Operation) – The operation to replace the block with
- wire_pos_map (Dict[Bit, int]) – The dictionary mapping the bits to their positions in the output qargsorcargs. This is necessary to reconstruct the arg order over multiple gates in the combined single op node. If aBitis not in the dictionary, it will not be added to the args; this can be useful when dealing with control-flow operations that have inherent bits in theirconditionortargetfields.
- cycle_check (bool) – When set to True this method will check that replacing the provided node_blockwith a single node would introduce a cycle (which would invalidate theDAGCircuit) and will raise aDAGCircuitErrorif a cycle would be introduced. This checking comes with a run time penalty. If you can guarantee that your inputnode_blockis a contiguous block and won’t introduce a cycle when it’s contracted to a single node, this can be set toFalseto improve the runtime performance of this method.
Raises
DAGCircuitError – if cycle_check is set to True and replacing the specified block introduces a cycle or if node_block is empty.
Returns
The op node that replaces the block.
Return type
reverse_ops
reverse_ops()
Reverse the operations in the self circuit.
Returns
the reversed dag.
Return type
separable_circuits
separable_circuits(remove_idle_qubits=False, *, vars_mode=Ellipsis)
Decompose the circuit into sets of qubits with no gates connecting them.
Parameters
remove_idle_qubits (bool) – Flag denoting whether to remove idle qubits from the separated circuits. If False, each output circuit will contain the same number of qubits as self.
Returns
The circuits resulting from separating self into sets
of disconnected qubits
Return type
List[DAGCircuit]
Each DAGCircuit instance returned by this method will contain the same number of clbits as self. The global phase information in self will not be maintained in the subcircuits returned by this method.
serial_layers
serial_layers(*, vars_mode=Ellipsis)
Yield a layer for all gates of this circuit.
A serial layer is a circuit with one gate. The layers have the same structure as in layers().
size
size(*, recurse=False)
Return the number of operations. If there is control flow present, this count may only be an estimate, as the complete control-flow path cannot be statically known.
Parameters
recurse – if True, then recurse into control-flow operations. For loops with known-length iterators are counted unrolled. If-else blocks sum both of the two branches. While loops are counted as if the loop body runs once only. Defaults to False and raises DAGCircuitError if any control flow is present, to avoid silently returning a mostly meaningless number.
Returns
the circuit size
Return type
Raises
DAGCircuitError – if an unknown ControlFlowOp is present in a call with recurse=True, or any control flow is present in a non-recursive call.
structurally_equal
structurally_equal(other)
Are these two DAGs structurally equal?
This function returns true iff the graph structures are precisely the same as each other, including the valid node indices, edge orders, and so on. This is a much stricter check than graph equivalence, and is mostly useful for testing if two DAGCircuit instances have been constructed and manipulated in the exact same ways. For example, this method can be used to test whether a sequence of manipulations of a DAG is deterministic.
This method does not consider tracking metadata such as metadata or name, but does consider many low-level implementation details of the internal representation, many of which do not change the semantics of the circuit.
This method should, in general, be much faster than graph-equivalence checks, but will return False in many more situations. This method should never return True when a graph-equivalence check would return False.
This currently does not handle control flow, because of technical limitations in the internal representation of control flow, and will return false if any control-flow operation is present, even if they are individually equal.
The == operator
DAGCircuit implements __eq__() between itself and other DAGCircuit instances (this same method also powers QuantumCircuit’s equality check). This implements a semantic data-flow equality check, which is less sensitive to the order operations were defined. This is typically what a user cares about with respect to equality.
substitute_node
substitute_node(node, op, inplace=False, propagate_condition=None)
Replace a DAGOpNode with a single operation. qargs, cargs and conditions for the new operation will be inferred from the node to be replaced. The new operation will be checked to match the shape of the replaced operation.
Parameters
- node (DAGOpNode) – Node to be replaced
- op (qiskit.circuit.Operation) – The qiskit.circuit.Operationinstance to be added to the DAG
- inplace (bool) – Optional, default False. If True, existing DAG node will be modified to include op. Otherwise, a new DAG node will be used.
- propagate_condition (bool) – DEPRECATED a legacy option that used to control the behavior of handling control flow. It has no effect anymore, left it for backwards compatibility. Will be removed in Qiskit 3.0.
Returns
the new node containing the added operation.
Return type
Raises
- DAGCircuitError – If replacement operation was incompatible with
- location** of **target node. –
substitute_node_with_dag
substitute_node_with_dag(node, input_dag, wires=None, propagate_condition=None)
Replace one node with dag.
Parameters
- node (DAGOpNode) – node to substitute
- input_dag (DAGCircuit) – circuit that will substitute the node
- wires (list[Bit] | Dict[Bit, Bit]) – gives an order for (qu)bits in the input circuit. If a list, then the bits refer to those in the input_dag, and the order gets matched to the node wires by qargs first, then cargs, then conditions. If a dictionary, then a mapping of bits in theinput_dagto those that thenodeacts on.
- propagate_condition (bool) – DEPRECATED a legacy option that used to control the behavior of handling control flow. It has no effect anymore, left it for backwards compatibility. Will be removed in Qiskit 3.0.
Returns
maps node IDs from input_dag to their new node incarnations in self.
Return type
Raises
DAGCircuitError – if met with unexpected predecessor/successors
successors
successors(node)
Returns iterator of the successors of a node as DAGOpNodes and DAGOutNodes.
swap_nodes
swap_nodes(node1, node2)
Swap connected nodes e.g. due to commutation.
Parameters
- node1 (OpNode) – predecessor node
- node2 (OpNode) – successor node
Raises
DAGCircuitError – if either node is not an OpNode or nodes are not connected
topological_nodes
topological_nodes(key=None)
Yield nodes in topological order.
Parameters
key (Callable) – A callable which will take a DAGNode object and return a string sort key. If not specified the bit qargs and cargs of a node will be used for sorting.
Returns
node in topological order
Return type
generator(DAGOpNode, DAGInNode, or DAGOutNode)
topological_op_nodes
topological_op_nodes(key=None)
Yield op nodes in topological order.
Allowed to pass in specific key to break ties in top order
Parameters
key (Callable) – A callable which will take a DAGNode object and return a string sort key. If not specified the qargs and cargs of a node will be used for sorting.
Returns
op node in topological order
Return type
generator(DAGOpNode)
two_qubit_ops
two_qubit_ops()
Get list of 2 qubit operations. Ignore directives like snapshot and barrier.
width
width()
Return the total number of qubits + clbits used by the circuit. This function formerly returned the number of qubits by the calculation return len(self._wires) - self.num_clbits() but was changed by issue #2564 to return number of qubits + clbits with the new function DAGCircuit.num_qubits replacing the former semantic of DAGCircuit.width().