qiskit-documentation/docs/api/qiskit/dev/qiskit.primitives.BaseSampl...

54 lines
3.1 KiB
Plaintext
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

---
title: BaseSamplerV2 (dev version)
description: API reference for qiskit.primitives.BaseSamplerV2 in the dev version of qiskit
in_page_toc_min_heading_level: 1
python_api_type: class
python_api_name: qiskit.primitives.BaseSamplerV2
---
# BaseSamplerV2
<Class id="qiskit.primitives.BaseSamplerV2" isDedicatedPage={true} github="https://github.com/Qiskit/qiskit/tree/main/qiskit/primitives/base/base_sampler.py#L35-L74" signature="qiskit.primitives.BaseSamplerV2" modifiers="class">
Bases: [`ABC`](https://docs.python.org/3/library/abc.html#abc.ABC "(in Python v3.13)")
Base class for `SamplerV2` implementations.
A Sampler returns samples of quantum circuit outputs. Implementations of this [`BaseSamplerV2`](#qiskit.primitives.BaseSamplerV2 "qiskit.primitives.BaseSamplerV2") interface must define their own [`run()`](#qiskit.primitives.BaseSamplerV2.run "qiskit.primitives.BaseSamplerV2.run") method, which is designed to take the following inputs:
> * **pubs: list of pubs (Primitive Unified Blocs). A sampler pub is a list or tuple**
>
> of two to three elements that define the unit of work for the sampler. These are:
>
> > * A single [`QuantumCircuit`](qiskit.circuit.QuantumCircuit "qiskit.circuit.QuantumCircuit"), possibly parameterized.
> > * A collection parameter value sets to bind the circuit against if it is parametric.
> > * Optionally, the number of shots to sample.
>
> * **shots: the number of shots to sample. This specification is optional and will be overriden by**
>
> the pub-wise shots if provided.
All sampler implementations must implement default value for the `shots` in the [`run()`](#qiskit.primitives.BaseSamplerV2.run "qiskit.primitives.BaseSamplerV2.run") method. This default value will be used any time `shots=None` is specified, which can take place in the [`run()`](#qiskit.primitives.BaseSamplerV2.run "qiskit.primitives.BaseSamplerV2.run") kwargs or at the pub level.
## Methods
### run
<Function id="qiskit.primitives.BaseSamplerV2.run" github="https://github.com/Qiskit/qiskit/tree/main/qiskit/primitives/base/base_sampler.py#L59-L74" signature="run(pubs, *, shots=None)" modifiers="abstract">
Run and collect samples from each pub.
**Parameters**
* **pubs** (*Iterable\[SamplerPubLike]*) An iterable of pub-like objects. For example, a list of circuits or tuples `(circuit, parameter_values)`.
* **shots** ([*int*](https://docs.python.org/3/library/functions.html#int "(in Python v3.13)") *| None*) The total number of shots to sample for each sampler pub that does not specify its own shots. If `None`, the primitives default shots value will be used, which can vary by implementation.
**Returns**
The job object of Samplers result.
**Return type**
[BasePrimitiveJob](qiskit.primitives.BasePrimitiveJob "qiskit.primitives.BasePrimitiveJob")\[[PrimitiveResult](qiskit.primitives.PrimitiveResult "qiskit.primitives.PrimitiveResult")\[[SamplerPubResult](qiskit.primitives.SamplerPubResult "qiskit.primitives.SamplerPubResult")]]
</Function>
</Class>