Skip to content

Commit

Permalink
fit lint errors, upgrade pylint, fix tomo bug
Browse files Browse the repository at this point in the history
  • Loading branch information
dcmckayibm committed Sep 27, 2024
1 parent 2a5d1cb commit d796ea3
Show file tree
Hide file tree
Showing 11 changed files with 50 additions and 41 deletions.
4 changes: 2 additions & 2 deletions .pylintrc
Original file line number Diff line number Diff line change
Expand Up @@ -73,8 +73,8 @@ disable=fixme, # disabled as TODOs would show up as warnings
cyclic-import, # This checker raises on all module pairs that import each other,
# even submodules that only import already loaded objects from a
# parent module, a common pattern in qiskit-experiments.
assigning-non-slot # https://github.com/Qiskit/qiskit/pull/7347#issuecomment-985007311

assigning-non-slot, # https://github.com/Qiskit/qiskit/pull/7347#issuecomment-985007311
too-many-positional-arguments



Expand Down
1 change: 1 addition & 0 deletions qiskit_experiments/framework/backend_data.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
Since `BackendV1` and `BackendV2` do not share the same interface, this
class unifies data access for various data fields.
"""
# pylint: disable=no-name-in-module
from qiskit.providers.models import PulseBackendConfiguration
from qiskit.providers import BackendV1, BackendV2

Expand Down
38 changes: 20 additions & 18 deletions qiskit_experiments/framework/base_experiment.py
Original file line number Diff line number Diff line change
Expand Up @@ -23,15 +23,14 @@
from qiskit.exceptions import QiskitError
from qiskit.qobj.utils import MeasLevel
from qiskit.providers.options import Options
from qiskit_ibm_runtime import SamplerV2 as Sampler
from qiskit_experiments.framework import BackendData
from qiskit_experiments.framework.store_init_args import StoreInitArgs
from qiskit_experiments.framework.base_analysis import BaseAnalysis
from qiskit_experiments.framework.experiment_data import ExperimentData
from qiskit_experiments.framework.configs import ExperimentConfig
from qiskit_experiments.database_service import Qubit

from qiskit_ibm_runtime import SamplerV2 as Sampler


class BaseExperiment(ABC, StoreInitArgs):
"""Abstract base class for experiments."""
Expand All @@ -42,7 +41,7 @@ def __init__(
analysis: Optional[BaseAnalysis] = None,
backend: Optional[Backend] = None,
experiment_type: Optional[str] = None,
use_sampler: Options[bool] = False
use_sampler: Options[bool] = False,
):
"""Initialize the experiment object.
Expand Down Expand Up @@ -218,6 +217,7 @@ def run(
it contains one.
timeout: Time to wait for experiment jobs to finish running before
cancelling.
use_sampler: Use the SamplerV2 to run the experiment
run_options: backend runtime options used for circuit execution.
Returns:
Expand Down Expand Up @@ -359,29 +359,31 @@ def _run_jobs(self, circuits: List[QuantumCircuit], **run_options) -> List[Job]:
if self._use_sampler:
sampler = Sampler(self.backend)

#have to hand set some of these options
#see https://docs.quantum.ibm.com/api/qiskit-ibm-runtime/qiskit_ibm_runtime.options.SamplerExecutionOptionsV2
if 'init_qubits' in run_options:
sampler.options.execution.init_qubits = run_options['init_qubits']
if 'rep_delay' in run_options:
sampler.options.execution.rep_delay = run_options['rep_delay']
if 'meas_level' in run_options:
if run_options['meas_level'] == 2:
# have to hand set some of these options
# see https://docs.quantum.ibm.com/api/qiskit-ibm-runtime
# /qiskit_ibm_runtime.options.SamplerExecutionOptionsV2
if "init_qubits" in run_options:
sampler.options.execution.init_qubits = run_options["init_qubits"]
if "rep_delay" in run_options:
sampler.options.execution.rep_delay = run_options["rep_delay"]
if "meas_level" in run_options:
if run_options["meas_level"] == 2:
sampler.options.execution.meas_type = "classified"
elif run_options['meas_level'] == 1:
if 'meas_return' in run_options:
if run_options['meas_return'] == 'avg':
elif run_options["meas_level"] == 1:
if "meas_return" in run_options:
if run_options["meas_return"] == "avg":
sampler.options.execution.meas_type = "avg_kerneled"
else:
sampler.options.execution.meas_type = "kerneled"
else:
#assume this is what is wanted if no meas return specified
# assume this is what is wanted if no meas return specified
sampler.options.execution.meas_type = "kerneled"
else:
raise QiskitError('Only meas level 1 + 2 supported by sampler')
raise QiskitError("Only meas level 1 + 2 supported by sampler")


jobs = [sampler.run(circs, shots=run_options.get('shots', None)) for circs in job_circuits]
jobs = [
sampler.run(circs, shots=run_options.get("shots", None)) for circs in job_circuits
]
else:
jobs = [self.backend.run(circs, **run_options) for circs in job_circuits]

Expand Down
34 changes: 17 additions & 17 deletions qiskit_experiments/framework/experiment_data.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,13 +38,15 @@
from qiskit.exceptions import QiskitError
from qiskit.providers import Job, Backend, Provider
from qiskit.utils.deprecation import deprecate_arg
from qiskit.primitives import BitArray, SamplerPubResult

from qiskit_ibm_experiment import (
IBMExperimentService,
ExperimentData as ExperimentDataclass,
AnalysisResultData as AnalysisResultDataclass,
ResultQuality,
)

from qiskit_experiments.framework.json import ExperimentEncoder, ExperimentDecoder
from qiskit_experiments.database_service.utils import (
plot_to_svg_bytes,
Expand All @@ -68,8 +70,6 @@

from .containers.figure_data import FigureData, FigureType

from qiskit.primitives import BitArray, SamplerPubResult

if TYPE_CHECKING:
# There is a cyclical dependency here, but the name needs to exist for
# Sphinx on Python 3.9+ to link type hints correctly. The gating on
Expand Down Expand Up @@ -604,7 +604,7 @@ def _set_hgp_from_provider(self, provider):
self.hgp = hgp_string
break
except (AttributeError, IndexError, QiskitError):
return
pass

@property
def hgp(self) -> str:
Expand Down Expand Up @@ -987,8 +987,8 @@ def _add_result_data(self, result: Result, job_id: Optional[str] = None) -> None
job_id: The id of the job the result came from. If `None`, the
job id in `result` is used.
"""
if hasattr(result, 'results'):
#backend run results
if hasattr(result, "results"):
# backend run results
if job_id is None:
job_id = result.job_id
if job_id not in self._jobs:
Expand All @@ -1011,9 +1011,9 @@ def _add_result_data(self, result: Result, job_id: Optional[str] = None) -> None
data["meas_return"] = expr_result.meas_return
self._result_data.append(data)
else:
#sampler results
# sampler results
if job_id is None:
raise QiskitError('job_id must be provided, not available in the sampler result')
raise QiskitError("job_id must be provided, not available in the sampler result")
if job_id not in self._jobs:
self._jobs[job_id] = None
self.job_ids.append(job_id)
Expand All @@ -1022,22 +1022,22 @@ def _add_result_data(self, result: Result, job_id: Optional[str] = None) -> None
# Sampler results are a list
for i, _ in enumerate(result):
data = {}
#convert to a Sampler Pub Result (can remove this later when the bug is fixed)
# convert to a Sampler Pub Result (can remove this later when the bug is fixed)
testres = SamplerPubResult(result[i].data, result[i].metadata)
data["job_id"] = job_id
if type(testres.data[next(iter(testres.data))]) is BitArray:
#bit results so has counts
if isinstance(testres.data[next(iter(testres.data))], BitArray):
# bit results so has counts
data["meas_level"] = 2
data["meas_return"] = 'avg'
#join the data
data["meas_return"] = "avg"
# join the data
data["counts"] = testres.join_data(testres.data.keys()).get_counts()
#number of shots
# number of shots
data["shots"] = testres.data[next(iter(testres.data))].num_shots
else:
raise QiskitError("Sampler with meas level 1 support TBD")
data["metadata"] = testres.metadata['circuit_metadata']
raise QiskitError("Sampler with meas level 1 support TBD")

data["metadata"] = testres.metadata["circuit_metadata"]

self._result_data.append(data)

def _retrieve_data(self):
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,8 @@ def __init__(
delay_ops = [delay.operation for delay in interleaved_element.get_instructions("delay")]
if delay_ops:
timing = BackendTiming(backend)
else:
timing = None
for delay_op in delay_ops:
if delay_op.unit != timing.delay_unit:
raise QiskitError(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -281,7 +281,7 @@ def trace_preserving_constaint(

# If not hermitian add imaginary partial trace constraint
if isinstance(mat_i, (tuple, list)):
arg_r = cvxpy.sum(mat_i)
arg_i = cvxpy.sum(mat_i)
elif isinstance(mat_i, Variable):
arg_i = mat_i
else:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ def lstsq_data(
cdim = 1
num_meas_cond = 0
num_prep_cond = 0
bsize = None

# Get full and conditional measurement basis dimensions
if measurement_basis:
Expand Down
2 changes: 1 addition & 1 deletion qiskit_experiments/test/pulse_backend.py
Original file line number Diff line number Diff line change
Expand Up @@ -544,7 +544,7 @@ def __init__(
**kwargs,
)

self._defaults = PulseDefaults.from_dict(
self._defaults = PulseDefaults.from_dict( # pylint: disable=no-member
{
"qubit_freq_est": [qubit_frequency / 1e9],
"meas_freq_est": [0],
Expand Down
1 change: 1 addition & 0 deletions qiskit_experiments/test/t2hahn_backend.py
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ def run(self, dag: DAGCircuit):

if node.name == "delay":
q0 = qubit_indices[node.qargs[0]]
duration = 0
if self.qubit_frequencies[q0] is None:
continue
if node.op.unit == "dt":
Expand Down
4 changes: 2 additions & 2 deletions requirements-dev.txt
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# Linters
black~=22.0
pylint~=3.0.2
astroid~=3.0.1 # Must be kept aligned to what pylint wants
pylint~=3.3.1
astroid~=3.3.4 # Must be kept aligned to what pylint wants

# Test runner tools
coverage>=5.5
Expand Down
2 changes: 2 additions & 0 deletions test/library/tomography/test_process_tomography.py
Original file line number Diff line number Diff line change
Expand Up @@ -547,6 +547,8 @@ def test_qpt_conditional_circuit(self, circuit_clbits):
targets = [4 * i.expand(j) for j in [proj0, proj1] for i in [proj0, proj1]]
elif circuit_clbits == [1, 0]:
targets = [4 * i.expand(j) for j in [proj0, proj1] for i in [proj0, proj1]]
else:
targets = None
num_cond = len(circuit_clbits)
prob_target = 0.5**num_cond
for fitter in FITTERS:
Expand Down

0 comments on commit d796ea3

Please sign in to comment.