QuantumProgram¶
- class QuantumProgram(shots, items=None, noise_maps=None)[source]¶
Bases:
objectA quantum runtime executable.
A quantum program consists of a list of ordered elements, each of which contains a single circuit and an array of associated parameter values. Executing a quantum program will sample the outcome of each circuit for the specified number of
shotsfor each set of circuit arguments provided.- Parameters:
shots (int) – The number of shots for each circuit execution.
items (Iterable[QuantumProgramItem] | None) – Items that comprise the program.
noise_maps (dict[str, PauliLindbladMap] | None) – Noise maps to use with samplex items.
Methods
- append_circuit_item(circuit, *, circuit_arguments=None, chunk_size=None)[source]¶
Append a new
CircuitItemto this program.- Parameters:
circuit (QuantumCircuit) – The circuit of this item.
circuit_arguments (ndarray | None) – A real-valued array of parameter values for the circuit. The last axis is intrinsic with size equal to the number of circuit parameters. Leading axes are extrinsic and define the sweep grid.
chunk_size (int | None) – The maximum number of bound circuits in each shot loop execution, or
Noneto use a server-side heuristic to optimize speed. When not executing in a session, the server-side heuristic is always used and this value is ignored.
- Return type:
None
- append_samplex_item(circuit, *, samplex, samplex_arguments=None, shape=None, chunk_size=None)[source]¶
Append a new
SamplexItemto this program.- Parameters:
circuit (QuantumCircuit) – The circuit of this item.
samplex (Samplex) – A samplex to draw random parameters for the circuit.
samplex_arguments (dict[str, Any] | None) – A map from argument names to argument values for the samplex. Each argument array has intrinsic axes determined by its type (e.g.,
parameter_valueshas intrinsic shape(n,)fornparameters). The extrinsic shapes of all arguments are broadcasted together.shape (tuple[int, ...] | None) – A shape that the item’s extrinsic shape must be broadcastable to. Axes where
shapeexceeds the shape implicit insamplex_argumentsenumerate independent randomizations.chunk_size (int | None) – The maximum number of bound circuits in each shot loop execution, or
Noneto use a server-side heuristic to optimize speed. When not executing in a session, the server-side heuristic is always used and this value is ignored.
- Return type:
None
- validate(backend)[source]¶
Validate this quantum program against the given backend.
- Parameters:
backend (IBMBackend)
- Return type:
None