Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Improve handling of circuit execution providers (backport #1502) #1506

Merged
merged 1 commit into from
Dec 26, 2024

Conversation

mergify[bot]
Copy link

@mergify mergify bot commented Dec 26, 2024

This change improves several aspects about the way ExperimentData works with "providers." Here "provider" is generalized beyond qiskit.providers.Provider to any object which can provide a Job-like object with data about an experiment's circuit execution. This generalization is needed because qiskit-ibm-runtime, the main provider that Experiments integrates with, does not use the Provider class, so

  • Replace references to qiskit.providers.Provider and qiskit.providers.Job with custom interface definitions using typing.Protocol. The new interfaces document the API Experiments needs for working with these objects.
  • Improve type hints and type checking related to providers, jobs, and results, using the new protocol classes.
  • Infer IBMExperimentService authentication parameters from a qiskit_ibm_runtime.QiskitRuntimeService instance in the same way that the inference used to work with qiskit_ibm_provider.IBMProvider.
  • Delay inferring an IBMExperimentService from a backend or provider until ExperimentData tries to communicate with the experiment service. With the fix to infer the authentication parameters from QiskitRuntimeService, this delay is needed to avoid breaking existing code that creates an ExperimentData instance and then tries to set a custom experiment service for it, relying on the fact that inferrence did not work for QiskitRuntimeService, since setting the service on ExperimentData after it has already been set once raises an exception.
  • Remove dead code, both helper functions that are not called anywhere in the repository and code paths only relevant to qiskit-ibm-provider, like references to time_per_step(). Since qiskit-ibm-provider has long been deprecated and unsupported by IBM Quantum, removing support for it is not treated as a breaking change.
  • Handle some optional data types better (like result objects that might have a metadata attribute).
    This is an automatic backport of pull request Improve handling of circuit execution providers #1502 done by Mergify.

This change improves several aspects about the way `ExperimentData`
works with "providers." Here "provider" is generalized beyond
`qiskit.providers.Provider` to any object which can provide a `Job`-like
object with data about an experiment's circuit execution. This
generalization is needed because `qiskit-ibm-runtime`, the main provider
that Experiments integrates with, does not use the `Provider` class, so

* Replace references to `qiskit.providers.Provider` and
`qiskit.providers.Job` with custom interface definitions using
`typing.Protocol`. The new interfaces document the API Experiments needs
for working with these objects.
* Improve type hints and type checking related to providers, jobs, and
results, using the new protocol classes.
* Infer `IBMExperimentService` authentication parameters from a
`qiskit_ibm_runtime.QiskitRuntimeService` instance in the same way that
the inference used to work with `qiskit_ibm_provider.IBMProvider`.
* Delay inferring an `IBMExperimentService` from a backend or provider
until `ExperimentData` tries to communicate with the experiment service.
With the fix to infer the authentication parameters from
`QiskitRuntimeService`, this delay is needed to avoid breaking existing
code that creates an `ExperimentData` instance and then tries to set a
custom experiment service for it, relying on the fact that inferrence
did not work for `QiskitRuntimeService`, since setting the service on
`ExperimentData` after it has already been set once raises an exception.
* Remove dead code, both helper functions that are not called anywhere
in the repository and code paths only relevant to qiskit-ibm-provider,
like references to `time_per_step()`. Since `qiskit-ibm-provider` has
long been deprecated and unsupported by IBM Quantum, removing support
for it is not treated as a breaking change.
* Handle some optional data types better (like result objects that might
have a `metadata` attribute).

(cherry picked from commit 2d48547)
@wshanks wshanks merged commit a0429ed into stable/0.8 Dec 26, 2024
11 checks passed
@wshanks wshanks deleted the mergify/bp/stable/0.8/pr-1502 branch December 26, 2024 19:21
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant