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 #1502

Merged
merged 1 commit into from
Dec 26, 2024

Conversation

wshanks
Copy link
Collaborator

@wshanks wshanks commented Dec 12, 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).

@@ -69,14 +70,15 @@
from qiskit_experiments.database_service.utils import objs_to_zip, zip_to_objs

from .containers.figure_data import FigureData, FigureType
from .provider_interfaces import Job, Provider
Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I wasn't sure if it was convenient to use the Job and Provider names here (they basically mean what you expect them to mean) or confusing (they don't quite mean exactly what you might first assume they mean). Maybe JobLike and ProviderLike would be better or something like that?

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).
@dcmckayibm
Copy link
Collaborator

Pulled the branch and tested that it doesn't break anything to zero order... I don't use the experiment service extensively so haven't tested that. But otherwise looks fine, will approve.

@dcmckayibm dcmckayibm added this pull request to the merge queue Dec 26, 2024
Merged via the queue into qiskit-community:main with commit 2d48547 Dec 26, 2024
11 checks passed
@wshanks wshanks added the backport stable potential The issue or PR might be minimal and/or import enough to backport to stable label Dec 26, 2024
@wshanks wshanks deleted the providerservice branch December 26, 2024 19:06
mergify bot pushed a commit that referenced this pull request 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).

(cherry picked from commit 2d48547)
wshanks added a commit that referenced this pull request 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).<hr>This is an automatic backport of pull
request #1502 done by [Mergify](https://mergify.com).

Co-authored-by: Will Shanks <willshanks@us.ibm.com>
@wshanks wshanks mentioned this pull request Dec 27, 2024
2 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
backport stable potential The issue or PR might be minimal and/or import enough to backport to stable
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants